forked from mporter-gre/mtools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
createRenderedImage.m
97 lines (89 loc) · 3.91 KB
/
createRenderedImage.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
function renderedImage = createRenderedImage(fullImage, pixels)
%Do renderedImage = createRenderedImage(fullImage, pixels)
%
%Author Michael Porter
% Copyright (C) 2009-2014 University of Dundee.
% All rights reserved.
%
% This program is free software; you can redistribute it and/or modify
% it under the terms of the GNU General Public License as published by
% the Free Software Foundation; either version 2 of the License, or
% (at your option) any later version.
%
% This program is distributed in the hope that it will be useful,
% but WITHOUT ANY WARRANTY; without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% GNU General Public License for more details.
%
% You should have received a copy of the GNU General Public License along
% with this program; if not, write to the Free Software Foundation, Inc.,
% 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
global session;
%[client session gateway] = gatewayConnect(credentials{1}, credentials{2}, credentials{3});
if strcmp(class(pixels), 'java.util.ArrayList');
pixels = pixels.get(0);
end
fullImage = double(fullImage);
%maxVal = maxOfType(pixels);
pixelsId = pixels.getId.getValue;
numChannels = pixels.getSizeC.getValue;
sizeX = pixels.getSizeX.getValue;
sizeY = pixels.getSizeY.getValue;
renderingService = session.getRenderingSettingsService;
renderingSettings = renderingService.getRenderingSettings(pixelsId);
renderingModel = renderingSettings.getModel.getValue.getValue;
fullImageScaled = zeros(sizeY, sizeX, numChannels);
pixelsDescription = session.getPixelsService.retrievePixDescription(pixelsId);
for thisChannel = 1:numChannels
channelBinding = renderingSettings.getChannelBinding(thisChannel-1);
redVal(thisChannel) = channelBinding.getRed.getValue;
greenVal(thisChannel) = channelBinding.getGreen.getValue;
blueVal(thisChannel) = channelBinding.getBlue.getValue;
active(thisChannel) = channelBinding.getActive.getValue;
startVal = channelBinding.getInputStart.getValue;
endVal = channelBinding.getInputEnd.getValue;
globalMax = pixelsDescription.getChannel(thisChannel-1).getStatsInfo.getGlobalMax.getValue;
if startVal < 1
startVal = 1;
end
globalMaxScaled = endVal/globalMax;
startValScaled = startVal/globalMax;
if globalMaxScaled > 1
globalMaxScaled = 1;
startValScaled = 0.5;
end
fullImage(:,:,thisChannel) = fullImage(:,:,thisChannel)./globalMax;
fullImageScaled(:,:,thisChannel) = imadjust(fullImage(:,:,thisChannel), [startValScaled globalMaxScaled], []);
end
[blah activeIdx] = find(active);
numActiveChannels = length(activeIdx);
renderedImage = zeros(sizeY, sizeX, 3);
if strcmp(renderingModel, 'greyscale')
if redVal(activeIdx) > 0
greyLevel = redVal(activeIdx);
elseif greenVal(activeIdx) > 0
greyLevel = greenVal(activeIdx);
elseif blueVal(activeIdx) > 0
greyLevel = blueVal(activeIdx);
end
for thisRGB = 1:3
renderedImage(:,:,thisRGB) = fullImageScaled(:,:,activeIdx).*greyLevel/255;
end
else
for thisActiveChannel = 1:numActiveChannels
if redVal(activeIdx(thisActiveChannel)) ~= 0
thisRedImage = fullImageScaled(:,:,activeIdx(thisActiveChannel)).*(redVal(activeIdx(thisActiveChannel))/255);
renderedImage(:,:,1) = renderedImage(:,:,1) + thisRedImage;
end
if greenVal(activeIdx(thisActiveChannel)) ~= 0
thisGreenImage = fullImageScaled(:,:,activeIdx(thisActiveChannel)).*(greenVal(activeIdx(thisActiveChannel))/255);
renderedImage(:,:,2) = renderedImage(:,:,2) + thisGreenImage;
end
if blueVal(activeIdx(thisActiveChannel)) ~= 0
thisBlueImage = fullImageScaled(:,:,activeIdx(thisActiveChannel)).*(blueVal(activeIdx(thisActiveChannel))/255);
renderedImage(:,:,3) = renderedImage(:,:,3) + thisBlueImage;
end
end
end
renderedImage = double(renderedImage);
disp('');