清华山维EPS二次开发VBS基础篇



程序控制

For-next

SSProcess.PushUndoMark 

      SSProcess.ClearSelectConditionGroups 

      SSProcess.ClearSelectCondition 

      SSProcess.ClearSelection 

      SSProcess.SetSelectCondition "SSObj_Type", "==", "point"

      SSProcess.SelectFilter 

      cnt=      SSProcess.GetSelGeoCount 

        for i=0 to cnt-1[step 2]

            id=      SSProcess.GetSelGeoValue (i,"SSObj_ID" )

            MSGBOX id

        next

While-wend

      SSProcess.PushUndoMark 

 

      SSProcess.ClearSelectConditionGroups 

      SSProcess.ClearSelectCondition 

      SSProcess.ClearSelection 

      SSProcess.SetSelectCondition "SSObj_Type", "==", "point"

      SSProcess.SelectFilter 

      cnt=      SSProcess.GetSelGeoCount 

        while cnt<>0

            id=      SSProcess.GetSelGeoValue (cnt-1, "SSObj_ID" )

            MSGBOX id

            cnt=cnt-1

        wend

while-wend 语句在循环中不允许结束,不如我们只想显示前5个点的ID

do-while-loop

      SSProcess.PushUndoMark 

 

      SSProcess.ClearSelectConditionGroups 

      SSProcess.ClearSelectCondition 

      SSProcess.ClearSelection 

      SSProcess.SetSelectCondition "SSObj_Type", "==", "point"

      SSProcess.SelectFilter 

      cnt=      SSProcess.GetSelGeoCount 

      c=0

        do while( c<5)

            id=      SSProcess.GetSelGeoValue (c,"SSObj_ID" )

            MSGBOX id

            c=c+1

        loop

if

select case

Dim value '定义一个变量

value = 10 '变量赋值为10

Select Case value '判断变量的值大小,如果相等则输出变量值

   Case 0 MsgBox 0

   Case 1 MsgBox 1

   Case 2 MsgBox 2

   Case Else MsgBox "数值超出范围!" '如过都不相等,则输出”数值超出范围!”

End Select

Exit(for,sub,function,do)

数组操作

数组

定义数组,使用常数定义数组的长度,不能直接使用数值变量定义,如果要使用数值变量,则首先定义一个不带参数的数组,再redim

Dim arr(5)

Dim arrX()

Cnt=9

Redim arrX(Cnt)

      SSProcess.ClearSelectConditionGroups 

      SSProcess.ClearSelectCondition 

      SSProcess.ClearSelection 

      SSProcess.SetSelectCondition "SSObj_Type", "==", "POINT"

      SSProcess.SelectFilter 

      cnt=      SSProcess.GetSelGeoCount 

        MSGBOX cnt

    dim arrX()

    dim arrY()

    dim arrZ()

redim arrX(cnt)

redim arrY(cnt)

redim arrZ(cnt)

    for i=0 to cnt-1

        arrX(i)=      SSProcess.GetSelGeoValue (i,"SSObj_X")

        arrY(i)=      SSProcess.GetSelGeoValue (i,"SSObj_Y")

        arrZ(i)=      SSProcess.GetSelGeoValue (i,"SSObj_Z")

    next

dictionary

类似于C#里的hashtablekey value

   Sub OnClick()

'添加代码将左侧2个房屋的名称设置为4#,编号分别设置为12,右侧两栋楼名称设置为5#,编号分别设置为12,以名称和编号的组合为key保存每栋楼的建筑面积,并根据key提取4#1层的面积

      SSProcess.PushUndoMark 

 

      SSProcess.ClearSelectConditionGroups 

      SSProcess.ClearSelectCondition 

      SSProcess.ClearSelection 

      SSProcess.SetSelectCondition "SSObj_Code", "==", "3103013"

      SSProcess.SelectFilter 

      cnt=      SSProcess.GetSelGeoCount 

        dim dic

        set dic=CreateObject("Scripting.Dictionary")

        for i=0 to cnt-1

            lh=      SSProcess.GetSelGeoValue (i,"[JZMC]")

            bh=      SSProcess.GetSelGeoValue (i,"[JZBH]")

            key=lh+bh

            mj=      SSProcess.GetSelGeoValue (i,"SSObj_Area")

 

            dic.add key ,mj

        next

if dic.Exists("4#1") then'判断某个key是否存在

c=dic.Item("4#1")'提取key对应的value

msgbox c

end if

msgbox dic.count'输出字典数据总数

End Sub

List(是否存在)

字符串操作

Split-拆分字符串

标准符号分割

str="1,2,3,4,5"

arrStr=split(str,",")

msgbox arrStr(4)

>5

空格分割

通常情况下,要分割的字符串之中,字符之间的空格往往不是一个且个数并不相同,比如

Str=”1 2 3    4      5”分割的话,直接用

arrStr=split(str," ")

msgbox arrStr(4)

是实现不了的,通常是先将字符之间的空格替换为1个空格,然后再分割。类似于这种替换多个空格为1个空格的通用函数,可以将其写在一个vbs文件里,方便多个程序调用,这里顺便记录一下跨文件函数引用的方法,不同于c中的includevbs稍微复杂点,直接贴代码:

commonFunction.vbs文件里

Function myReplace(ByVal s )

    '将字符串中的多个连续空白符成一个

    '调用:str=myReplace(ostr)

    myReplace = ""

    With CreateObject("VBSCRIPT.REGEXP")

        .Global = True

        .IgnoreCase = True

        .Pattern = "\s+"          '查找空白字符,空格、制表符什么的

        myReplace = .Replace(s," ")

    End With

End Function

 

 

test.vbs里引用

********************************************************************

Sub Include (strFile)

    Dim fsObj : Set fsObj = CreateObject("Scripting.FileSystemObject")

    Dim vbsFile : Set vbsFile = fsObj.OpenTextFile(strFile,1, TRUE)

    Dim myFunctionsStr : myFunctionsStr = vbsFile.ReadAll

    vbsFile.Close

    Set vbsFile = Nothing

    Set fsObj = Nothing

    ExecuteGlobal myFunctionsStr

End Sub

*********************************************************************

Sub OnClick()

    scriptLocation ="C:\Users\Administrator\Desktop\砀山\Eps2008\DeskTop\外业生产台面\Script\杨军建\commonFunction.vbs"

    Include(scriptLocation)’引用文件位置

str="1 2 3    4            5"

msgbox str

str1=myReplace(str)

msgbox str1

arrStr=split(str1," ")

msgbox arrStr(4)

End Sub

 

Mid-提取字符串中字符

str="YangJunJian"

msgbox str

str1=mid(str,3,4)

msgbox str1

>ngJu

 

str="YangJunJian"

msgbox str

str1=mid(str,1,4)

msgbox str1

>Yang

Replace-字符串替换

dim txt

txt="This is a beautiful day!"

document.write(Replace(txt,"beautiful","horrible"))

 

输出:

This is a horrible day!

复杂情况参考正则表达式

此外还有LTrim/RTime/Trim/Len/inStr/Join

'统计字符串中是否有文字,是否全是数字 Function hasnoChinese(str) bl = True For i = 1 to Len(str) - 0 'ss=CStr(Asc(Mid(str,i,1))) 'msgbox ss If Asc(Mid(str,i,1)) < 0 Then bl = False End If Next hasnoChinese = bl End Function Function UnAdjustNote(FontClass,dx,dy,widscale,heightscale,nochinese) SSProcess.ClearSelection SSProcess.ClearSelectCondition SSProcess.SetSelectCondition "SSObj_Type", "=", "NOTE" SSProcess.SetSelectCondition "SSObj_FontClass", "=", FontClass SSProcess.SetSelectCondition "[DGNAttr_FontID]", "<>", "188" SSProcess.SelectFilter SSProcess.PushUndoMark notecount = SSProcess.GetSelNoteCount 'msgbox notecount For i=0 To notecount-1 txtx=SSProcess.GetSelNoteValue( i, "SSObj_FontString") If hasnoChinese(txtx) = nochinese Then pointcount = SSProcess.GetSelNotePointCount(i) For j=0 To pointcount-1 Dim x, y, z, pointtype, name SSProcess.GetSelNotePoint i, j, x, y, z, pointtype, name x = x - dx y = y - dy SSProcess.SetSelNotePoint i, j, x, y, z, pointtype, name Next wid=SSProcess.GetSelNoteValue( i, "SSObj_FontWidth") hit=SSProcess.GetSelNoteValue( i, "SSObj_FontHeight") wid1=CStr(CDbl(wid) / widscale) hit1=CStr(CDbl(hit) / heightscale) SSProcess.SetSelNoteValue i, "SSObj_FontWidth", wid1 SSProcess.SetSelNoteValue i, "SSObj_FontHeight", hit1 SSProcess.AddSelNoteToSaveNoteList i End If Next End Function Function changeNoteDw() UnAdjustNote "#",0,0,1.16,1,True UnAdjustNote "#",0,0,1.16,1,False UnAdjustNote "FZ",0,0,1.25,1,True UnAdjustNote "FZ",0,0,1.25,1,False UnAdjustNote "@",0,0,1.275,1,True UnAdjustNote "@",0,0,1.275,1,False UnAdjustNote "899000",0,0,1.27,1,True UnAdjustNote "899000",0,0,1.27,1,False UnAdjustNote "DXLC",0,0,1.333,1,True UnAdjustNote "DXLC",0,0,1.333,1,False UnAdjustNote "499000",-0.117,0,1,1.3,True UnAdjustNote "499000",-0.117,0,1,1.3,False End Function Function UnAdjustNote1(EpsFontClass,dx,dy,widscale,heightscale,nochinese) SSProcess.ClearSelection SSProcess.ClearSelectCondition SSProcess.SetSelectCondition "SSObj_Type", "=", "NOTE" SSProcess.SetSelectCondition "SSObj_FontClass", "=", EpsFontClass SSProcess.SelectFilter SSProcess.PushUndoMark notecount = SSProcess.GetSelNoteCount 'msgbox notecount For i=0 To notecount-1 txtx=SSProcess.GetSelNoteValue( i, "SSObj_FontString") If hasnoChinese(txtx) = nochinese Then pointcount = SSProcess.GetSelNotePointCount(i) For j=0 To pointcount-1 Dim x, y, z, pointtype, name SSProcess.GetSelNotePoint i, j, x, y, z, pointtype, name x = x - dx y = y - dy SSProcess.SetSelNotePoint i, j, x, y, z, pointtype, name Next wid=SSProcess.GetSelNoteValue( i, "SSObj_FontWidth") hit=SSProcess.GetSelNoteValue( i, "SSObj_FontHeight") wid1=CStr(CDbl(wid) / widscale) hit1=CStr(CDbl(hit) / heightscale) SSProcess.SetSelNoteValue i, "SSObj_FontWidth", wid1 SSProcess.SetSelNoteValue i, "SSObj_FontHeight", hit1 SSProcess.AddSelNoteToSaveNoteList i End If Next End Function Function changeNoteDw1() '属于86号字体(居民地注记) UnAdjustNote1 "297000",2.5,0,1.33,1.25,True UnAdjustNote1 "297000",2.5,0,1.33,1.25,False UnAdjustNote1 "297100",1.25,-0.3,1.33,1.25,True UnAdjustNote1 "297100",1.25,-0.3,1.33,1.25,False UnAdjustNote1 "297200",2.25,-0.3,1.33,1.25,True UnAdjustNote1 "297200",2.25,-0.3,1.33,1.25,False UnAdjustNote1 "297500",1.8,0,1.33,1.33,True UnAdjustNote1 "297500",1.8,0,1.33,1.33,False '属于86号字体(地貌注记) UnAdjustNote1 "881000",0.7,-0.15,1.3,1.25,True UnAdjustNote1 "881000",0.7,-0.15,1.3,1.25,False UnAdjustNote1 "882000",0.7,-0.15,1.3,1.33,True UnAdjustNote1 "882000",0.7,-0.15,1.3,1.33,False '属于242号字体(居民地注记) UnAdjustNote1 "297300",1.6,0,1.3,1.3,True UnAdjustNote1 "297300",1.6,0,1.3,1.3,False UnAdjustNote1 "297400",2,0,1.3,1.3,True UnAdjustNote1 "297400",2,0,1.3,1.3,False '属于86号字体(水系注记) 'UnAdjustNote "698100",0.3,0.25,1.25,1.4,True 'UnAdjustNote "698100",0.3,0.25,1.25,1.4,False UnAdjustNote1 "698100",-0.2,0,1.27,1.25,True UnAdjustNote1 "698100",-0.2,0,1.27,1.25,False UnAdjustNote1 "698200",-0.1,0.1,1.27,1.26,True UnAdjustNote1 "698200",-0.1,0.1,1.27,1.26,False UnAdjustNote1 "698300",-0.1,0.1,1.27,1.26,True UnAdjustNote "698300",-0.1,0.1,1.27,1.26,False '属于43号字体(居民地注记) UnAdjustNote1 "298000",0,-0.1,1.2,1.3,True UnAdjustNote1 "298000",0,-0.1,1.2,1.3,False UnAdjustNote1 "298200",0,-0.1,1.23,1.3,True UnAdjustNote1 "298200",0,-0.1,1.23,1.3,False '属于43号字体(交通注记注记) UnAdjustNote1 "498000",0.3,0,1.35,1.5,True UnAdjustNote1 "498000",0.3,0,1.35,1.5,False UnAdjustNote1 "498100",0.5,0,1.35,1.5,True UnAdjustNote1 "498100",0.5,0,1.35,1.5,False '属于88号字体(交通注记) UnAdjustNote1 "498200",1.3,-0.15,1.33,1.35,True UnAdjustNote1 "498200",1.3,-0.15,1.33,1.35,False UnAdjustNote1 "498300",1.3,-0.15,1.33,1.35,True UnAdjustNote1 "498300",1.3,-0.15,1.33,1.35,False UnAdjustNote1 "498400",1,-0.15,1.33,1.35,True UnAdjustNote1 "498400",1,-0.15,1.33,1.35,False End Function Function AddNewPointFormLine(Code,NewCode,distx,disty) SSProcess.ClearSelection SSProcess.ClearSelectCondition SSProcess.SetSelectCondition "SSObj_Type", "=", "LINE" SSProcess.SetSelectCondition "SSObj_Code", "=", Code SSProcess.SelectFilter geocount = SSProcess.GetSelGeoCount For i = 0 To geocount - 1 sso= SSProcess.GetSelGeoPointCount(i) If sso = 5 or sso = 4 Then '取出处理对象 ppid = SSProcess.GetSelGeoValue( i, "SSObj_ID") ppcode = SSProcess.GetSelGeoValue( i, "SSObj_Code") '取出对象点坐标 x0 = CDbl(SSProcess.GetObjectAttr( ppid, "SSObj_X(0)")) y0 = CDbl(SSProcess.GetObjectAttr( ppid, "SSObj_Y(0)")) x1 = CDbl(SSProcess.GetObjectAttr( ppid, "SSObj_X(1)")) Y1 = CDbl(SSProcess.GetObjectAttr( ppid, "SSObj_Y(1)")) x3 = CDbl(SSProcess.GetObjectAttr( ppid, "SSObj_X(3)")) y3 = CDbl(SSProcess.GetObjectAttr( ppid, "SSObj_Y(3)")) '算出准备插入点符号的位置x,y If ppcode <> 515100 Then x = (x0 + x3)/2 y = (y0 + y3)/2 '距离 dist1 = sqr((x0-x3)*(x0-x3)+(y0-y3)*(y0-y3)) dist2 = sqr((x0-x1)*(x0-x1)+(y0-y1)*(y0-y1)) scalex = dist1/distx scaley = dist2/disty '角度 Dx = x1-x0 Dy = y1-y0 If Dx = 0 and Dy > 0 Then arc = 0 ElseIf Dx = 0 and Dy < 0 Then arc = 3.1415926 ElseIf Dx < 0 and Dy < 0 Then arc = 3.1415926-atn(Dx/Dy) ElseIf Dx < 0 and Dy = 0 Then arc = 3.1415926/2 ElseIf Dx > 0 and Dy = 0 Then arc = -3.1415926/2 ElseIf Dx > 0 and Dy < 0 Then arc = 3*3.1415926-atn(Dx/Dy) Else arc = 2*3.1415926-atn(Dx/Dy) End If Else x = (x1 + x3)/2 y = (y1 + y3)/2 '距离 dist1 = sqr((x0-x3)*(x0-x3)+(y0-y3)*(y0-y3)) dist2 = sqr((x0-x1)*(x0-x1)+(y0-y1)*(y0-y1)) scalex = dist1/distx scaley = dist2/disty '角度 Dx = x1-x0 Dy = y1-y0 If Dx = 0 and Dy > 0 Then arc = 0 ElseIf Dx = 0 and Dy < 0 Then arc = 3.1415926 ElseIf Dx < 0 and Dy < 0 Then arc = 3.1415926-atn(Dx/Dy) ElseIf Dx < 0 and Dy = 0 Then arc = 3.1415926/2 ElseIf Dx > 0 and Dy = 0 Then arc = -3.1415926/2 ElseIf Dx > 0 and Dy < 0 Then arc = 3*3.1415926-atn(Dx/Dy) Else arc = 2*3.1415926-atn(Dx/Dy) End If End If '按照x,y,scale插入点符号 SSProcess.CreateNewObj 0 SSProcess.SetNewObjValue "SSObj_Code", NewCode SSProcess.SetNewObjValue "SSObj_LineType", "0" SSProcess.SetNewObjValue "SSObj_LayerName", "DEFAULT" SSProcess.SetNewObjValue "SSObj_Color", "RGB(255,255,0)" SSProcess.SetNewObjValue "SSObj_Angle", arc SSProcess.SetNewObjValue "SSObj_ScaleX", scalex SSProcess.SetNewObjValue "SSObj_ScaleY", scaley SSProcess.AddNewObjPoint x, y, 0, 0, "" SSProcess.AddNewObjToSaveObjList End If Next End Function Function lineTopoint() AddNewPointFormLine "221100","2211001","1","0.75" AddNewPointFormLine "861100","8611001","1","0.5" AddNewPointFormLine "515100","5151001","0.5","0.5" End Function Function arcTodgn() SSProcess.ClearSelection SSProcess.ClearSelectCondition SSProcess.SetSelectCondition "SSObj_Type", "==", "LINE" SSProcess.SetSelectCondition "SSObj_LineType", "==", "4" SSProcess.SetSelectCondition "<Clockwise>", "==", "1" SSProcess.SelectFilter geoCount = SSProcess.GetSelGeoCount For i=0 To geoCount-1 geoID = CLng(SSProcess.GetSelGeoValue (i, "SSObj_ID")) SSProcess.ObjectDeal geoID, "GotoPoints", "", result Next End Function Function ExportDgn( fileName ) SSProcess.SetMapStatus 1,2 '输出DGN前的锁库处理 changeNoteDw changeNoteDw1 lineTopoint arcTodgn '工作台面目录下的DGN种子文件 dgnSeedFile = SSProcess.GetSysPathName (8) & "seed5h.dgn" '工作台面目录下的线型对照文件 dgnlinestylefile = SSProcess.GetSysPathName (8) & "dgnlinestyle.lin" '空转换参数 SSProcess.ClearDataXParameter '设置输出文件格式为DGN SSProcess.SetDataXParameter "DataType", "9" 'DGN种子文件 SSProcess.SetDataXParameter "EXCHANGE_DGN_SeedFile", dgnSeedFile 'DGN线型对照文件 SSProcess.SetDataXParameter "EXCHANGE_DGN_LineStyleFile", dgnlinestylefile '设置输出文件名 SSProcess.SetDataXParameter "ExportPathName", fileName '设置使用编码表 SSProcess.SetDataXParameter "FeatureCodeTBName", "FeatureCodeTB_OutDgn" SSProcess.SetDataXParameter "SymbolScriptTBName", "SymbolScriptTB_OutDgn" SSProcess.SetDataXParameter "NoteTemplateTBName", "NoteTemplateTB_OutDgn" SSProcess.SetDataXParameter "ExplodeObjLayerStatus","0" SSProcess.SetDataXParameter "DataBoundMode", "2" SSProcess.SetDataXParameter "LayerRelationCount", "1" SSProcess.SetDataXParameter "LayerRelation1", "图廓层:60:60:60:60:60" '打散对象编组输出 SSProcess.SetDataXParameter "ExplodeObjMakeGroup", "1" '颜色使用编码表指定 SSProcess.SetDataXParameter "ColorUseStatus", "0" '图层使用编码表指定 SSProcess.SetDataXParameter "LayerUseStatus", "0" '面地物输出方式 0 Shape 1 LineString SSProcess.SetDataXParameter "EXCHANGE_DGN_ExportAreaMode", "1" '线串最多点数 SSProcess.SetDataXParameter "EXCHANGE_DGN_MaxLineStringPointCount", "101" '开始输出数据 SSProcess.ExportData SSProcess.SetMapStatus 0,2 SSProcess.MapMethod "Unloaddata","" SSProcess.MapMethod "loaddata", "" End Function Sub OnClick() pathName = SSProcess.SelectPathName( ) If pathName = "" Then Exit Sub End If SSProcess.CreateMapFrame frameCount = SSProcess.GetMapFrameCount() For i=0 To frameCount-1 SSProcess.GetMapFrameCenterPoint i, x, y SSProcess.SetCurMapFrame x, y, 0, "" frameID = SSProcess.GetCurMapFrame() mapNumber = SSProcess.GetObjectAttr( CLng(frameID), "[MapNumber]") If mapNumber <> "" Then fileName = pathName & mapNumber & ".DGN" ExportDgn fileName End If Next SSProcess.FreeMapFrame End Sub
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值