File: load_and_transform_acis_entities.py

package info (click to toggle)
ezdxf 1.4.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 104,528 kB
  • sloc: python: 182,341; makefile: 116; lisp: 20; ansic: 4
file content (34 lines) | stat: -rw-r--r-- 1,171 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# Copyright (c) 2024, Manfred Moitzi
# License: MIT License

from pathlib import Path
import ezdxf
from ezdxf import xref, transform

# ------------------------------------------------------------------------------
# 1. This example shows how to load ACIS based entities by the xref module from
#    one DXF document into another DXF document.
#
# 2. How to transform ACIS based entities.
#    The current implementation of the transformation is a trick.
#    The ACIS data format is not documented, therefore ezdxf puts ACIS based entities
#    into an anonymous block and transforms that block.  This transformation is applied
#    when exporting the DXF document.
# ------------------------------------------------------------------------------

CWD = Path(__file__).parent
OUTPUT = Path("~/Desktop/Outbox").expanduser()
if not OUTPUT.exists():
    OUTPUT = CWD


def main():
    sdoc = ezdxf.readfile(CWD / "sphere.dxf")
    tdoc = ezdxf.new(dxfversion=sdoc.dxfversion)
    xref.load_modelspace(sdoc, tdoc)
    transform.translate(tdoc.modelspace(), (10, 11, 12))
    tdoc.saveas(OUTPUT / "imported_and_translated_sphere.dxf")


if __name__ == "__main__":
    main()