Example #1
0
#python

import k3d
import testing

setup = testing.setup_mesh_modifier_test("PolyCube", "GTSMeshArea")
setup.source.width = 1
setup.source.height = 1
setup.source.depth = 1

testing.require_mesh_area(setup.modifier.area, 6.0)

positions = [(-5, 5, 0), (5, 5, 0), (-5, -5, 0), (5, -5, 0)]

points = mesh.create_points()
point_selection = mesh.create_point_selection()

for position in positions:
	points.append(k3d.point3(position[0], position[1], position[2]))
	point_selection.append(0.0)

polyhedron = k3d.polyhedron.create(mesh)
polyhedron.shell_types().append(k3d.polyhedron.shell_type.POLYGONS)
polyhedron.face_shells().append(0)
polyhedron.face_first_loops().append(0)
polyhedron.face_loop_counts().append(1)
polyhedron.face_materials().append(None)
polyhedron.face_selections().append(0.0)
polyhedron.loop_first_edges().append(0)
polyhedron.clockwise_edges().assign([1, 2, 3, 0])
polyhedron.edge_selections().assign([0, 0, 0, 0])
polyhedron.vertex_points().assign([0, 1, 2, 3])
polyhedron.vertex_selections().assign([0, 0, 0, 0])

Cs = polyhedron.edge_attributes().create("Cs", "k3d::color")
Cs.assign([k3d.color(1, 0, 0), k3d.color(0, 1, 0), k3d.color(0, 0, 1), k3d.color(1, 1, 1)])

modifier = k3d.plugin.create("GTSMeshArea", document)
k3d.property.connect(document, source.get_property("output_mesh"), modifier.get_property("input_mesh"))

testing.require_mesh_area(modifier.area, 50.0)

for position in positions:
    points.append(k3d.point3(position[0], position[1], position[2]))
    point_selection.append(0.0)

polyhedron = k3d.polyhedron.create(mesh)
polyhedron.shell_types().append(k3d.polyhedron.shell_type.POLYGONS)
polyhedron.face_shells().append(0)
polyhedron.face_first_loops().append(0)
polyhedron.face_loop_counts().append(1)
polyhedron.face_materials().append(None)
polyhedron.face_selections().append(0.0)
polyhedron.loop_first_edges().append(0)
polyhedron.clockwise_edges().assign([1, 2, 3, 0])
polyhedron.edge_selections().assign([0, 0, 0, 0])
polyhedron.vertex_points().assign([0, 1, 2, 3])
polyhedron.vertex_selections().assign([0, 0, 0, 0])

Cs = polyhedron.edge_attributes().create("Cs", "k3d::color")
Cs.assign([
    k3d.color(1, 0, 0),
    k3d.color(0, 1, 0),
    k3d.color(0, 0, 1),
    k3d.color(1, 1, 1)
])

modifier = k3d.plugin.create("GTSMeshArea", document)
k3d.property.connect(document, source.get_property("output_mesh"),
                     modifier.get_property("input_mesh"))

testing.require_mesh_area(modifier.area, 50.0)