jw_cad 外部変形 - (1021) tclshで矩形に内接する楕円を描く(ov) -

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

 

tclshで矩形に内接する楕円を描く(ov)

:tclshで矩形に内接する楕円を描く(ov)
@echo off
for /f "delims=:" %%n in ('findstr /n "^#!" %0') do (
  copy jwc_temp.txt myfiles > nul
  more +%%n %0 | tclsh - > jwc_temp.txt
)
goto:eof

REM #jww
REM #1-%d 楕円が内接する矩形の始点を指示してください
REM #2%d 対頂点を指示してください
REM #e

#!この次の行からプログラムを書いてください
set tcl_precision 16; #文字列を数値演算するとき有効桁数 16 (デフォルト 12)

set f [open myfiles]
foreach 0 [split [read $f] \n] {
  lassign $0 1 2 3
  switch -regexp -- $0 {
    ^hk { set hk $2 }
    ^hp1 { set p1 "$2 $3" }
    ^hp2 { set p2 "$2 $3" }
  }
}
close $f

lassign "$p1 $p2" x1 y1 x2 y2
set PI [expr acos(-1)]
set d [expr $hk * $PI / 180]
lassign "[expr cos($d)] [expr sin($d)]" co si
set ww [expr  ($x2 - $x1) * $co + ($y2 - $y1) * $si]
set hh [expr -($x2 - $x1) * $si + ($y2 - $y1) * $co]
set x [expr ($x1 + $x2) / 2]
set y [expr ($y1 + $y2) / 2]
set r [expr abs($ww) / 2]
set w [expr abs($hh / $ww)]
puts [format "ci %.15g %.15g %.15g 0 360 %.15g %.15g" $x $y $r $w $hk]