diff --git a/girder_annotation/docs/annotations.rst b/girder_annotation/docs/annotations.rst index 041e0856a..0892a1b62 100644 --- a/girder_annotation/docs/annotations.rst +++ b/girder_annotation/docs/annotations.rst @@ -16,16 +16,16 @@ the comments are not part of a valid annotation: :: - { - "name": "MyAnnotationName", # Non-empty string. Optional - "description": "This is a description", # String. Optional - "attributes": { # Object. Optional - "key1": "value1", - "key2": ["any", {"value": "can"}, "go", "here"] - }, - "elements": [] # A list. Optional. - # See below for valid elements. - } + { + "name": "MyAnnotationName", # Non-empty string. Optional + "description": "This is a description", # String. Optional + "attributes": { # Object. Optional + "key1": "value1", + "key2": ["any", {"value": "can"}, "go", "here"] + }, + "elements": [] # A list. Optional. + # See below for valid elements. + } Elements -------- @@ -42,20 +42,22 @@ it is not allowed. If element IDs are specified, they must be unique. :: - { - "type": "point", # Exact string for the specific shape. Required - "id": "0123456789abcdef01234567", # String, 24 lowercase hexadecimal digits. Optional. - "label": { # Object. Optional - "value": "This is a label", # String. Optional - "visibility": "hidden", # String. One of "always", "hidden", "onhover". Optional - "fontSize": 3.4, # Number. Optional - "color": "#0000FF" # String. See note about colors. Optional - }, - "lineColor": "#000000", # String. See note about colors. Optional - "lineWidth": 1, # Number >= 0. Optional - "group": "group name", # String. Optional - - } + { + "type": "point", # Exact string for the specific shape. Required + "id": "0123456789abcdef01234567", # String, 24 lowercase hexadecimal digits. Optional. + "label": { # Object. Optional + "value": "This is a label", # String. Optional + "visibility": "hidden", # String. One of "always", "hidden", "onhover". Optional + "fontSize": 3.4, # Number. Optional + "color": "#0000FF" # String. See note about colors. Optional + }, + "lineColor": "#000000", # String. See note about colors. Optional + "lineWidth": 1, # Number >= 0. Optional + "group": "group name", # String. Optional + "user": {}, # User properties -- this can contain anything, + # but should be kept small. Optional. + + } Arrow ~~~~~ @@ -64,14 +66,14 @@ Not currently rendered. :: - { - "type": "arrow", # Exact string. Required - # Optional general shape properties - "points": [ # Arrows ALWAYS have two points - [5,6,0], # Coordinate. Arrow head. Required - [-17,6,0] # Coordinate. Aroow tail. Required - ] - } + { + "type": "arrow", # Exact string. Required + # Optional general shape properties + "points": [ # Arrows ALWAYS have two points + [5,6,0], # Coordinate. Arrow head. Required + [-17,6,0] # Coordinate. Aroow tail. Required + ] + } Circle ~~~~~~ @@ -80,13 +82,13 @@ Not currently rendered. :: - { - "type": "circle", # Exact string. Required - # Optional general shape properties - "center": [10.3, -40.0, 0], # Coordinate. Required - "radius": 5.3, # Number >= 0. Required - "fillColor": "#0000fF", # String. See note about colors. Optional - } + { + "type": "circle", # Exact string. Required + # Optional general shape properties + "center": [10.3, -40.0, 0], # Coordinate. Required + "radius": 5.3, # Number >= 0. Required + "fillColor": "#0000fF", # String. See note about colors. Optional + } Ellipse ~~~~~~~ @@ -97,28 +99,28 @@ The width and height of an ellipse are the major and minor axes. :: - { - "type": "rectangle", # Exact string. Required - # Optional general shape properties - "center": [10.3, -40.0, 0], # Coordinate. Required - "width": 5.3, # Number >= 0. Required - "height": 17.3, # Number >= 0. Required - "rotation": 0, # Number. Counterclockwise radians around normal. Required - "normal": [0, 0, 1.0], # Three numbers specifying normal. Default is positive Z. - # Optional - "fillColor": "rgba(0, 255, 0, 1)" # String. See note about colors. Optional - } + { + "type": "rectangle", # Exact string. Required + # Optional general shape properties + "center": [10.3, -40.0, 0], # Coordinate. Required + "width": 5.3, # Number >= 0. Required + "height": 17.3, # Number >= 0. Required + "rotation": 0, # Number. Counterclockwise radians around normal. Required + "normal": [0, 0, 1.0], # Three numbers specifying normal. Default is positive Z. + # Optional + "fillColor": "rgba(0, 255, 0, 1)" # String. See note about colors. Optional + } Point ~~~~~ :: - { - "type": "point", # Exact string. Required - # Optional general shape properties - "center": [123.3, 144.6, -123] # Coordinate. Required - } + { + "type": "point", # Exact string. Required + # Optional general shape properties + "center": [123.3, 144.6, -123] # Coordinate. Required + } Polyline ~~~~~~~~ @@ -127,34 +129,34 @@ When closed, this is a polygon. When open, this is a continuous line. :: - { - "type": "polyline", # Exact string. Required - # Optional general shape properties - "points": [ # At least two points must be specified - [5,6,0], # Coordinate. At least two required - [-17,6,0], - [56,-45,6] - ], - "closed": true, # Boolean. Default is false. Optional - "fillColor": "rgba(0, 255, 0, 1)" # String. See note about colors. Optional - } + { + "type": "polyline", # Exact string. Required + # Optional general shape properties + "points": [ # At least two points must be specified + [5,6,0], # Coordinate. At least two required + [-17,6,0], + [56,-45,6] + ], + "closed": true, # Boolean. Default is false. Optional + "fillColor": "rgba(0, 255, 0, 1)" # String. See note about colors. Optional + } Rectangle ~~~~~~~~~ :: - { - "type": "rectangle", # Exact string. Required - # Optional general shape properties - "center": [10.3, -40.0, 0], # Coordinate. Required - "width": 5.3, # Number >= 0. Required - "height": 17.3, # Number >= 0. Required - "rotation": 0, # Number. Counterclockwise radians around normal. Required - "normal": [0, 0, 1.0], # Three numbers specifying normal. Default is positive Z. - # Optional - "fillColor": "rgba(0, 255, 0, 1)" # String. See note about colors. Optional - } + { + "type": "rectangle", # Exact string. Required + # Optional general shape properties + "center": [10.3, -40.0, 0], # Coordinate. Required + "width": 5.3, # Number >= 0. Required + "height": 17.3, # Number >= 0. Required + "rotation": 0, # Number. Counterclockwise radians around normal. Required + "normal": [0, 0, 1.0], # Three numbers specifying normal. Default is positive Z. + # Optional + "fillColor": "rgba(0, 255, 0, 1)" # String. See note about colors. Optional + } Rectangle Grid ~~~~~~~~~~~~~~ @@ -166,19 +168,19 @@ such as that used to show a regular scale grid overlay on an image. :: - { - "type": "rectanglegrid", # Exact string. Required - # Optional general shape properties - "center": [10.3, -40.0, 0], # Coordinate. Required - "width": 5.3, # Number >= 0. Required - "height": 17.3, # Number >= 0. Required - "rotation": 0, # Number. Counterclockwise radians around normal. Required - "normal": [0, 0, 1.0], # Three numbers specifying normal. Default is positive Z. - # Optional - "widthSubdivisions": 3, # Integer > 0. Required - "heightSubdivisions": 4, # Integer > 0. Required - "fillColor": "rgba(0, 255, 0, 1)" # String. See note about colors. Optional - } + { + "type": "rectanglegrid", # Exact string. Required + # Optional general shape properties + "center": [10.3, -40.0, 0], # Coordinate. Required + "width": 5.3, # Number >= 0. Required + "height": 17.3, # Number >= 0. Required + "rotation": 0, # Number. Counterclockwise radians around normal. Required + "normal": [0, 0, 1.0], # Three numbers specifying normal. Default is positive Z. + # Optional + "widthSubdivisions": 3, # Integer > 0. Required + "heightSubdivisions": 4, # Integer > 0. Required + "fillColor": "rgba(0, 255, 0, 1)" # String. See note about colors. Optional + } Heatmap ~~~~~~~ @@ -188,27 +190,27 @@ near by values aggregate together when viewed. :: - { - "type": "heatmap", # Exact string. Required - # Optional general shape properties - "points": [ # A list of coordinate-value entries. Each is x, y, z, value. - [32320, 48416, 0, 0.192], - [40864, 109568, 0, 0.87], - [53472, 63392, 0, 0.262], - [23232, 96096, 0, 0.364], - [10976, 93376, 0, 0.2], - [42368, 65248, 0, 0.054] - ], - "radius": 25, # Positive number. Optional. The size of the gaussian plot - # spread - "colorRange": ["rgba(0, 0, 0, 0)", "rgba(255, 255, 0, 1)"], # A list of colors corresponding to - # the rangeValues. Optional - "rangeValues: [0, 1], # A list of range values corresponding to the colorRange list - # and possibly normalized to a scale of [0, 1]. Optional - "normalizeRange": true # If true, the rangeValues are normalized to [0, 1]. If - # false, the rangeValues are in the - # value domain. Defaults to true. Optional - } + { + "type": "heatmap", # Exact string. Required + # Optional general shape properties + "points": [ # A list of coordinate-value entries. Each is x, y, z, value. + [32320, 48416, 0, 0.192], + [40864, 109568, 0, 0.87], + [53472, 63392, 0, 0.262], + [23232, 96096, 0, 0.364], + [10976, 93376, 0, 0.2], + [42368, 65248, 0, 0.054] + ], + "radius": 25, # Positive number. Optional. The size of the gaussian plot + # spread + "colorRange": ["rgba(0, 0, 0, 0)", "rgba(255, 255, 0, 1)"], # A list of colors corresponding to + # the rangeValues. Optional + "rangeValues: [0, 1], # A list of range values corresponding to the colorRange list + # and possibly normalized to a scale of [0, 1]. Optional + "normalizeRange": true # If true, the rangeValues are normalized to [0, 1]. If + # false, the rangeValues are in the + # value domain. Defaults to true. Optional + } Grid Data ~~~~~~~~~ @@ -218,54 +220,54 @@ choropleth, a grid with a list of values can be specified. :: - { - "type": "griddata", # Exact string. Required - # Optional general shape properties - "interpretation": "contour", # One of heatmap, contour, or choropleth - "gridWidth": 6, # Number of values across the grid. Required - "origin": [0, 0, 0], # Origin including fized x value. Optional - "dx": 32, # Grid spacing in x. Optional - "dy": 32, # Grid spacing in y. Optional - "colorRange": ["rgba(0, 0, 0, 0)", "rgba(255, 255, 0, 1)"], # A list of colors corresponding to - # the rangeValues. Optional - "rangeValues: [0, 1], # A list of range values corresponding to the colorRange list. - # This should have the same number of entries as colorRange - # unless a contour where stepped is true. Possibly normalized - # to a scale of [0, 1]. Optional - "normalizeRange": false, # If true, the rangeValues are normalized to [0, 1]. If - # false, the rangeValues are in the value domain. Defaults to - # true. Optional - "minColor": "rgba(0, 0, 255, 1)", # The color of data below the minimum range. Optional - "maxColor": "rgba(255, 255, 0, 1)", # The color of data above the maximum range. Optional - "stepped": true, # For contours, whether discrete colors or continuous colors - # should be used. Default false. Optional - "values": [ - 0.508, - 0.806, - 0.311, - 0.402, - 0.535, - 0.661, - 0.866, - 0.31, - 0.241, - 0.63, - 0.555, - 0.067, - 0.668, - 0.164, - 0.512, - 0.647, - 0.501, - 0.637, - 0.498, - 0.658, - 0.332, - 0.431, - 0.053, - 0.531 - ] - } + { + "type": "griddata", # Exact string. Required + # Optional general shape properties + "interpretation": "contour", # One of heatmap, contour, or choropleth + "gridWidth": 6, # Number of values across the grid. Required + "origin": [0, 0, 0], # Origin including fized x value. Optional + "dx": 32, # Grid spacing in x. Optional + "dy": 32, # Grid spacing in y. Optional + "colorRange": ["rgba(0, 0, 0, 0)", "rgba(255, 255, 0, 1)"], # A list of colors corresponding to + # the rangeValues. Optional + "rangeValues: [0, 1], # A list of range values corresponding to the colorRange list. + # This should have the same number of entries as colorRange + # unless a contour where stepped is true. Possibly normalized + # to a scale of [0, 1]. Optional + "normalizeRange": false, # If true, the rangeValues are normalized to [0, 1]. If + # false, the rangeValues are in the value domain. Defaults to + # true. Optional + "minColor": "rgba(0, 0, 255, 1)", # The color of data below the minimum range. Optional + "maxColor": "rgba(255, 255, 0, 1)", # The color of data above the maximum range. Optional + "stepped": true, # For contours, whether discrete colors or continuous colors + # should be used. Default false. Optional + "values": [ + 0.508, + 0.806, + 0.311, + 0.402, + 0.535, + 0.661, + 0.866, + 0.31, + 0.241, + 0.63, + 0.555, + 0.067, + 0.668, + 0.164, + 0.512, + 0.647, + 0.501, + 0.637, + 0.498, + 0.658, + 0.332, + 0.431, + 0.053, + 0.531 + ] + } Image overlays ~~~~~~~~~~~~~~ @@ -278,21 +280,22 @@ a ``2x2`` affine matrix. :: - { - "type": "imageoverlay", # Exact string. Required - "girderId": , # 24-character girder id pointing - # to a large image object. Required - "opacity": 1, # Default opacity for the overlay. Defaults to 1. Optional - "transform": { # Object specifying additional overlay information. Optional - "xoffset": 0, # How much to shift the overlaid image right. - "yoffset": 0, # How much to shift the overlaid image down. - "matrix": [ # Affine matrix to specify tranformations like scaling, - # rotation, or shearing. - [1, 0], - [0, 1] - ] - } + { + "type": "imageoverlay", # Exact string. Required + # Optional general shape properties + "girderId": , # 24-character girder id pointing + # to a large image object. Required + "opacity": 1, # Default opacity for the overlay. Defaults to 1. Optional + "transform": { # Object specifying additional overlay information. Optional + "xoffset": 0, # How much to shift the overlaid image right. + "yoffset": 0, # How much to shift the overlaid image down. + "matrix": [ # Affine matrix to specify transformations like scaling, + # rotation, or shearing. + [1, 0], + [0, 1] + ] } + } Component Values ---------------- @@ -322,66 +325,66 @@ A sample that shows off a valid annotation: :: - { - "name": "AnnotationName", - "description": "This is a description", - "attributes": { - "key1": "value1", - "key2": ["any", {"value": "can"}, "go", "here"] - }, - "elements": [{ - "type": "point", - "label": { - "value": "This is a label", - "visibility": "hidden", - "fontSize": 3.4 - }, - "lineColor": "#000000", - "lineWidth": 1, - "center": [123.3, 144.6, -123] - },{ - "type": "arrow", - "points": [ - [5,6,0], - [-17,6,0] - ], - "lineColor": "rgba(128, 128, 128, 0.5)" - },{ - "type": "circle", - "center": [10.3, -40.0, 0], - "radius": 5.3, - "fillColor": "#0000fF", - "lineColor": "rgb(3, 6, 8)" - },{ - "type": "rectangle", - "center": [10.3, -40.0, 0], - "width": 5.3, - "height": 17.3, - "rotation": 0, - "fillColor": "rgba(0, 255, 0, 1)" - },{ - "type": "ellipse", - "center": [3.53, 4.8, 0], - "width": 15.7, - "height": 7.1, - "rotation": 0.34, - "fillColor": "rgba(128, 255, 0, 0.5)" - },{ - "type": "polyline", - "points": [ - [5,6,0], - [-17,6,0], - [56,-45,6] - ], - "closed": true - },{ - "type": "rectanglegrid", - "id": "0123456789abcdef01234567", - "center": [10.3, -40.0, 0], - "width": 5.3, - "height": 17.3, - "rotation": 0, - "widthSubdivisions": 3, - "heightSubdivisions": 4 - }] - } + { + "name": "AnnotationName", + "description": "This is a description", + "attributes": { + "key1": "value1", + "key2": ["any", {"value": "can"}, "go", "here"] + }, + "elements": [{ + "type": "point", + "label": { + "value": "This is a label", + "visibility": "hidden", + "fontSize": 3.4 + }, + "lineColor": "#000000", + "lineWidth": 1, + "center": [123.3, 144.6, -123] + },{ + "type": "arrow", + "points": [ + [5,6,0], + [-17,6,0] + ], + "lineColor": "rgba(128, 128, 128, 0.5)" + },{ + "type": "circle", + "center": [10.3, -40.0, 0], + "radius": 5.3, + "fillColor": "#0000fF", + "lineColor": "rgb(3, 6, 8)" + },{ + "type": "rectangle", + "center": [10.3, -40.0, 0], + "width": 5.3, + "height": 17.3, + "rotation": 0, + "fillColor": "rgba(0, 255, 0, 1)" + },{ + "type": "ellipse", + "center": [3.53, 4.8, 0], + "width": 15.7, + "height": 7.1, + "rotation": 0.34, + "fillColor": "rgba(128, 255, 0, 0.5)" + },{ + "type": "polyline", + "points": [ + [5,6,0], + [-17,6,0], + [56,-45,6] + ], + "closed": true + },{ + "type": "rectanglegrid", + "id": "0123456789abcdef01234567", + "center": [10.3, -40.0, 0], + "width": 5.3, + "height": 17.3, + "rotation": 0, + "widthSubdivisions": 3, + "heightSubdivisions": 4 + }] + } diff --git a/girder_annotation/girder_large_image_annotation/models/annotation.py b/girder_annotation/girder_large_image_annotation/models/annotation.py index 39079a862..87c509e93 100644 --- a/girder_annotation/girder_large_image_annotation/models/annotation.py +++ b/girder_annotation/girder_large_image_annotation/models/annotation.py @@ -99,6 +99,28 @@ class AnnotationSchema: 'additionalProperties': True } + labelSchema = { + 'type': 'object', + 'properties': { + 'value': {'type': 'string'}, + 'visibility': { + 'type': 'string', + # TODO: change to True, False, None? + 'enum': ['hidden', 'always', 'onhover'] + }, + 'fontSize': { + 'type': 'number', + 'minimum': 0, + 'exclusiveMinimum': True, + }, + 'color': colorSchema, + }, + 'required': ['value'], + 'additionalProperties': False + } + + groupSchema = {'type': 'string'} + baseShapeSchema = { '$schema': 'http://json-schema.org/schema#', 'id': '/girder/plugins/large_image/models/base_shape', @@ -111,31 +133,13 @@ class AnnotationSchema: 'type': {'type': 'string'}, # schema free field for users to extend annotations 'user': userSchema, - 'label': { - 'type': 'object', - 'properties': { - 'value': {'type': 'string'}, - 'visibility': { - 'type': 'string', - # TODO: change to True, False, None? - 'enum': ['hidden', 'always', 'onhover'] - }, - 'fontSize': { - 'type': 'number', - 'minimum': 0, - 'exclusiveMinimum': True, - }, - 'color': colorSchema, - }, - 'required': ['value'], - 'additionalProperties': False - }, + 'label': labelSchema, 'lineColor': colorSchema, 'lineWidth': { 'type': 'number', 'minimum': 0 }, - 'group': {'type': 'string'} + 'group': groupSchema }, 'required': ['type'], 'additionalProperties': True @@ -500,7 +504,10 @@ class AnnotationSchema: }, 'matrix': transformArray }, - } + }, + 'user': userSchema, + 'label': labelSchema, + 'group': groupSchema, }, 'required': ['girderId', 'type'], 'additionalProperties': False,