jw_cad 外部変形 - (1424) vbscriptで指示線を確認する(ln) -

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

 

vbscriptで指示線を確認する(ln)

:vbscriptで指示線を確認する(ln)
@echo off
if not exist %~dp0eval.vbs echo ExecuteGlobal WScript.StdIn.ReadAll > %~dp0eval.vbs
for /f "delims=:" %%n in ('findstr /n "^#!" %0') do (
  copy jwc_temp.txt myfiles > nul
  (
:   echo Option Explicit
    echo On Error Resume Next
:   echo On Error GoTo 0
    more +%%n %0
  ) | cscript //nologo %~dp0eval.vbs > jwc_temp.txt
)
goto:eof

REM #jww
REM #1%dln 線を指示してください
REM #99#
REM #bz
REM #e

#!この次の行からプログラムを書いてください
'1)正規表現
Dim re
Set re = New RegExp
re.IgnoreCase = True '大文字と小文字を区別しない
re.Global = True '文字列全体を検索する

function reSplit(str)
  re.Pattern = "[ ]+"
  reSplit = Split(Trim(re.Replace(str," ")))
end function

function reTest(pat, str)
  re.Pattern = pat
  reTest = re.Test(str)
end function

'4)ユーザ定義関数
function hypot(x, y)
  hypot = sqr(x * x + y * y)
end function

function lnlength(x) '線長
  if typename(x) = "String" then x = Split(Trim(x))
  lnlength = hypot(x(2) - x(0), x(3) - x(1))
end function

Dim line, F
Dim hp(100), hpn
Dim ln(100), lnn, j
With CreateObject("Scripting.FileSystemObject")
  With .OpenTextFile("myfiles")
  Do While Not .AtEndOfStream
    line = .ReadLine: F = reSplit(line)
    if reTest("^hp([1-9][0-9]?)ln",line) then '指示点の座標値
      hpn = CInt(re.Replace(F(0),"$1"))
      hp(hpn) = Array(F(1), F(2))
    end if
    if reTest("^hhp([1-9][0-9]?)ln",line) then '指示線番号
      lnn = CInt(re.Replace(line,"$1"))
    end if
    if reTest("^ ",line) then '指示線
      ln(lnn) = F
      for j = 0 to 3: ln(lnn)(j) = Cdbl(ln(lnn)(j)): next
    end if
  Loop
  End With
End With

WScript.Echo "bz"
Dim i, r, x1, y1, x2, y2
for i = 1 to lnn
  r = lnlength(ln(i)) / 2
  x1 = ln(i)(0)
  y1 = ln(i)(1)
  x2 = ln(i)(2)
  y2 = ln(i)(3)
  WScript.Echo Join(Array("ci", (x1 + x2) / 2, (y1 + y2) / 2, r))
  WScript.Echo Join(Array("ci", Join(hp(i)), 1))
next