jw_cad 外部変形 - (852) pythonでソリッド図形の矩形を描く -

外部変形は データのやり取りをテキストファイルで行うので プログラム言語は 自由に選ぶことができます。図形は機能的かつシンプルなため、数多くのユーザーに受け入れられています。

 

pythonでソリッド図形の矩形を描く

:pythonでソリッド図形の矩形を描く
@echo off
if not exist %~dpn0.py (
  for /f "delims=:" %%n in ('findstr /n "^#!" %0') do (
    more +%%n %0 > %~dpn0.py
  )
)
copy jwc_temp.txt myfiles > nul
python %~dpn0.py > jwc_temp.txt
goto:eof

REM #jww
REM #1-%d 矩形の始点を指示してください
REM #2%d 対頂点を指示してください
REM #e

#!この次の行からプログラムを書いてください
# coding: shift_jis
import sys,re
from math import *

try :
  f = open("myfiles", "r")
  for line in f:
    F = line.split()
    if re.compile("^hk").search(line): hk = float(F[1])
    if re.compile("^hp1").search(line): p1 = F[1:3]
    if re.compile("^hp2").search(line): p2 = F[1:3]
  f.close()
except :
  sys.exit()

r, g, b = (0, 128, 128)
d = hk * pi / 180
co = cos(d)
si = sin(d)
x1, y1, x2, y2 =  map(float, p1 + p2)
ww = (x2 - x1) * co + (y2 - y1) * si
hh =-(x2 - x1) * si + (y2 - y1) * co
p3 = [x1 + ww * co, y1 + ww * si]
p4 = [x1 - hh * si, y1 + hh * co]

print("lc10 %s" % (r + 256 * g + 256 * 256 * b))
print("sl %s %s %s %s %s %s %s %s" % tuple(p1 + p3 + p2 + p4))