|
| 1 | +from trame.app import get_server |
| 2 | +from trame.widgets import html, client |
| 3 | +from trame.ui.html import DivLayout |
| 4 | +from trame_image_tools.widgets import ( |
| 5 | + TrameImage, |
| 6 | + TrameImageRoi, |
| 7 | + TrameImageLine, |
| 8 | + TrameImageCircle, |
| 9 | + TrameImagePolygon, |
| 10 | + TrameImageGrid, |
| 11 | +) |
| 12 | + |
| 13 | + |
| 14 | +class ExampleApp: |
| 15 | + def __init__(self, server=None): |
| 16 | + self._server = get_server(server, client_type="vue3") |
| 17 | + self.ui = None |
| 18 | + self._build_ui() |
| 19 | + |
| 20 | + @property |
| 21 | + def server(self): |
| 22 | + return self._server |
| 23 | + |
| 24 | + @property |
| 25 | + def state(self): |
| 26 | + return self.server.state |
| 27 | + |
| 28 | + @property |
| 29 | + def ctrl(self): |
| 30 | + return self.server.controller |
| 31 | + |
| 32 | + def _build_ui(self): |
| 33 | + with DivLayout(self.server) as layout: |
| 34 | + self._ui = layout |
| 35 | + |
| 36 | + layout.root.style = "height: 100%;" |
| 37 | + |
| 38 | + client.Style(""" |
| 39 | + html { height: 100%; overflow: hidden;} |
| 40 | + body { height: 100%; margin: 0;} |
| 41 | + #app { height: 100%; } |
| 42 | + """) |
| 43 | + |
| 44 | + with html.Div(style="width: 100%; height: 100%; background-color: black;"): |
| 45 | + with TrameImage( |
| 46 | + src="https://www.kitware.com/main/wp-content/uploads/2023/10/logo-trame.png", |
| 47 | + size=("[800, 210]",), |
| 48 | + v_model_scale=("scale", 0.9), |
| 49 | + v_model_center=("center", [0.5, 0.5]), |
| 50 | + ): |
| 51 | + TrameImageGrid( |
| 52 | + spacing=("grid_spacing", [50, 25]), |
| 53 | + ) |
| 54 | + |
| 55 | + TrameImageLine( |
| 56 | + v_model=("line", [200, 50, 300, 150]), |
| 57 | + color="lime", |
| 58 | + thickness=3, |
| 59 | + handle_size=12, |
| 60 | + ) |
| 61 | + |
| 62 | + TrameImageRoi( |
| 63 | + v_model=("roi", [350, 50, 100, 100]), |
| 64 | + border_color="yellow", |
| 65 | + border_size=3, |
| 66 | + handle_size=12, |
| 67 | + ) |
| 68 | + |
| 69 | + TrameImageCircle( |
| 70 | + v_model=("circle", [550, 100, 50]), |
| 71 | + border_color="cyan", |
| 72 | + border_size=3, |
| 73 | + handle_size=12, |
| 74 | + ) |
| 75 | + |
| 76 | + TrameImagePolygon( |
| 77 | + v_model=("polygon", [650, 90, 670, 150, 730, 150, 750, 90, 700, 50]), |
| 78 | + border_color="fuchsia", |
| 79 | + border_size=3, |
| 80 | + handle_size=12, |
| 81 | + ) |
| 82 | + |
| 83 | + html.Button( |
| 84 | + "Reset Camera", |
| 85 | + style="position: absolute; left: 1rem; top: 1rem;", |
| 86 | + click="scale = 0.9; center = [0.5, 0.5];", |
| 87 | + ) |
| 88 | + |
| 89 | + |
| 90 | +def main(server=None, **kwargs): |
| 91 | + app = ExampleApp(server) |
| 92 | + app.server.start(**kwargs) |
| 93 | + |
| 94 | + |
| 95 | +if __name__ == "__main__": |
| 96 | + main() |
0 commit comments