|
5 | 5 | from PIL import Image |
6 | 6 | import numpy as np |
7 | 7 | import logging |
8 | | -from .render import format_preamble, renderaccess |
| 8 | +from .render import format_preamble, format_baseurl, renderaccess |
9 | 9 | from .errors import RenderError |
10 | | -from .utils import NullHandler, jbool |
| 10 | +from .utils import NullHandler, jbool, get_json, put_json |
11 | 11 |
|
12 | 12 | logger = logging.getLogger(__name__) |
13 | 13 | logger.addHandler(NullHandler()) |
|
25 | 25 | None: 'png-image'} # Default to png |
26 | 26 |
|
27 | 27 |
|
| 28 | +def _strip_None_value_dictitems(d, exclude_keys=[]): |
| 29 | + return {k: v for k, v in d.items() |
| 30 | + if v is not None and k not in exclude_keys} |
| 31 | + |
| 32 | + |
| 33 | +@renderaccess |
| 34 | +def get_bb_renderparams(stack, z, x, y, width, height, scale=1.0, |
| 35 | + channel=None, minIntensity=None, maxIntensity=None, |
| 36 | + binaryMask=None, filter=None, filterListName=None, |
| 37 | + convertToGray=None, excludeMask=None, |
| 38 | + host=None, port=None, owner=None, |
| 39 | + project=None, session=requests.session(), |
| 40 | + render=None, **kwargs): |
| 41 | + |
| 42 | + request_url = format_preamble( |
| 43 | + host, port, owner, project, stack) + \ |
| 44 | + "/z/%d/box/%d,%d,%d,%d,%f/render-parameters" % ( |
| 45 | + z, x, y, width, height, scale) |
| 46 | + |
| 47 | + qparams = _strip_None_value_dictitems({ |
| 48 | + "minIntensity": minIntensity, |
| 49 | + "maxIntensity": maxIntensity, |
| 50 | + "binaryMask": binaryMask, |
| 51 | + "filter": filter, |
| 52 | + "filterListName": filterListName, |
| 53 | + "convertToGray": convertToGray, |
| 54 | + "excludeMask": excludeMask, |
| 55 | + "channels": channel}) |
| 56 | + |
| 57 | + return get_json(session, request_url, params=qparams) |
| 58 | + |
| 59 | + |
28 | 60 | @renderaccess |
29 | 61 | def get_bb_image(stack, z, x, y, width, height, scale=1.0, |
30 | 62 | channel=None, |
@@ -109,6 +141,41 @@ def get_bb_image(stack, z, x, y, width, height, scale=1.0, |
109 | 141 | return RenderError(r.text) |
110 | 142 |
|
111 | 143 |
|
| 144 | +@renderaccess |
| 145 | +def get_tile_renderparams( |
| 146 | + stack, tileId, channel=None, normalizeForMatching=None, |
| 147 | + excludeAllTransforms=None, excludeTransformsAfterLast=None, |
| 148 | + excludeFirstTransformAndAllAfter=None, scale=None, |
| 149 | + width=None, height=None, minIntensity=None, maxIntensity=None, |
| 150 | + filter=None, filterListName=None, excludeMask=None, convertToGray=None, |
| 151 | + binaryMask=None, host=None, port=None, owner=None, |
| 152 | + project=None, img_format=None, |
| 153 | + session=requests.session(), render=None, **kwargs): |
| 154 | + request_url = format_preamble( |
| 155 | + host, port, owner, project, stack) + \ |
| 156 | + "/tile/%s/render-parameters" % ( |
| 157 | + tileId) |
| 158 | + |
| 159 | + qparams = _strip_None_value_dictitems({ |
| 160 | + "normalizeForMatching": normalizeForMatching, |
| 161 | + "excludeAllTransforms": excludeAllTransforms, |
| 162 | + "excludeTransformsAfterLast": excludeTransformsAfterLast, |
| 163 | + "excludeFirstTransformAndAllAfter": excludeFirstTransformAndAllAfter, |
| 164 | + "scale": scale, |
| 165 | + "width": width, |
| 166 | + "height": height, |
| 167 | + "minIntensity": minIntensity, |
| 168 | + "maxIntensity": maxIntensity, |
| 169 | + "binaryMask": binaryMask, |
| 170 | + "filter": filter, |
| 171 | + "filterListName": filterListName, |
| 172 | + "convertToGray": convertToGray, |
| 173 | + "excludeMask": excludeMask, |
| 174 | + "channels": channel}) |
| 175 | + |
| 176 | + return get_json(session, request_url, params=qparams) |
| 177 | + |
| 178 | + |
112 | 179 | @renderaccess |
113 | 180 | def get_tile_image_data(stack, tileId, channel=None, normalizeForMatching=True, |
114 | 181 | excludeAllTransforms=False, scale=None, |
@@ -191,6 +258,32 @@ def get_tile_image_data(stack, tileId, channel=None, normalizeForMatching=True, |
191 | 258 | return RenderError(r.text) |
192 | 259 |
|
193 | 260 |
|
| 261 | +@renderaccess |
| 262 | +def get_section_renderparams(stack, z, binaryMask=None, channel=None, |
| 263 | + convertToGray=None, excludeMask=None, filter=None, |
| 264 | + filterListName=None, minIntensity=None, |
| 265 | + maxIntensity=None, scale=None, |
| 266 | + host=None, port=None, owner=None, project=None, |
| 267 | + session=requests.session(), |
| 268 | + render=None, **kwargs): |
| 269 | + request_url = format_preamble( |
| 270 | + host, port, owner, project, stack) + "/z/{}/render-parameters".format( |
| 271 | + z) |
| 272 | + |
| 273 | + qparams = _strip_None_value_dictitems({ |
| 274 | + "scale": scale, |
| 275 | + "minIntensity": minIntensity, |
| 276 | + "maxIntensity": maxIntensity, |
| 277 | + "binaryMask": binaryMask, |
| 278 | + "filter": filter, |
| 279 | + "filterListName": filterListName, |
| 280 | + "convertToGray": convertToGray, |
| 281 | + "excludeMask": excludeMask, |
| 282 | + "channels": channel}) |
| 283 | + |
| 284 | + return get_json(session, request_url, params=qparams) |
| 285 | + |
| 286 | + |
194 | 287 | @renderaccess |
195 | 288 | def get_section_image(stack, z, scale=1.0, channel=None, |
196 | 289 | filter=False, |
@@ -255,3 +348,20 @@ def get_section_image(stack, z, scale=1.0, channel=None, |
255 | 348 |
|
256 | 349 | r = session.get(request_url, params=qparams) |
257 | 350 | return np.asarray(Image.open(io.BytesIO(r.content))) |
| 351 | + |
| 352 | + |
| 353 | +@renderaccess |
| 354 | +def get_renderparameters_image(renderparams, img_format=None, |
| 355 | + host=None, port=None, owner=None, |
| 356 | + session=requests.session(), |
| 357 | + render=None, **kwargs): |
| 358 | + try: |
| 359 | + image_ext = IMAGE_FORMATS[img_format] |
| 360 | + except KeyError as e: # pragma: no cover |
| 361 | + raise ValueError('{} is not a valid render image format!'.format(e)) |
| 362 | + |
| 363 | + request_url = format_baseurl(host, port) + '/owner/{owner}/{ext}'.format( |
| 364 | + owner=owner, ext=image_ext) |
| 365 | + |
| 366 | + r = put_json(session, request_url, renderparams) |
| 367 | + return np.array(Image.open(io.BytesIO(r.content))) |
0 commit comments