明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 19294|回复: 20

[基础] [飞马系列] AutoCAD 2014 之Javascript API编程初探

[复制链接]
发表于 2013-10-20 18:50:44 | 显示全部楼层 |阅读模式
本帖最后由 qjchen 于 2024-11-3 22:09 编辑

[飞马系列] AutoCAD 2014 之Javascript编程初探

qjchen

2013.10.1

(一)简介

Autocad 2014的一个重要特性,就是从这个版本开始支持Javascript编程了。

一直有些忙,前些日子稍空了,本人杂学而不精,颇喜尝新,花了几天学习了一下其编程入门,发现网络上此类似的学习心得不多,中文的似乎没有,于是将近日一些学习心得草录如下,权当学习笔记。不过最后两个例子,得迟些才能放上源码和介绍了。

1. 重要参考资料

1)Autocad Devblog,应该是官方开发人员的公用blog

http://adndevblog.typepad.com/au ... n-autocad-2014.html

这篇文章中的附件是一个开发视频及相关例子资料,是非常好的学习资料。

2) JavaScript Application Programming Interface (API) for AutoCAD

http://www.autocadws.com/jsapi/v1/docs/

官方的API资料,不过从其中可以看出,现在其内容还是比较简陋的,正如第一版.net时候的帮助一样

3)  Kean的相关文章

http://through-the-interface.typ ... terface/javascript/

Kean是Autocad公司的二次开发专家,第一个官方附件中的好些例子其实就是出自Kean之手

其中的几篇博文

缩放显示物体到最大化

http://through-the-interface.typ ... ing-javascript.html

Jig圆

http://through-the-interface.typ ... efined-command.html

等,均是非常好的学习资料

本人研读了以上文献后入门。

2. Javascript 编程的优缺点

由于只是粗浅了解Javascript编程,以下仅为本阶段个人体会

1)方便网络编程,也可较方便地可以利用网络Javascript库。

这个Kean在其文章中也提到了希望引入Paper.js及leap.js等有趣的2d图形库。而本人也通过尝试d3.js库了解了利用网络库编程的优点,因此,如box2d、Processing.js、Raphaël、Math.js等图形库和物理引擎库等。熟悉Javascript的朋友自然可以更得心应手。而且,大家可以创建自己的函数库,放置于网络,及时更新。

帖子后文将介绍关于d3库用于delaunay图形绘制的代码。近两年,html5发展迅猛,基于html5的Javascript库如雨后春笋,这也必将对其他相关领域带来活力。

部分Javascirpt库可参见

http://www.comsharp.com/GetKnowl ... mothyPage_K741.aspx

2)可以很好地利用html界面。

Html+div+css是现在网络上流行的页面布局,善用div可以得到非常漂亮的页面。Javascript和.net的混合编程,可以通过.Net在Palette中引入html界面,这将使得页面布局更加简单和丰富。后文将以一个简单的例子来说明其应用

缺点:

由于并非很深入的研究,此处说法或许有误。

个人觉得Javascript毕竟是脚本类程序,可能在运行效率上比之Arx或者.Net有所不如。

另,由于Javascript在这一版本中首次引入,因此其函数有缺失。上次咨询了第一个文献的作者Philippe Leefsma后确认,Javascript API在本阶段并没有开放太多的物体数据库的操作函数(大概只是探路版本吧),因此比如画圆、获取多义线顶点等内容无法直接用Javascript进行操作,必须自编.Net程序或者ARX程序用于扩展Javascript函数,现阶段还是比较麻烦。

下面本人以3个感兴趣的几个自学例子探讨一下JavaScript的应用,仅当抛砖引玉。各位尽可讨论,不过鉴于本人水平有限,也不见得能回答。并对官方范例中的几个例子进行抓图说明。




评分

参与人数 6明经币 +11 金钱 +82 收起 理由
tryhi + 1 赞一个!
3xxx + 1 + 5 很给力!
不死猫 + 3 + 18 很给力!
河伯 + 2 + 9 赞一个!
lzx838 + 3 + 20
chlh_jd + 1 + 30 赞一个!

查看全部评分

 楼主| 发表于 2018-1-7 11:38:37 | 显示全部楼层
simpleye 发表于 2015-5-5 10:02
按你的方法,加载菜单index.html后,一片空白

原来'http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js'
这个网站不好访问了,得重新下载https://code.jquery.com/jquery-3.2.1.min.js
放到同个目录下
把这句话改成
<script src='jquery-3.2.1.min.js'></script>
才能顺利运行
发表于 2018-11-12 17:46:10 | 显示全部楼层
请问,为啥我的2018 和2019都无法执行webload的命令啊,输入了url,没有返回值啊
发表于 2020-7-18 13:41:31 | 显示全部楼层
放弃吧,官方已经停止支持了,相关的连接已经失效,这是一次失败的尝试。
 楼主| 发表于 2013-10-20 18:51:50 | 显示全部楼层
本帖最后由 qjchen 于 2013-10-21 09:46 编辑

(2) Helloworld
下载附件得到helloworld.JS, 或打开记事本,键入如下代码,存为如helloworld.JS

  1. function helloWorld() {

  2.     write("\nHello World\n");

  3. }

  4. Acad.Editor.addCommand(

  5.   "Q_CMDS",

  6.   "HELLOWORLD",

  7.   "HELLOWORLD",

  8.   Acad.CommandFlag.TRANSPARENT,

  9.   helloWorld

  10. );

  11. write("\nRegistered helloworld command.\n");

复制代码
语句后解释,需要注意的“HELLOWORLD”必须是全部大写的。

打开AUTOCAD 2014(注意,此版本之后的才开始支持JAVASCRIPT编程,切记,本文均以针对此版本进行), 在命令行键入webload命令。



跳出如图命令行,键入文件全路径,(没有文件框,需自己键入,可通过与.NET交互编程实现界面选择)



之后,跳出此窗口,问是否加载,按加载

如顺利成功的话,会在命令行出现

Registered helloworld command.此语句

那么,键入helloworld

会在命令行出现

Hello World 的字样



再回过头来看那些代码

  1. function helloWorld() {

  2.     write(“\nHello World\n”);

  3. }
复制代码
这个与C#的语句还是比较类似的,建议可以找些JAVASCRIPT的入门教程学下,我自己也不太懂,边学边记录。

  1. Acad.Editor.addCommand(

  2.   “Q_CMDS”,

  3.   “HELLOWORLD”,

  4.   “HELLOWORLD”,

  5.   Acad.CommandFlag.TRANSPARENT,

  6.   helloWorld

  7. );
复制代码
这个必须查AUTOCAD JAVASCRIPT API函数了



http://www.autocadws.com/jsapi/v ... obalName@localName@flags@jsFunc.html

这里可以看到

function Acad.Editor.addCommand(groupName,globalName,localName,flags,jsFunc);

分别对应的应该是一个命令组名,国际命令名,本土命令名,是透明命令还是普通命令,所对应的JS函数这样的内容。

groupName: is a string that specifies the command group name for adding this command.

globalName: is a string that specifies the global and untranslated name of the command to add.

localName:is a string that specifies the local and translated name of the command to add.

Flags:is an integer that specifies the flag associated with the command.

Note:The flags should be either Acad.CommandFlag.TRANSPARENT or Acad.CommandFlag.MODAL and can be logically OR’d with other flags in Acad.CommandFlag.

jsFunc:is the callback function to be executed when this command is invoked.

Note: It returns the command name and command event name specified in Acad.CmdEventName. As it is a synchronous callback, it should return value, such as return JSON.stringify({ retCode: Acad.ErrorStatus.eJsOk });


最后一行的write(“\nRegistered helloworld command.\n”);

是在命令行显示命令已加载。

由于JAVASCRIPT现在的调试还较麻烦,所以,一旦语句有误之后,经常会加载不成功,

且无任何提示。

且若在同名文件中进行修改,往往无法重新webload掉原来的来覆盖问题,经常都只能是改名webload或者是关闭cad重启来解决问题。

希望后续版本能在这方面做些改进,才能让这项有趣的技术更加推广。

所以可以看出,相对.NET编程需要编译成为DLL而言,JAVASCRIPT在这一点更像LISP多些。

本帖子中包含更多资源

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

x
 楼主| 发表于 2013-10-20 18:52:40 | 显示全部楼层
本帖最后由 qjchen 于 2013-10-23 20:10 编辑

(2) 自定义漂亮菜单
界面如下



Mjtd许多朋友很喜欢采用自制菜单来实现对自定制命令的使用
如老迈兄等都曾经推出过许多方便使用的Lisp工具
但要制作一个漂亮的菜单确实也不容易,即使在.net中也不容易
相对而言,应用html的菜单确实网上随处可见,利用ACAD官方例子中的ACHTML范例,可非常容易做出上图的效果

Mjtd许多朋友很喜欢采用自制菜单来实现对自定制命令的使用
如老迈兄等都曾经推出过许多方便使用的Lisp工具
但要制作一个漂亮的菜单确实也不容易,即使在.net中也不容易
相对而言,应用html的菜单确实网上随处可见,利用上述的ACHTML范例,可非常容易

先学下怎么做HTML+CSS的菜单
对于HTML,大家总可以看到许多漂亮的菜单,这种菜单可以是JAVASCRIPT做的,也可能是FLASH做的,或者是其他类型的。
CSS是叫样式表,我也只懂皮毛,美工好的朋友可以用之做出非常炫的效果,也可以制作多种主题,随时更换skin(皮肤)。
参考资源:1. CSS禅意花园,这是一个非常著名的关于CSS的网站
这里可以看到许多设计

这是一本由禅意花园作者写的书(中文翻译版)
总而言之,CSS可以让界面很漂亮。
可是自己做菜单也不容易
于是,找到了这个网站
CSS菜单在线制作
可以看到有横版、竖版、TAB版等许多种内置模板












本文是利用了其中的
这个模板来进行制作的。
下载了该模板了之后
打开zip
可以发现里面有三个文件
index.html
menu_jquery.js
styles.css
那么,后两个文件不用修改,只需要修改第一个文件
(注,styles.css就是样式表文件,而menu_jquery.js则是一个利用了jquery库编写的Javascript代码)

打开index.html,在里面做如下的一些修改,内容如下

<!DOCTYPEhtml>
<html>
<head>
<meta http-equiv="content-type"content="text/html; charset=gb2312" />
            <link rel='stylesheet'type='text/css' href='styles.css' />
            <scripttype="text/javascript"src="http://www.autocadws.com/jsapi/v1/Autodesk.AutoCAD.js"></script>
            <scriptsrc='http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js'></script>
            <script type='text/javascript'src='menu_jquery.js'></script>
</head>
<body>
<script>
  function myFunction()
  {
  Acad.Editor.executeCommand("circle");
}
</script>

<divid='cssmenu'>
<ul>
   <li class='active'><ahref='index.html'><span>qjchen工具箱</span></a></li>
   <li class='has-sub'><ahref='#'><span>几何工具</span></a>
      <ul>
         <li><a href='#'><span>螺旋彩线</span></a></li>
         <li><ahref="javascript:myFunction()"><span>画圆</span></a></li>
         <li class='last'><ahref='#'><span>字归圆心</span></a></li>
      </ul>
   </li>
   <li class='has-sub'><ahref='#'><span>尺寸</span></a>
      <ul>
         <li><ahref='#'><span>尺寸归原</span></a></li>
         <li class='last'><ahref='#'><span>尺寸加减</span></a></li>
      </ul>
   </li>
   <li class='last'><ahref='#'><span>三角网</span></a></li>
</ul>
</div>
</body>
</html>


里面红色部分是我的修改。
可以看出
<meta http-equiv="content-type"content="text/html; charset=gb2312" />
是为了让其支持中文
            <scripttype="text/javascript"src="http://www.autocadws.com/jsapi/v1/Autodesk.AutoCAD.js"></script>
是在线引入了Autodesk.AutoCAD.js

<script>
  function myFunction()
  {
  Acad.Editor.executeCommand("circle");
}
</script>
是定义了一个函数,用ACAD JS API函数Acad.Editor.executeCommand("circle");来发送画圆的命令,大家在导入LISP函数之后,就可以发送LISP函数名的。
后面的红色字体,大部分都是改菜单内容,只有其中的
<li><a href="javascript:myFunction()"><span>画圆</span></a></li>
是定义了菜单内容和Javascript函数的相关联系的。

好了,菜单制作完成,但是为了要在ACAD中引用,必须采用5楼中的ACHTML的程序。
附件中包含了这个已编译的CAD官方例子的ACHTML.DLL
这个时候,可参见5楼的说法
AUTOCAD命令行键入 NETLOAD,然后找到AcHTML.dll进行加载 (与普通.Net程序无异)
加载完毕后,键入ADNJSDEMO,加载这个菜单index.html导入,那么就得到了如图的结果了。
点击画圆,即可画圆。(其他菜单本文中未附加函数处理,故无法运行)

本帖子中包含更多资源

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

x

点评

的确好看,楼主加油  发表于 2013-10-21 18:29
 楼主| 发表于 2013-10-20 18:53:26 | 显示全部楼层
本帖最后由 qjchen 于 2013-11-9 20:15 编辑

(3) Delaunay 三角网的建立
之前说过,Javascript最大的一个优势,是可以在线引用函数库,那么现在HTML5的势头很猛,不少非常有趣的JAVASCRIPT函数库也逐步推出,我们不妨一试,下面是我采用D3.JS函数库进行的Delaunay三角形测试。如下图


之前说过,Javascript最大的一个优势,是可以在线引用函数库,那么现在HTML5的势头很猛,不少非常有趣的JAVASCRIPT函数库也逐步推出,我们不妨一试,下面是我采用D3.JS函数库进行的Delaunay三角形测试。如下图

好的,终于有点时间了
打开附件中的dwg


如图所示,就是在一个(0,0)-(960,500)的矩形,内部有一些零散的点。
本文的目的是针对此零散点,建立Delaunay关系图。
之所以选择(960,500)并没有特别的意义,只是为了保证后面的图形出现在左边的HTML界面中而已。

附件中有一个test.js和一个delaunay-me.html
其中的delaunay-me.html的内容是大量引用了
http://static.cybercommons.org/j ... aunay/delaunay.html
的内容
在此表示非常感谢。
由其源码知道其就是采用了d3这个Javascript数据库。
那先简单介绍一下d3,这是一个将数据和图形进行关联的库。主要作用,比如数据图形化等。内置了一些计算几何函数,如Delaunay就是其中一个。
http://d3js.org/


https://github.com/mbostock/d3/wiki/Gallery
这里有更多的范例,简支是眼花缭乱啊。
后面有时间,再在其他楼给出各种有名的Javascript函数库。
那么,也就是说,在以后的cad编程中,你拥有了更多的工具箱了。

好,回归原文。
改造后的javascript文件和html文件如下(可直接下载附件)
delaunay-me.html

  1. <html>
  2. <head>
  3.   <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
  4.   <title>Delaunay Triangulation</title>
  5. <script type="text/javascript" src="http://static.cybercommons.org/js/d3/d3.v2.js"></script>
  6.   <script type="text/javascript" src="http://www.autocadws.com/jsapi/v1/Autodesk.AutoCAD.js"></script>
  7.   <script type="text/javascript" src="test.js"></script>
  8.   <style type="text/css">
  9.   @import url("http://static.cybercommons.org/js/d3/lib/colorbrewer/colorbrewer.css");
  10.   path {
  11.     stroke: #000;
  12.     stroke-width: .5px;
  13.   }
  14.   </style>
  15. </head>
  16. <body>
  17. <input type="button" value="Select object" />
  18.   <input type="button" value="Draw Delaunay in Html" />
  19.   <input type="button" value="Draw Delaunay in Cad (slow)" />
  20. </body>
  21. </html>


test.js
  1. //全局变量
  2. var allpointshtml=new Array();
  3. var allpoints=new Array();

  4. //用于获取物体
  5. function setPromptSelectionOptions(options) {
  6.             options.messageForAdding = "\n Please select some entities";
  7. }

  8. //成功的话运行此步
  9. function onCompletePromptSelectionResult(jsonPromptResult) {
  10.     var resObj = JSON.parse(jsonPromptResult);
  11.     allpoints.length = 0;
  12.     allpointshtml.length = 0;
  13.     if (resObj) {
  14.         if (resObj.status == 5100) { // normal (point selected/entered)
  15.             var x=JSON.stringify(resObj);
  16.             //write(x);
  17.             var allselect=resObj.value
  18.             var i=0;
  19.             for (var x in allselect)
  20.            {
  21.              var z=allselect[i];
  22.              write(JSON.stringify(z));
  23.              var entity = new Acad.DBEntity(z.objectId);
  24.            var ext = entity.getExtents();
  25.            //write(JSON.stringify(ext));
  26.                 //write(JSON.stringify(ext.minPoint3d.x));
  27.                 //write(JSON.stringify(ext.minPoint3d.y));
  28.             allpointshtml[i]=new Array(ext.minPoint3d.x,500-ext.minPoint3d.y);
  29.             allpoints[i]=new Array(ext.minPoint3d.x,ext.minPoint3d.y);
  30.             //write(allpoints[i][0]);
  31.             i=i+1;
  32.             }
  33.         }
  34.     }
  35. }

  36. //失败的时候运行此步
  37. function onErrorPromptResult(jsonPromptResult) {
  38.     write("\nerror\n")
  39. }

  40. //处理选择的函数
  41. function promptForSelectionqjchen() {
  42. write("\nHi\n")
  43.         var options = new Acad.PromptSelectionOptions();
  44.         setPromptSelectionOptions(options);
  45.         Acad.Editor.getSelection(options).then(
  46.             onCompletePromptSelectionResult,
  47.             onErrorPromptResult);
  48. }

  49. //绘制三角形
  50. function myFunctionpolyLine(p1,p2,p3)
  51. {
  52.   Acad.Editor.executeCommand("pline "+p1[0]+","+p1[1]+" "+p2[0]+","+p2[1]+" "+p3[0]+","+p3[1]+" "+p1[0]+","+p1[1]+" ");
  53. }

  54. //画三角形
  55. function drawDelaunayHtml()
  56. {
  57.   //这段在html界面上绘制出delaunay三角形
  58.   var width = 960,
  59.   height = 500;
  60.   var verticeshtml = allpointshtml;
  61.   var svg = d3.select("body")
  62.       .append("svg")
  63.       .attr("width", width)
  64.       .attr("height", height)
  65.       .attr("class", "PiYG");
  66.   var res=svg.append("g")
  67.     .selectAll("path")
  68.     .data(d3.geom.delaunay(verticeshtml))
  69.   res1=res[0];
  70.   res.enter().append("path")
  71.           .attr("class", function(d, i) { return "q" + (i % 9) + "-9"; })
  72.           .attr("d", function(d) { return "M" + d.join("L") + "Z"; });
  73. }

  74. function drawDelaunayCad()
  75. {
  76.   //下面这段是采用不得已的发送命令法来绘制delaunay图,若去掉,会发现其实js算法也挺快的,就是发送太慢了
  77.         //改进的方法是采用.NET扩展JS的方法
  78.         var vertices = allpoints;
  79.   var dme=d3.geom.delaunay(vertices);
  80.         var i,j;
  81.   for(i=0;i<dme.length;i++)
  82.   {
  83.     var a1=new Array();
  84.     a1=dme[i];
  85.     for(j=0;j<a1.length;j++)
  86.     {
  87.         var v1=new Array();
  88.         var v2=new Array();
  89.         var v3=new Array();
  90.         v1=a1[0];
  91.         v2=a1[1];
  92.         v3=a1[2];
  93.         myFunctionpolyLine(v1,v2,v3);
  94.     }
  95.   }
  96. }
可以看出这次的代码要比前两次都长不少。
代码稍后略做解读,此处先讲应用。

同上一楼说法,为了要在ACAD中引用,必须采用5楼中的ACHTML的程序。
3楼附件中包含了这个已编译的CAD官方例子的ACHTML.DLL。
这个时候,可参见5楼的说法
到AUTOCAD命令行键入 NETLOAD,然后找到AcHTML.dll进行加载 (与普通.Net程序无异)。
加载完毕后,键入ADNJSDEMO,加载这个菜单delaunay-me.html导入,那么就得到了本楼第一图左侧的面板。
点击 select object,选择drawing1.dwg中方框内的点。再点击Draw Delaunay in Html,则在面板左侧出现了delaunay图。再点击 Draw Delaunay in Cad (slow),则可以看到慢慢地在cad中绘制了这些图形出来。之所以加slow,确实是很慢,主要原因是这个版本的javascript没有内置cad绘图函数,我只好用发送命令的方法慢慢来。如1楼所说,咨询了官方范例作者Philippe Leefsma和Kean大师后确认,Javascript API在本阶段并没有开放太多的物体数据库的操作函数,因此连画直线比如画圆、获取多义线顶点等内容无法直接用Javascript进行操作,或者用发送命令,或者必须自编.Net程序或者ARX程序用于扩展Javascript函数,大家可以参考Kean的代码,我编了一下,也不难,但此处暂时不做讨论。


代码解读:
Html代码中
<script type="text/javascript" src="http://static.cybercommons.org/js/d3/d3.v2.js"></script>
<script type="text/javascript" src="http://www.autocadws.com/jsapi/v1/Autodesk.AutoCAD.js"></script>
<script type="text/javascript" src="test.js"></script>

这三句话是很重要的
第一句,表明了在此页面中,引用了d3函数库。
第二句,表明引用了cad的java api函数。
第三句,表明要引用我们自己写的test.js函数。

@import url("http://static.cybercommons.org/js/d3/lib/colorbrewer/colorbrewer.css");
这句话,大家可以看到我们在html截面上绘制的delaunay图还是很漂亮的,这个定义来自于css定义。是http://static.cybercommons.org/j ... aunay/delaunay.html
这个文件中原语句。

<input type="button" value="Select object" />
  <input type="button" value="Draw Delaunay in Html" />
  <input type="button" value="Draw Delaunay in Cad (slow)" />
这三句话,则是定义了按钮和对应引用的test.js中的函数的。

其实我最早的时候,希望在test.js中,嵌入d3.js等,后来发现,只能通过html来联系两个js文件,只好作罢。
下面解读一下test.js
① allpointshtml和allpoints全局函数的定义
只是为了拆分函数短些,否则这选择物体、绘图在html和cad,都可以写在一起的。
之所以分别定义,是因为html界面绘制的坐标方向和cad是上下颠倒的,y轴方向是向下的。

② setPromptSelectionOptions
这个只是一个设置选择项的小函数,其实可以合并到后面函数中的。

③ function promptForSelectionqjchen() {
write("\nHi\n")
        var options = new Acad.PromptSelectionOptions();
        setPromptSelectionOptions(options);
        Acad.Editor.getSelection(options).then(
            onCompletePromptSelectionResult,
            onErrorPromptResult);
}
这个函数是用于物体选择的,在这里面,必须采用 一个分支结构 .then(A,B)来实现,这个看了文献,是acad javascript api要求的,只好照用。


④ function onCompletePromptSelectionResult(jsonPromptResult)
这个函数是得到点的坐标,供下一步使用。
var resObj = JSON.parse(jsonPromptResult);
范例都是这样写的。
大概在这个API中,cad的结果是通过json这样的形式传递给javascript的。(关于json,其实就是一种数据结构,和xaml有点像,但更加紧凑些,我们可以通过write来看到这些内容。可以百度或者google一下json)
allpoints.length = 0;
allpointshtml.length = 0;
把这两个数组清空的写法。
if (resObj.status == 5100) { // normal (point selected/entered)
            var x=JSON.stringify(resObj);
            //write(x);
            var allselect=resObj.value
这个5100是表明有结果出来了,那么将.value赋值给allselect
for (var x in allselect)
           {
                   var z=allselect;
                   write(JSON.stringify(z));
                   var entity = new Acad.DBEntity(z.objectId);
                 var ext = entity.getExtents();
这一段是将得到的点的坐标取出来的。
前文说过,要得到物体的属性,一般这个阶段的javascript是不行的,但有几个是漏网之鱼的,这个entity.getExtents()居然是存在的,就是物体的包围框,类似lisp中的bounding box,非常奇怪,Kean最大化物体的那个例子,就是用getExtents的。那么,假如要获得点的坐标,或者圆的圆心和直径,可以用这种取巧的方法得到,不需要用.net去扩展。

好了,有了点的坐标,就可以利用d3函数了
function drawDelaunayHtml()
var width = 960,
        height = 500;
        var verticeshtml = allpointshtml;
        var svg = d3.select("body")
                  .append("svg")
                  .attr("width", width)
                  .attr("height", height)
                  .attr("class", "PiYG");
        var res=svg.append("g")
                .selectAll("path")
                .data(d3.geom.delaunay(verticeshtml))
        res1=res[0];
        res.enter().append("path")
                .attr("class", function(d, i) { return "q" + (i % 9) + "-9"; })
                .attr("d", function(d) { return "M" + d.join("L") + "Z"; });
这一段基本是http://static.cybercommons.org/j ... aunay/delaunay.html
这个文件中原语句。

关键的就是这句话
d3.geom.delaunay(verticeshtml)
这句话,就已经把我们前文得到的verticeshtml这些点的坐标,变成一堆Delaunay关系区域了,只要把他们提取出来,就是结果,所以,这句话是最主要的。
其他,关于svg和链式写法,可以参考这篇Scott Murray的教程http://alignedleft.com/tutorials/d3/,里面写的非常好。深入浅出,非常好文。

至于
drawDelaunayCad()
里面,主要是提取了d3的Delaunay结果,来绘制图形而已。
采用了 Acad.Editor.executeCommand("pline "+p1[0]+","+p1[1]+" "+p2[0]+","+p2[1]+" "+p3[0]+","+p3[1]+" "+p1[0]+","+p1[1]+" ");
这种非常落后的方法来实现。
希望下次有时间,能把这个.NET扩展JS API的过程也写下来。

这一楼其实主要是引入了一种网络库的思路,来解决cad的问题。
扩展思路还有许多
比如,物理库的引入,图形库的引入,神经网络….. 许多许多。
可能解决问题的思路,又可以多一种。


本帖子中包含更多资源

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

x
 楼主| 发表于 2013-10-20 18:54:11 | 显示全部楼层

http://qjchen.mjtd.com/wp-content/uploads/2013/10/4.png

本帖最后由 qjchen 于 2013-10-20 19:23 编辑

(5) 官方范例中的一些应用截图说明

其实这个在3楼,4楼中应该都得用到,此处放到最后,主要是让2,3,4楼连续而已

所下载的autocad_2014_getting_started_with_javascript_api 文件中,分了



等几个部分

其中Sample就是一些代码

Recording是一个视频,是配合pptx讲解的

看一遍可对整个Javascript开发有个比较清晰的认识。

而Sample目录中



Extending Js API Test 是介绍和.NET及ARX进行结合,扩展JAVASCRIPT FOR AUTOCAD API的功能的,如上所述,此版本的JAVASCRIPT还比较简单,许多功能没有提供,但是开发人员自己可以通过.NET或者.ARX给JAVASCRIPT API加函数,比如画线,取坐标等基本功能现阶段都得靠编外接函数来实现,所以,此版本只能算是一个展现思想的版本。

Achtml是一个.Net程序源码,是教你如何用Palette(也就是CAD中的各种面板)来调用Html文件,而html文件中可以内置Javascript代码的。这点将使得Javascript不在是枯燥的后台,而是可以通过html来展示其迷人魅力的了,这点是我感觉最深的。



里面包括了这么多内容,后面将抓几张应用图表明他们的作用的



后面两个目录,由于尚未仔细研究,待学习后再补上

以下简单介绍一下ACHTML中的几个应用

那么,要使用这个ACHTML,必须先用VISUAL STUDIO 2010(2008有可能是不行的)

打开ACHTML进行编译,编译成功后

到AUTOCAD命令行键入 NETLOAD,然后找到/bin/debug/ AcHTML.dll进行加载 (与普通.Net程序无异)。

加载完毕后,键入ADNJSDEMO,那么可以到ACHTML/UnitTests/找到某个html进行导入,



比如这个TESTPREVIEW的



那么,左图中的capture preview,就会实现对当前界面的抓图,挺有趣的

Testview是一些获取与视图相关的函数测试 (里面的zoom的我测试总有问题)



Sysvar是与系统变量相关的



PromptSelection是与选择相关的



Prompt是和prompt相关的(好像很废话)主要就是测试如要求选矩形,填整数之类的



Misc中是几个命令测试



如显示页面、高亮物体、执行命令等,不过我在测试这个的时候,CAD崩溃了几次 J



比如你选中了一个物体作为listener之后,以后每次如移动这个物体,就会得到相应的Event的记录。
发表于 2013-10-29 21:04:56 | 显示全部楼层
这次长见识了
 楼主| 发表于 2013-11-9 20:28:34 | 显示全部楼层
谢谢喜欢 :)
终于把delaunay的补全了,过了许久。
找些时间再检查一遍,改改错。
发表于 2014-2-28 11:34:53 | 显示全部楼层
膜拜一下!!!
发表于 2014-2-28 15:17:00 | 显示全部楼层
好文前排果断露脸
发表于 2014-3-1 09:08:24 | 显示全部楼层
好文章。
要好好学习学习。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-1-9 11:33 , Processed in 0.222422 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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