/
getAnnotations.m
68 lines (61 loc) · 2.6 KB
/
getAnnotations.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
function annotations = getAnnotations(session, ids, type, varargin)
% GETANNOTATIONS Retrieve annotations from a given type from the OMERO server
%
% annotations = getAnnotations(session, ids, type) returns all the
% annotations identified by the input ids of the specified type.
%
% Examples:
%
% annotations = getAnnotations(session, ids, type);
% annotations = getAnnotations(session, ids, type, 'group', groupId);
% returns annoations from the input group specfied by groupId.
%
% See also: GETANNOTATIONTYPES, GETDOUBLEANNOTATIONS, GETCOMMENTANNOTATIONS,
% GETFILEANNOTATIONS, GETLONGANNOTATIONS, GETTAGANNOTATIONS,
% GETTIMESTAMPANNOTATIONS, GETXMLANNOTATIONS
% Copyright (C) 2013-2015 University of Dundee & Open Microscopy Environment.
% 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.
% Check input
annotationTypes = getAnnotationTypes();
annotationNames = {annotationTypes.name};
ip = inputParser;
ip.addRequired('session');
ip.addRequired('ids', @(x) isvector(x) || ~isempty(x));
ip.addRequired('type', @(x) ischar(x) && ismember(x, annotationNames));
ip.addParameter('group', [], @(x) isscalar(x) && isnumeric(x));
ip.parse(session, ids, type, varargin{:});
annotationType = annotationTypes(strcmp(type, annotationNames));
% Create list of annotations identifiers to load
ids = toJavaList(ip.Results.ids, 'java.lang.Long');
% Create container service to load annotations
context = java.util.HashMap;
if ~isempty(ip.Results.group)
context.put(...
'omero.group', java.lang.String(num2str(ip.Results.group)));
else
context.put('omero.group', '-1');
end
service = session.getMetadataService();
annotationList = service.loadAnnotation(ids, context);
% Filter annotation list by annotation class
for i = annotationList.size - 1 : -1 : 0
if ~isa(annotationList.get(i), annotationType.class)
annotationList.remove(i);
end
end
% Convert java.util.ArrayList into Matlab arrays
annotations = toMatlabList(annotationList);