明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 4672|回复: 5

[F#] [飞马系列] 个人的第一个F# JIG代码——截断线绘制

[复制链接]
发表于 2010-8-10 23:51:00 | 显示全部楼层 |阅读模式
本帖最后由 qjchen 于 2013-10-20 19:29 编辑

个人的第一个F# JIG代码——截断线绘制

由于.NET编程一直似懂非懂,不过最近看了一些F#的介绍之后,对其颇有好感
于是啃了两天帮助
仔细阅读了才鸟兄的C# 五角星jig例子、KEAN的F# 螺旋线jig例子和AUTODESK公司的椭圆C# JIG例子
照葫芦画瓢地写下了如下一段简单的截断线例子
在此对以上作者表示衷心的感谢
而本人水平有限,代码非常不简洁,没有体现出F#的任何优点,各位见笑了,请不吝指教
后续希望能有所改进

源代码和项目如附件,内有说明
使用说明
(1) 可在AutoCAD2007 或2011 中,用netload命令,加载这个myfirstjig.dll
     则可以通过命令 mybl来调用画截断线,效果可见gif文件


(2)源码使用说明:请用VS2008+F# 2.0安装包或者 VS2010打开
     注意:要修改引用中ACMGD.DLL和ACDBMGD.DLL的路径(重新删除再引用,并设置拷贝到本地为false)
               要修改项目属性中debug里面的acad.exe的路径(重新查找)
by qjchen

  1. //本文参照了才鸟兄的五角星例子、KEAN的螺旋线例子和AUTODESK公司的椭圆JIG例子
  2. //在此对他们表示衷心的感谢
  3. //by qjchen@gmail.com 华南理工大学 2010.08.10
  4. module File1_mod.Commands
  5. //引入一些空间,类似C#的using
  6. open System
  7. open Autodesk.AutoCAD.ApplicationServices
  8. open Autodesk.AutoCAD.DatabaseServices
  9. open Autodesk.AutoCAD.EditorInput
  10. open Autodesk.AutoCAD.Geometry
  11. open Autodesk.AutoCAD.GraphicsInterface
  12. open Autodesk.AutoCAD.Runtime
  13. //根据才鸟兄实体书中的例子编写函数,仿LISP的polar
  14. let PolarPoint (basePt:Point2d) (angle:double) (distance:double):Point2d=
  15.     let point = Point2d(basePt.X+distance*Math.Cos angle,basePt.Y+distance*Math.Sin angle)
  16.     point
  17. //Ang2Rad,仿才鸟兄的函数,不过才鸟兄写成了rad2ang,或许是笔误?
  18. let Ang2Rad (angle:double) =
  19.     let rad=angle*Math.PI/180.0
  20.     rad
  21. //定义一个继承于DrawJig的JdxJig类
  22. type JdxJig() as this = class
  23.   inherit DrawJig()
  24.   //此处定义的两个变量,一个来自于jdx的初始赋值,一个来自于起始点
  25.   let mutable (_pl : Polyline) = null
  26.   let mutable _startPt=new Point3d()
  27.   //member是这个类中的一个函数,仿Kean函数编写
  28.   member x.StartJig(ed:Editor,pt,pl) =
  29.     //将之前获取的点及构造的函数赋予此两变量
  30.     _startPt <- pt
  31.     _pl <- pl
  32.     //开始drag处理
  33.     let stat = ed.Drag(this)
  34.     //返回一个状态值
  35.     stat
  36.   //重写sample函数,仿Kean的写法
  37.   override x.Sampler prompts =
  38.     //获取输入点
  39.     let jo = new JigPromptPointOptions()
  40.     jo.UseBasePoint <- true
  41.     jo.BasePoint <- _startPt
  42.     jo.Cursor <- CursorType.Crosshair
  43.     let respoi:PromptPointResult=prompts.AcquirePoint(jo)
  44.     let curPt = respoi.Value
  45.     let mutable endPt = new Point3d()
  46.     if curPt <> endPt then
  47.        //赋予起始点给p0,赋予当前移动点给p6
  48.        let p0:Point2d = new Point2d(_startPt.X, _startPt.Y)
  49.        let p6:Point2d = new Point2d(curPt.X, curPt.Y)
  50.        //计算起始点和终止点的矢量和角度
  51.        let vec:Vector2d = p6-p0
  52.        let ang:double = vec.Angle
  53.        //下面这几段写的真丑陋,没有一点F#简洁的特点,下一步来进行修改
  54.        let mutable p1=new Point2d()
  55.        let mutable p2=new Point2d()
  56.        let mutable p3=new Point2d()
  57.        let mutable p4=new Point2d()
  58.        let mutable p5=new Point2d()
  59.        let mutable p2a=new Point2d()
  60.        let mutable p4a=new Point2d()
  61.        let mutable d06:double = p6.GetDistanceTo(p0)
  62.        //以下是截断线的画法,是按照1:100的比例画的,没有考虑比例问题
  63.        if d06<=200.0 then
  64.            p1<-p0
  65.            p2<-p0
  66.            p3<-p0
  67.            p4<-p0
  68.            p5<-p0
  69.        else
  70.            let ang1801= Ang2Rad 180.0+ang
  71.            let ang901=Ang2Rad 90.0+ang
  72.            let ang902=ang-Ang2Rad 90.0
  73.            let d0605=0.5*d06
  74.            p3<-PolarPoint p0 ang d0605
  75.            p1<-PolarPoint p3 ang1801 100.0
  76.            p2a<-PolarPoint p3 ang1801 50.0
  77.            p2<-PolarPoint p2a ang901 200.0
  78.            p5<-PolarPoint p3 ang 100.0
  79.            p4a<-PolarPoint p3 ang 50.0
  80.            p4<-PolarPoint p4a ang902 200.0
  81.        _pl.SetPointAt(0, p0)
  82.        _pl.SetPointAt(1, p1)
  83.        _pl.SetPointAt(2, p2)
  84.        _pl.SetPointAt(3, p3)
  85.        _pl.SetPointAt(4, p4)
  86.        _pl.SetPointAt(5, p5)
  87.        _pl.SetPointAt(6, p6)
  88.        endPt <- curPt;
  89.        SamplerStatus.OK
  90.     else
  91.        SamplerStatus.NoChange;
  92.   //重写WorldDraw函数,仿Kean的写法,精简了一下
  93.   override x.WorldDraw (draw : WorldDraw) =
  94.     draw.Geometry.Polyline(_pl, 0,6)
  95.     |> ignore
  96.     true
  97. end

  98. //下面是函数命令部分
  99. [<CommandMethod("qjchen", "mybl", CommandFlags.Modal)>]
  100. let jigjdx() =
  101.   // 开始常用语句
  102.   let doc =
  103.     Application.DocumentManager.MdiActiveDocument
  104.   let ed = doc.Editor
  105.   let db = doc.Database
  106.   // 提示选择起始点
  107.   let startRes = ed.GetPoint("\nSelect first point: ")
  108.   if startRes.Status = PromptStatus.OK then
  109.     let startPt = startRes.Value
  110.     // 创建polyline和运行jig
  111.     let pl:Polyline = new Polyline(7)
  112.     for i=0 to 6 do
  113.         pl.AddVertexAt(i, Point2d(0.0,0.0),0.0,0.0,0.0)
  114.     let jig = new JdxJig()
  115.     let res = jig.StartJig(ed, startPt, pl)
  116.     if res.Status = PromptStatus.OK then
  117.       use tr =
  118.         db.TransactionManager.StartTransaction()
  119.       // 得到块表和块记录
  120.       let bt =
  121.         tr.GetObject
  122.           (db.BlockTableId,OpenMode.ForRead)
  123.           :?> BlockTable
  124.       let ms =
  125.         tr.GetObject
  126.           (bt.[BlockTableRecord.ModelSpace],
  127.           OpenMode.ForWrite)
  128.           :?> BlockTableRecord
  129.       // 把截断线加入到模型空间
  130.       let id = ms.AppendEntity(pl)
  131.       tr.AddNewlyCreatedDBObject(pl, true)
  132.       tr.Commit()

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x

评分

参与人数 1明经币 +1 收起 理由
雪山飞狐_lzh + 1 【好评】好程序 F#,有点晕晕,嘿嘿

查看全部评分

发表于 2010-8-11 17:52:00 | 显示全部楼层

才鸟兄的C# 五角星jig例子

 

在哪能看到

 

F# 不了解

 楼主| 发表于 2010-8-11 19:39:00 | 显示全部楼层

[原创] 个人的第一个F# JIG代码——截断线绘制

谢谢 lzh741206版主:)

 

To bearbear1: 这个例子是来自于我买的一本实体书 《Autocad Vba & Vb.net开发 基础与实例教程》:曾洪飞(网名才鸟),张帆(网名:zfbj),卢择临(ahlzl)几位高手写的书,几位高手也在明经上啊

 

不过刚才看了具体章节,讲jig的第22章是ahlzl兄写的,那我前面写的才鸟的写法可能有误.......

 

F#是函数式语言,有许多优点,我上面的写法是用最啰嗦的方法,无法体现其精髓,等我过些日子更熟悉一些再来改进。

 

由于这是我用F#编的第二个CAD范例,第一个是画圆啊画线找BOUNGDINGBOX等简单操作,第二个就进入这个JIG的撰写,跳跃有点大。调试的时候开始也出现了几十个错误,改了半天。其实F#对空格、缩进等的要求都挺高,最好还是先用C#或者VB.NET来开发好些。只是做了小小的尝试,希望以后熟悉之后能好些。

发表于 2010-8-14 11:40:00 | 显示全部楼层

  回复的这么清楚,万分激动,

 

发表于 2018-3-30 17:19:57 | 显示全部楼层
很好的程序,就是F#看着头大。。。
发表于 2021-12-10 14:16:05 | 显示全部楼层
我第一个学写的程序也是折断线
是四川德钢建筑工地上打工时自学的
只是没你这中途有动态显示这么高大上
但自我感觉还是实用
你这两端与指定点对齐与实用不太符合
实际中都是超出一小段的最后谢谢您的分享
祝您身体健康







本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 05:01 , Processed in 0.173241 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表