我想绘制一个带有填充标记的散点图并使它们半透明,因此当两个或多个标记重叠时,重叠区域将更加不透明。
我天真地以为
sg = scatter(rand(1000,1),rand(1000,1), 'filled');
alpha(0.5)
会工作,但它不会。还
set(get(sg, 'Children'), 'FaceAlpha', 0.2)
不起作用。有任何想法吗?
我想绘制一个带有填充标记的散点图并使它们半透明,因此当两个或多个标记重叠时,重叠区域将更加不透明。
我天真地以为
sg = scatter(rand(1000,1),rand(1000,1), 'filled');
alpha(0.5)
会工作,但它不会。还
set(get(sg, 'Children'), 'FaceAlpha', 0.2)
不起作用。有任何想法吗?
这是一些使用补丁对象制作透明散点图的示例 matlab 代码:
x=randn(5000,1)*20;
y= randn(5000,1)*20;
t= 0:pi/10:2*pi;
figure();
for i=1:size(x)
pb=patch((sin(t)+ x(i)),(cos(t)+y(i)),'b','edgecolor','none');
alpha(pb,.1);
end
您实际上可以在不使用补丁的情况下进行此操作。下面的示例使用隐藏的 MarkerHandle 让您访问透明度。您只需提供所需颜色的 rgb 代码和相同比例的透明度级别。下面的示例将随机标记绘制为透明红色,不透明度为 10%,设置FaceColorData
为uint8(255*[1;0;0;0.1])
sg = scatter(rand(1000,1),rand(1000,1), 'filled');
sMarkers=sg.MarkerHandle; %hidden marker handle
sMarkers.FaceColorData = uint8(255*[1;0;0;0.1]); %fourth element allows setting alpha
sMarkers.EdgeColorData = uint8(255*[1;0;0;0]); %set edge color in a similar way
编辑:当您调整大小、保存...或者显然只是看起来很有趣时,MATLAB 似乎会在没有警告的情况下更改这些属性。
基于http://undocumentedmatlab.com/blog/plot-markers-transparency-and-color-gradient
我不确定以前的版本,但 Matlab 2016 似乎具有您正在寻找的功能:
sg = scatter(rand(1000,1),rand(1000,1), '填充');
sg.MarkerFaceAlpha = 0.1;
这是我用来创建半透明散点图的函数。
* 这是user2149589答案的修改版本(对 matlab 更友好一点)。
function scatterPoints = transparentScatter(x,y,sizeOfCirlce,opacity)
% usage example:
% scatterPoints = transparentScatter(randn(5000,1),randn(5000,1),0.1,0.05);
% set(scatterPoints,'FaceColor',[1,0,0]);
defaultColors = get(0,'DefaultAxesColorOrder');
assert(size(x,2) == 1 && size(y,2) == 1 , 'x and y should be column vectors');
t= 0:pi/10:2*pi;
rep_x = repmat(x',[size(t,2),1]);
rep_y = repmat(y',[size(t,2),1]);
rep_t = repmat(t',[ 1, size(x,1)]);
scatterPoints = patch((sizeOfCirlce*sin(rep_t)+ rep_x),(sizeOfCirlce*cos(rep_t)+rep_y),defaultColors(1,:),'edgecolor','none');
alpha(scatterPoints,opacity);
end
上面的代码是一个不错的小函数(对于我们这些仍然在 2014b 之前的人),但可以通过调用“DataAspectRatio”和调整补丁大小来确保圆圈看起来像圆圈:
function scatterPoints = transparentScatter(x,y,sizeOfCirlce,opacity)
% usage example:
% scatterPoints = transparentScatter(randn(5000,1),randn(5000,1),0.1,0.05);
% set(scatterPoints,'FaceColor',[1,0,0]);
dRatio = get(gca,'DataAspectRatio');
dRatio = dRatio(1) / dRatio(2);
defaultColors = get(0,'DefaultAxesColorOrder');
assert(size(x,2) == 1 && size(y,2) == 1 , 'x and y should be column vectors');
t= 0:pi/10:2*pi;
rep_x = repmat(x',[size(t,2),1]);
rep_y = repmat(y',[size(t,2),1]);
rep_t = repmat(t',[ 1, size(x,1)]);
scatterPoints = patch((dRatio*sizeOfCirlce*sin(rep_t)+ rep_x),(sizeOfCirlce*cos(rep_t)+rep_y),defaultColors(1,:),'edgecolor','none');
alpha(scatterPoints,opacity);
end