Hello,
I am trying to take this binary 3D plot and color code the layers by depth. For example if z =1, all pixels are red; if z = 25, all pixels are orange, etc...I would like the color scale to be continuous. Any help on this would be appreciated. This is what I have thus far:
stack = tiff(:,:,:);
T = adaptthresh(stack, 0.57,'neigh', [99 99 99], 'ForegroundPolarity', 'dark');
bw = imbinarize(stack,T); %applies adaptive threshold to image
x = 1:size(stack,2);
y = 1:size(stack,1);
z = 1:size(stack,3);
figure(1),isosurface(x,y,z,stack,0.5)
pores.png

댓글 수: 1

Brian Hart
Brian Hart 2019년 1월 22일
You can probably do this by changing the figure color map. It would help to have the input TIFF file to play with.

댓글을 달려면 로그인하십시오.

 채택된 답변

Walter Roberson
Walter Roberson 2019년 1월 22일

0 개 추천

See https://www.mathworks.com/help/matlab/ref/isosurface.html#bq349vy-1 for an example of coloring by x. In the isosurface() call in that example, you would replace the final x by z to color by z.

댓글 수: 5

I tried this, and my code now looks like this, but I'm getting the error 'COLORS array must be the same size as V.' I am not sure how to get around this issue. Any advice?
stack = tiff(:,:,:);
T = adaptthresh(stack, 0.57,'neigh', [99 99 99], 'ForegroundPolarity', 'dark');
bw = imbinarize(stack,T); %applies adaptive threshold to image
x = 1:size(stack,2);
y = 1:size(stack,1);
z = 1:size(stack,3);
[faces,verts,colors] = isosurface(x,y,z,bw2,0.5,z);
patch('Vertices',verts,'Faces',faces,'FaceVertexCData',colors,...
'FaceColor','interp','EdgeColor','interp')
view(30,-15)
axis vis3d
colormap jet
What is bw2 ? You create bw here but not bw2.
[X, Y, Z] = meshgrid(X, Y, Z);
[faces,verts,colors] = isosurface(X, Y, Z, bw, 0.5, Z);
sorry...
bw2 is the same as stack. I copied an abreviated version of my code here for simplicity. It should read:
stack = tiff(:,:,:);
T = adaptthresh(stack, 0.57,'neigh', [99 99 99], 'ForegroundPolarity', 'dark');
bw = imbinarize(stack,T); %applies adaptive threshold to image
x = 1:size(stack,2);
y = 1:size(stack,1);
z = 1:size(stack,3);
[faces,verts,colors] = isosurface(x,y,z,stack,0.5,z);
patch('Vertices',verts,'Faces',faces,'FaceVertexCData',colors,...
'FaceColor','interp','EdgeColor','interp')
view(30,-15)
axis vis3d
colormap jet
Walter Roberson
Walter Roberson 2019년 1월 22일
Then the two lines I suggested should probably work.
Emily Pendleton
Emily Pendleton 2019년 1월 23일
It does, thank you!

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by