外部変形は データのやり取りをテキストファイルで行うので プログラム言語は 自由に選ぶことができます。図形は機能的かつシンプルなため、数多くのユーザーに受け入れられています。
pythonで矩形に内接する楕円を描く(ov)
:pythonで矩形に内接する楕円を描く(ov)
@echo off
if not exist %~dpn0.py (
for /f "delims=:" %%n in ('findstr /n "^#!" %0') do (
more +%%n %0 > %~dpn0.py
)
)
python %~dpn0.py
goto:eof
REM #jww
REM #1-%d 楕円が内接する矩形の始点を指示してください
REM #2%d 対頂点を指示してください
REM #e
#!この次の行からプログラムを書いてください
# coding: shift_jis
import sys,re
from math import *
try :
f = open("jwc_temp.txt", "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()
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
x, y, r = (x1 + x2) / 2, (y1 + y2) / 2, abs(ww) / 2
w = abs(hh / ww)
sys.stdout = open("jwc_temp.txt", "w")
print("ci %s %s %s %s %s %s %s" % (x, y, r, 0, 360, w, hk))