正如 cmets 中的 @bdecaf 所指出的,您可以编写一个事件处理程序来处理 z-ticks 何时发生变化,以便相应地自定义刻度标签。这是使用undocumentedfunctionality。
这很方便,因为我们仍然让 MATLAB 根据轴可用的屏幕空间自动决定使用的最佳刻度数,我们只需自定义显示标签的格式。
示例:
function customize_ticks_example()
% data
[adj,XYZ] = bucky;
[r,c] = find(adj);
edges = [r c];
points = XYZ';
e = edges';
e(end+1,:) = 1;
e = e(:);
p = points(:,e);
p(:,3:3:end) = NaN;
% plot
hFig = figure;
line(p(1,:), p(2,:), p(3,:), ...
'LineWidth',2, 'Marker','.', 'MarkerSize',20);
ax = handle(gca);
view(3), grid on, box on
xlabel x, ylabel y, zlabel z
rotate3d on
% listen to changes on ZTick property
ev = handle.listener(ax, findprop(ax,'ZTick'), ...
'PropertyPostSet', @onZTickChange);
setappdata(hFig, 'my_ztick_listener', ev);
end
function onZTickChange(~,e)
% get the new 'ZTick', and format them as needed
labels = num2str(e.NewValue(:),'%g $');
% update the 'ZTickLabel'
set(double(e.AffectedObject), 'ZTickLabel',labels)
end
当然,标签不必是数字,您可以使用任何自定义标签,只要您有某种比例尺,您可以沿着该比例尺插入值来确定要使用的标签。
编辑:
set the event listener 的更简单方法:
ev = addlistener(gca, 'ZTick', 'PostSet', @onZTickChange);
(在这种情况下,无需将ev 与setappdata 一起存储在GUI 中。This syntax 将监听器绑定到GUI 对象的生命周期)。
编辑 2:
针对cmets,这里再举一个例子:
function example_manual_ticks
%% some 3d plot
hFig = figure;
sphere
view(3), grid on, box on
xlabel x, ylabel y, zlabel z
%% create a hidden copy of the axis
hax1 = gca;
hax2 = copyobj(hax1, hFig);
set(hax2, 'Visible','off', 'Color','none', 'HitTest','off', ...
'XLimMode','manual', 'YLimMode','manual', 'ZLimMode','manual')
delete(get(hax2, 'Children'))
uistack(hax2, 'bottom')
% sync axes on 3d rotation
hlink = linkprop([hax1,hax2], {'CameraPosition','CameraUpVector'});
setappdata(hax1, 'my_axes_linkprop', hlink);
rotate3d on
% respnd to changes in ZTick axis property
ev = addlistener(hax2, 'ZTick', 'PostSet',@(o,e) onZTickChange(o,e,hax1));
%% animation
el = 90 .* sin(linspace(0,2*pi,100) + asin(1/3));
for n=1:numel(el)
view(-37.5, el(n))
drawnow
end
end
function onZTickChange(~,e,ax)
% determine number of ticks
num_ticks = numel(e.NewValue);
new_num_ticks = num_ticks - 1;
% interpolate new ticks along the axis limits
limits = get(ax, 'ZLim');
zticks = linspace(limits(1), limits(2), new_num_ticks);
zticks_labels = num2str(zticks(:), '%.2f ($)');
% update ticks
set(ax, 'ZTick',zticks, 'ZTickLabel',zticks_labels)
drawnow
end
这个想法是创建一个隐藏的copy 轴,kept in sync 与原始的 3D 旋转。这第二个轴将具有自动刻度线,而我们根据需要自定义第一个轴的刻度(类似于我们在隐藏轴上注册回调以了解刻度变化时)。
我再次使用这个隐藏轴作为让 MATLAB 处理确定给定视图的最佳刻度数的任务的一种方式(这比为了找出答案而弄乱相机角度和矩阵变换要容易得多投影轴的长度(以像素为单位)。
在上面的示例中,我只是将刻度数设置为比自动数少一({2,4,10} 而不是 {3,5,11}),但您可以使用任何类型的映射。