from cqmore import Workplane from cqmore.curve import archimedeanSpiral, circle from cqmore.polygon import regularPolygon, star from random import randint, choice import cadquery as cq import functools as fnc import itertools as it from cad_utilities.shapes import makeDice from typing import cast from cadquery import Face from cqmore import Workplane from cqmore.polyhedron import ( tetrahedron, hexahedron, octahedron, dodecahedron, icosahedron, ) radius = 20 font_name = "Arial Black" font_distance = 2 detail = 0 dice = Workplane().polyhedron(*icosahedron(radius, detail)) faces = dice.faces().vals() nums = len(faces) texts = Workplane() for i in range(nums): print(i) if i == 0: text_to_write = "20" font_size = 8.5 else: text_to_write = str(nums - i) font_size = 8.5 texts.add( Workplane(faces[i]) .workplane(origin=cast(Face, faces[i]).Center()) .text( text_to_write, font_size, -font_distance, fontPath="/home/deck/fonts/SEVESBRG.TTF", ) ) dice = dice.cut(texts) cq.exporters.export(dice, "/home/deck/model_files/dice.step")