Skip to content
Merged

Next #39

Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
24 changes: 21 additions & 3 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,22 @@
# CHANGELOG


## v1.1.1-rc.2 (2024-12-20)

### Bug Fixes

- **schemas**: Add missing schemas
([`37e8504`](https://github.com/Geode-solutions/OpenGeodeWeb-Viewer/commit/37e8504236a9f622cefffb99c4fbe684853e4d13))


## v1.1.1-rc.1 (2024-12-20)

### Bug Fixes

- **semantic**: Trigger semantic release
([`5025b3b`](https://github.com/Geode-solutions/OpenGeodeWeb-Viewer/commit/5025b3b8aa9008103939ff51dbbead85bb9ca37e))


## v1.1.0 (2024-12-09)


Expand All @@ -14,6 +30,11 @@

## v1.1.0-rc.1 (2024-12-04)

### Features

- **get_mouse**: New rpc
([`94280f3`](https://github.com/Geode-solutions/OpenGeodeWeb-Viewer/commit/94280f3bc30f03e0c550cd7baf76afd30192c1e3))


## v1.0.0 (2024-11-29)

Expand Down Expand Up @@ -55,9 +76,6 @@
- **generic rpcs**: Refactor all classes/tests
([`297b005`](https://github.com/Geode-solutions/OpenGeodeWeb-Viewer/commit/297b0050e4ab47817659021c3a099e715fba6a87))

- **get_mouse**: New rpc
([`94280f3`](https://github.com/Geode-solutions/OpenGeodeWeb-Viewer/commit/94280f3bc30f03e0c550cd7baf76afd30192c1e3))

- **new rpcs**: Refactor rpcs
([`c2fb4e7`](https://github.com/Geode-solutions/OpenGeodeWeb-Viewer/commit/c2fb4e75b83a862267ed4641e41e9344e6a2d70f))

Expand Down
6 changes: 4 additions & 2 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ build-backend = "setuptools.build_meta"

[project]
name = "OpenGeodeWeb-Viewer"
version = "1.1.0"
version = "1.1.1-rc.2"
dynamic = ["dependencies"]
authors = [
{ name="Geode-solutions", email="[email protected]" },
Expand Down Expand Up @@ -38,10 +38,12 @@ where = ["src"]
[tool.setuptools.package-data]
"opengeodeweb_viewer.rpc.generic.schemas" = ["*.json"]
"opengeodeweb_viewer.rpc.mesh.schemas" = ["*.json"]
"opengeodeweb_viewer.rpc.mesh.points.schemas" = ["*.json"]
"opengeodeweb_viewer.rpc.mesh.edges.schemas" = ["*.json"]
"opengeodeweb_viewer.rpc.mesh.polygons.schemas" = ["*.json"]
"opengeodeweb_viewer.rpc.model.schemas" = ["*.json"]
"opengeodeweb_viewer.rpc.viewer.schemas" = ["*.json"]


[tool.semantic_release]
version_toml = [
"pyproject.toml:project.version",
Expand Down
42 changes: 37 additions & 5 deletions src/opengeodeweb_viewer/object/object_methods.py
Original file line number Diff line number Diff line change
Expand Up @@ -100,24 +100,56 @@ def SetOpacity(self, id, opacity):
self.render()

def SetColor(self, id, red, green, blue):
reader = self.get_object(id)["reader"]
mapper = self.get_object(id)["mapper"]
mapper.ScalarVisibilityOff()
actor = self.get_object(id)["actor"]
actor.GetProperty().SetColor([red, green, blue])
self.render()

def SetEdgeVisibility(self, id, visibility):
def SetEdgesVisibility(self, id, visibility):
actor = self.get_object(id)["actor"]
actor.GetProperty().SetEdgeVisibility(visibility)
self.render()

def SetEdgesSize(self, id, size):
actor = self.get_object(id)["actor"]
actor.GetProperty().SetEdgeWidth(size)
self.render()

def SetVertexVisibility(self, id, visibility):
def SetEdgesColor(self, id, color):
actor = self.get_object(id)["actor"]
actor.GetProperty().SetEdgeColor(color)
self.render()
def SetPointsVisibility(self, id, visibility):
actor = self.get_object(id)["actor"]
actor.GetProperty().SetVertexVisibility(visibility)
actor.GetProperty().SetEdgeVisibility(visibility)
self.render()

def SetPointSize(self, id, size):
def SetPointsSize(self, id, size):
actor = self.get_object(id)["actor"]
actor.GetProperty().SetPointSize(size)
self.render()
self.render()

def SetPointsColor(self, id, color):
actor = self.get_object(id)["actor"]
actor.GetProperty().SetVertexColor(color)
self.render()

def SetPolygonsVisibility(self, id, visibility):
actor = self.get_object(id)["actor"]
actor.SetVisibility(visibility)
self.render()

def SetPolygonsColor(self, id, color):
actor = self.get_object(id)["actor"]
actor.GetProperty().SetColor(color)
self.render()

def clearColors(self, id):
db = self.get_object(id)
mapper = db["mapper"]
reader = db["reader"]
reader.GetOutput().GetPointData().SetActiveScalars("")
reader.GetOutput().GetCellData().SetActiveScalars("")
mapper.ScalarVisibilityOff()
18 changes: 8 additions & 10 deletions src/opengeodeweb_viewer/rpc/generic/generic_protocols.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,23 +9,21 @@

# Local application imports
from opengeodeweb_viewer.vtk_protocol import VtkView
from opengeodeweb_viewer.rpc.mesh.mesh_protocols import VtkMeshView
from opengeodeweb_viewer.rpc.model.model_protocols import VtkModelView
from opengeodeweb_viewer.utils_functions import get_schemas_dict, validate_schema

class VtkGenericView(VtkView):
prefix = "opengeodeweb_viewer.generic."
schemas_dict = get_schemas_dict(os.path.join(os.path.dirname(__file__), "schemas"))
generic_prefix = "opengeodeweb_viewer.generic."
generic_schemas_dict = get_schemas_dict(os.path.join(os.path.dirname(__file__), "schemas"))

def __init__(self, mesh_protocols, model_protocols):
super().__init__()
self.mesh_protocols = mesh_protocols
self.model_protocols = model_protocols

@exportRpc(prefix + schemas_dict["register"]["rpc"])
@exportRpc(generic_prefix + generic_schemas_dict["register"]["rpc"])
def register(self, params):
print(self.schemas_dict["register"]["rpc"], f"{params=}", flush=True)
validate_schema(params, self.schemas_dict["register"])
print(self.generic_prefix + self.generic_schemas_dict["register"]["rpc"], f"{params=}", flush=True)
validate_schema(params, self.generic_schemas_dict["register"])
viewer_object = params["viewer_object"]
params.pop('viewer_object', None)
print(f"{params=}", flush=True)
Expand All @@ -34,10 +32,10 @@ def register(self, params):
elif viewer_object == "model":
self.model_protocols.registerModel(params)

@exportRpc(prefix + schemas_dict["deregister"]["rpc"])
@exportRpc(generic_prefix + generic_schemas_dict["deregister"]["rpc"])
def deregister(self, params):
print(self.schemas_dict["deregister"]["rpc"], f"{params=}", flush=True)
validate_schema(params, self.schemas_dict["deregister"])
print(self.generic_prefix + self.generic_schemas_dict["deregister"]["rpc"], f"{params=}", flush=True)
validate_schema(params, self.generic_schemas_dict["deregister"])
viewer_object = params["viewer_object"]
params.pop('viewer_object', None)
if viewer_object == "mesh":
Expand Down
43 changes: 43 additions & 0 deletions src/opengeodeweb_viewer/rpc/mesh/edges/edges_protocols.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
# Standard library imports
import os

# Third party imports
from wslink import register as exportRpc

# Local application imports
from opengeodeweb_viewer.utils_functions import get_schemas_dict, validate_schema
from opengeodeweb_viewer.rpc.mesh.mesh_protocols import VtkMeshView

class VtkMeshEdgesView(VtkMeshView):
mesh_edges_prefix = "opengeodeweb_viewer.mesh.edges."
mesh_edges_schemas_dict = get_schemas_dict(os.path.join(os.path.dirname(__file__), "schemas"))

def __init__(self):
super().__init__()

@exportRpc(mesh_edges_prefix + mesh_edges_schemas_dict["visibility"]["rpc"])
def setMeshEdgesVisibility(self, params):
print(self.mesh_edges_prefix + self.mesh_edges_schemas_dict["visibility"]["rpc"], f"{params=}", flush=True)
validate_schema(params, self.mesh_edges_schemas_dict["visibility"])
id = params["id"]
visibility = bool(params["visibility"])
self.SetEdgesVisibility(id, visibility)

@exportRpc(mesh_edges_prefix + mesh_edges_schemas_dict["color"]["rpc"])
def setMeshEdgesColor(self, params):
print(self.mesh_edges_prefix + self.mesh_edges_schemas_dict["color"]["rpc"], f"{params=}", flush=True)
validate_schema(params, self.mesh_edges_schemas_dict["color"])
id = params["id"]
red, green, blue = params["color"]["r"], params["color"]["g"], params["color"]["b"]
self.SetEdgesColor(id, [red, green, blue])

@exportRpc(mesh_edges_prefix + mesh_edges_schemas_dict["size"]["rpc"])
def setMeshEdgesSize(self, params):
print(self.mesh_edges_prefix + self.mesh_edges_schemas_dict["size"]["rpc"], f"{params=}", flush=True)
validate_schema(params, self.mesh_edges_schemas_dict["size"])
id = params["id"]
size = bool(params["size"])
self.SetEdgesSize(id, size)



46 changes: 46 additions & 0 deletions src/opengeodeweb_viewer/rpc/mesh/edges/schemas/color.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
{
"rpc": "color",
"type": "object",
"properties": {
"id": {
"type": "string"
},
"color": {
"type": "object",
"properties": {
"r": {
"type": "integer",
"minimum": 0,
"maximum": 255
},
"g": {
"type": "integer",
"minimum": 0,
"maximum": 255
},
"b": {
"type": "integer",
"minimum": 0,
"maximum": 255
},
"a": {
"type": "number",
"minimum": 0,
"maximum": 1,
"default": 1
}
},
"required": [
"r",
"g",
"b"
],
"additionalProperties": false
}
},
"required": [
"id",
"color"
],
"additionalProperties": false
}
17 changes: 17 additions & 0 deletions src/opengeodeweb_viewer/rpc/mesh/edges/schemas/size.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
{
"rpc": "size",
"type": "object",
"properties": {
"id": {
"type": "string"
},
"size": {
"type": "integer"
}
},
"required": [
"id",
"size"
],
"additionalProperties": false
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"rpc": "display_vertex_attribute",
"rpc": "vertex_attribute",
"type": "object",
"properties": {
"id": {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"rpc": "set_visibility",
"rpc": "visibility",
"type": "object",
"properties": {
"id": {
Expand Down
Loading
Loading