jw_cad 外部変形 - (1046) tclshで線に直交線を引く -

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

 

tclshで線に直交線を引く

:tclshで線に直交線を引く
@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 #1ln 線を指示してください
REM #bz
REM #e

#!この次の行からプログラムを書いてください
proc lnlength {ln} { #線長を返す
  lassign $ln x1 y1 x2 y2
  return [expr hypot($x2 - $x1, $y2 - $y1)]
}

proc lnslope {ln} { #線の角度を返す
  lassign $ln x1 y1 x2 y2
  return [expr atan2($y2 - $y1, $x2 - $x1)]
}

set tcl_precision 16; #文字列を数値演算するとき有効桁数 16 (デフォルト 12)

set f [open myfiles]
foreach 0 [split [read $f] \n] {
  lassign $0 1 2 3 4
  switch -regexp -- $0 {
    ^hq { puts "bz"; continue }
    ^hp1ln { set p0 "$2 $3"; continue }
    {^[ ]} { 
      set NF [llength $0]
      if {$NF == 4} {
        set p1 "$1 $2"
        set p2 "$3 $4"
        set pc "[expr ($1 + $3) / 2] [expr ($2 + $4) / 2]"
        set l1 [lnlength "$p0 $p1"]
        set l2 [lnlength "$p0 $p2"]
        set l3 [lnlength "$p0 $pc"]
        if {$l2 > $l1 && $l3 > $l1} {set pc $p1}
        if {$l1 > $l2 && $l3 > $l2} {set pc $p2}
        set l [expr [lnlength $0] / 2]
        set d [lnslope $0]
        set co [expr cos($d) * $l]
        set si [expr sin($d) * $l]
        lassign $pc xc yc
        puts "[expr $xc + $si] [expr $yc - $co]\
              [expr $xc - $si] [expr $yc + $co]"
      }
    }
  }
}
close $f