Skip to content

Commit

Permalink
allow changing grid parameters of ui.scene (zauberzeug#3257)
Browse files Browse the repository at this point in the history
  • Loading branch information
falkoschindler authored Jun 27, 2024
1 parent 2f6649f commit 0b19394
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 6 deletions.
8 changes: 5 additions & 3 deletions nicegui/elements/scene.js
Original file line number Diff line number Diff line change
Expand Up @@ -123,16 +123,18 @@ export default {
this.$nextTick(() => this.resize());
window.addEventListener("resize", this.resize, false);

const gridSize = this.grid[0] || 100;
const gridDivisions = this.grid[1] || 100;
if (this.grid) {
const ground = new THREE.Mesh(
new THREE.PlaneGeometry(100, 100),
new THREE.PlaneGeometry(gridSize, gridSize),
new THREE.MeshPhongMaterial({ color: this.background_color })
);
ground.translateZ(-0.01);
ground.object_id = "ground";
this.scene.add(ground);

const grid = new THREE.GridHelper(100, 100);
const grid = new THREE.GridHelper(gridSize, gridDivisions);
grid.material.transparent = true;
grid.material.opacity = 0.2;
grid.rotateX(Math.PI / 2);
Expand Down Expand Up @@ -470,7 +472,7 @@ export default {
props: {
width: Number,
height: Number,
grid: Boolean,
grid: Object,
camera_type: String,
camera_params: Object,
drag_constraints: String,
Expand Down
6 changes: 3 additions & 3 deletions nicegui/elements/scene.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import asyncio
from dataclasses import dataclass
from typing import Any, Callable, Dict, List, Literal, Optional, Union
from typing import Any, Callable, Dict, List, Literal, Optional, Tuple, Union

from typing_extensions import Self

Expand Down Expand Up @@ -72,7 +72,7 @@ class Scene(Element,
def __init__(self,
width: int = 400,
height: int = 300,
grid: bool = True,
grid: Union[bool, Tuple[int, int]] = True,
camera: Optional[SceneCamera] = None,
on_click: Optional[Callable[..., Any]] = None,
on_drag_start: Optional[Callable[..., Any]] = None,
Expand All @@ -89,7 +89,7 @@ def __init__(self,
:param width: width of the canvas
:param height: height of the canvas
:param grid: whether to display a grid
:param grid: whether to display a grid (boolean or tuple of ``size`` and ``divisions`` for `Three.js' GridHelper <https://threejs.org/docs/#api/en/helpers/GridHelper>`_, default: 100x100)
:param camera: camera definition, either instance of ``ui.scene.perspective_camera`` (default) or ``ui.scene.orthographic_camera``
:param on_click: callback to execute when a 3D object is clicked
:param on_drag_start: callback to execute when a 3D object is dragged
Expand Down
9 changes: 9 additions & 0 deletions website/documentation/content/scene_documentation.py
Original file line number Diff line number Diff line change
Expand Up @@ -145,4 +145,13 @@ def custom_background() -> None:
scene.box()


@doc.demo('Custom Grid', '''
You can set custom grid parameters using the `grid` parameter of `ui.scene`.
It accepts a tuple of two integers, the first one for the grid size and the second one for the number of divisions.
''')
def custom_grid() -> None:
with ui.scene(grid=(3, 2)).classes('w-full h-64') as scene:
scene.sphere()


doc.reference(ui.scene)

0 comments on commit 0b19394

Please sign in to comment.