天气与日历 切换到窄版

 找回密码
 立即注册
中国膜结构网
十大进口膜材评选 十大国产膜材评选 十大膜结构设计评选 十大膜结构公司评选
查看: 28|回复: 0

AutoClose凸角多边形自动闭合(第2种办法)

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
[code]
;;;========================================================================================;;;
(defun c:tt (/ 2elst a b c d1 delpts en        endpts i lpts lss obj1 odlst pt1 pt2 ptiall ptilst ptm pts rpts        ss tf)
  (progn
    (vl-load-com)
    (defun yj-ss2lst (ss / i l)
      (if ss
        (repeat        (setq i (sslength ss))
          (setq l (cons (ssname ss (setq i (1- i))) l))
        )
      )
    )
;;;=====================================================   
    (defun IntersPointList (en1 lss / OBJ1 PTS)
      (setq lss (vl-remove en1 lss))
      (setq obj1 (vlax-ename->vla-object en1))
      (setq pts
             (vl-remove        nil
                        (mapcar        (function (lambda (x)
                                            (vlax-invoke
                                              obj1
                                              'IntersectWith
                                              (vlax-ename->vla-object x)
                                              acExtendboth
                                            )
                                          )
                                )
                                lss
                        )
             )
      )
    )
    ;|==============================================;;
;;;按序号删除表中的元素-------------------------yjtdkj.2021.07
参数: lst    - 表
参数: n      - 序号(从0开始)
参数: new    - 新元素
返回: 新表
例子: (yj-LST-Idxremove '(11 22 33) 0 )
|;
    (defun yj-LST-Idxremove (lst n / AA M NEWLST)
      (setq newLst '())
      (setq m 0)
      (repeat (length lst)
        (if (= m n)
          (progn
            (setq lst (cdr lst))
          )
          (progn
            (setq aa (car lst))
            (setq newLst (cons aa newLst))
            (setq lst (cdr lst))
          )
        )
        (setq m (1+ m))
      )
      (reverse newlst)
    )
;;;取表中两两相等的点的表
    (defun TwoEqual (ptlst / I NEWLST PT TMP)
      (setq tmp ptlst)
      (setq newlst '())
      (while tmp
        (setq pt  (car tmp)
              tmp (cdr tmp)
        ) ;end setq
        (repeat        (setq i (length tmp))
          (if (equal (nth (setq i (1- i)) tmp) pt 1e-6)
            (progn
              (setq newlst (cons pt newlst))
              (setq tmp (yj-LST-Idxremove tmp i))
            )
          )
        )
      )
      newlst
    )
;;;点表的差集
    (defun ptlst-subtract (lst1 lst2 / I NEWLST PT TMP)
      (while lst2
        (setq pt   (car lst2)
              lst2 (cdr lst2)
        ) ;end setq
        (repeat        (setq i (length lst1))
          (if (equal (nth (setq i (1- i)) lst1) pt 1e-6)
            (setq lst1 (yj-LST-Idxremove lst1 i))
          )
        )
      )
      lst1
    )
;;;点在点表中搜索,如果有,则返回找到的点及以后的表
    (defun memberpts (p lst / PT TF)
      (while (and lst (not tf))
        (setq pt (car lst))
        (if (equal p pt 1e-6)
          (setq tf t)
          (setq lst (cdr lst))
        )
      )
      lst
    )
;;;表变两元素表
    (defun lstto2Elst (lst / E I NEWLST)
      (setq newlst '())
      (while lst
        (setq e          (car lst)
              lst (cdr lst)
        )
        (if lst
          (repeat (setq i (length lst))
            (setq
              newlst (cons (list e (nth (setq i (1- i)) lst)) newlst)
            )
          )
        )
      )
      (reverse newlst)
    )
;;;
    (defun point2pline (lst ent / NEWENT)
      (setq newent '((0 . "LWPOLYLINE")))
      (foreach x '(100 67 410 62 6 370)
        (if (assoc x ent)
          (setq newent (cons (assoc x ent) newent))
        ) ;_  if
      )
      (vla-startundomark
        (vla-get-activedocument (vlax-get-acad-object))
      )
      (entmake
        (append
          (reverse newent)
          (list        '(100 . "AcDbPolyline")
                (cons 90 (length lst))
                '(70 . 1)
          )
          (apply 'append
                 (mapcar (function (lambda (x)
                                     (list
                                       (cons 10 (list (car x) (cadr x)))
                                       (cons 40 0.0)
                                       (cons 41 0.0)
                                       (cons 42 0.0)
                                     )
                                   )
                         )
                         lst
                 )
          )
          (list (assoc 210 ent))
        ) ;_  append
      )
      (vla-endundomark
        (vla-get-activedocument (vlax-get-acad-object))
      )
      (entlast)
    )
;;;----------------------------------------;;;
    (setq *acad        (vlax-get-acad-object)
          *doc        (vla-get-ActiveDocument *acad)
          ;;
          *ms        (if (= (getvar 'ctab) "Model")
                  (vla-get-modelSpace *doc)
                  (vla-get-paperSpace *doc)
                )
    )
    (defun *error* (msg)
      (mapcar 'setvar
              '("cmdecho" "osmode" "peditaccept" "Pickstyle")
              odlst
      )
      (vlax-invoke-method *doc 'EndUndoMark)
      (if (not
            (wcmatch (strcase msg t) "*break,*cancel*,*exit*,*取消*")
          )
        (princ (strcat "\nError: " msg))
      )
      (princ)
    )
    (vlax-invoke-method *doc 'StartUndoMark)
    (setq
      odlst (mapcar 'getvar
                    '("cmdecho" "osmode" "peditaccept" "Pickstyle")
            )
    )
    (mapcar 'setvar
            '("cmdecho" "osmode" "peditaccept" "Pickstyle")
            '(0 0 1 0)
    )
  )
;;;---------------------------------------------------------------------
;;;-------------------主程序开始----------------------------------------
;;;---------------------------------------------------------------------
  (setq ss (ssget))
  (if ss
    (progn
      (setq lss (yj-ss2lst ss))
      (setq ptilst
             (mapcar (function (lambda (x) (IntersPointList x lss))) lss)
      )
      (setq PtiAll (apply 'append ptilst))
      (setq PtiAll (twoEqual PtiAll))
      (setq delpts '())
      (mapcar
        (function (lambda (x)
                    (setq lpts '())
                    (setq rpts '())
                    (setq pts (ptlst-subtract PtiAll x))
                    (while pts
                      (setq ptm        (car pts)
                            pts        (cdr pts)
                      )
                      (setq pt1        (car x)
                            pt2        (cadr x)
                      )
                      (setq
                        a  (- (cadr pt2) (cadr pt1))
                        b  (- (car pt1) (car pt2))
                        c  (- (* -1 a (car pt1)) (* b (cadr pt1)))
                        d1 (- (* -1 a (car ptm)) (* b (cadr ptm)))
                      )
                      (cond
                        ((= d1 c)
                         nil
                        )
                        ((> d1 c)
                         (setq lpts (cons ptm lpts))
                        )
                        ((< d1 c)
                         (setq rpts (cons ptm rpts))
                        )
                      )
                    )
                    (if        (< (length lpts) (length rpts))
                      (setq delpts (cons lpts delpts))
                      (setq delpts (cons rpts delpts))
                    )
                  )
        )
        ptilst
      )
      (setq delpts (apply 'append delpts))
      (setq PtiAll (ptlst-subtract PtiAll delpts))
      (setq 2elst (lstto2Elst PtiAll)) ;图元表转2元素图元表
      (setq 2elst (vl-remove-if-not
                    (function (lambda (x)
                                (setq tf nil)
                                (repeat        (setq i (length ptilst))
                                  (setq pts (nth (setq i (1- i)) ptilst))
                                  (if (and (memberpts (car x) pts)
                                           (memberpts (cadr x) pts)
                                      )
                                    (setq tf t)
                                  )
                                )
                                tf
                              )
                    )
                    2elst
                  )
      ) ;找到所有在线上两点
      (if (= (length 2elst) (length lss))
        (progn
          (setq endpts (car 2elst))
          (setq 2elst (cdr 2elst))
          (while (/= (length endpts) (length lss))
            (if        (or (= i 0) (not i))
              (setq i (length 2elst))
            )
            (setq pts (nth (setq i (1- i)) 2elst))
            (cond ((equal (car endpts) (cadr pts) 1e-6)
                   (progn
                     (setq endpts (cons (car pts) endpts))
                     (setq 2elst (yj-LST-Idxremove 2elst i))
                   )
                  )
                  ((equal (car endpts) (car pts) 1e-6)
                   (progn
                     (setq endpts (cons (cadr pts) endpts))
                     (setq 2elst (yj-LST-Idxremove 2elst i))
                   )
                  )
            )
          )
        )
      )
      (setq en (point2pline endpts (entget (car lss))))
    )
    (progn
      (mapcar 'setvar
              '("cmdecho" "osmode" "peditaccept" "Pickstyle")
              odlst
      )
      (exit)
    )
  )
  (mapcar 'setvar
          '("cmdecho" "osmode" "peditaccept" "Pickstyle")
          odlst
  )
  (vlax-invoke-method *doc 'EndUndoMark)

  (princ)
)[/code]

 

 

 

 

AutoClose凸角多边形自动闭合(第2种办法)

该用户从未签到

主题

0

回帖

0

积分

管理员

积分
0
发表于 2024-7-28 09:28:43 | 显示全部楼层
  法拉利膜材作为一种高性能的建筑材料,在建筑、汽车及广告等多个领域有着广泛的应用。以下是对法拉利膜材型号、特点及优点的详细分析:
[img]http://www.mjgou.com/data/attachment/forum/202403/13/223041uiqmeujen4jjj6zv.jpg[/img]
[b]一、法拉利膜材型号[/b]
法拉利膜材有多种型号,包括但不限于以下几种:1302 S2 Flexlight Advanced:这是一种高性能IV型柔性复合膜材,以其卓越的透光性、耐久性和易维护性而受到青睐。942、1202 S2、1002 S2、902 S2、1212 S2、912 S2:这些型号同样属于法拉利膜材系列,各自具有不同的特性和适用范围,但具体特点需根据具体型号进一步分析。需要注意的是,法拉利膜材的型号可能随着产品更新换代而有所变化,具体型号及其特性请参考最新产品资料。
[img=860,1255]http://www.mjgou.com/data/attachment/forum/202403/13/223254bbblwlbvbvsbwlsl.jpg[/img]
[b]二、法拉利膜材特点[/b]
法拉利膜材的特点主要体现在以下几个方面:
1、高强度与耐用性:法拉利膜材采用高强度材料制成,具有良好的抗拉强度和撕裂强度,能够承受较大的外力作用而不易破损。耐用性强,能够在恶劣气候条件下保持稳定的性能,延长使用寿命。
2、透光性与美观性:部分型号如1302 S2 Flexlight Advanced具有高透光性,能够在保持室内光线充足的同时,提供清晰的视野。膜材表面平整光滑,色彩丰富多样,能够满足不同建筑和装饰需求,提升整体美观性。
3、轻质与灵活性:法拉利膜材重量较轻,便于运输和安装,能够降低施工成本和时间。膜材具有一定的柔韧性,能够适应各种复杂形状和结构的设计要求。
4、环保与可回收性:法拉利膜材符合环保要求,部分材料可回收利用,减少了对环境的影响。
[img]http://www.mjgou.com/data/attachment/forum/202403/13/223128owhn0099rrds5h5y.jpg[/img]
[b]三、法拉利膜材优点[/b]
法拉利膜材的优点主要体现在以下几个方面:
1、提升建筑性能:高强度与耐用性使得法拉利膜材能够提升建筑的稳定性和安全性,延长使用寿命。透光性与美观性使得建筑内部光线充足、视野开阔,同时提升整体美观度。
2、降低施工成本:轻质特性使得运输和安装成本降低,施工效率提高。膜材的柔韧性使得施工更加灵活多变,能够适应各种复杂地形和结构要求。
3、节能环保:部分材料可回收利用,符合环保要求,减少了对环境的影响。良好的透光性能够减少室内照明需求,降低能耗。
4、广泛应用领域:
法拉利膜材不仅适用于建筑领域(如体育设施、商业设施、文化设施、交通设施等),还广泛应用于汽车及广告领域(如高档车辆贴膜保护和装饰、广告招贴等),展现出其多功能的特性。

综上所述,法拉利膜材以其高强度、耐用性、透光性、美观性、轻质灵活性以及环保可回收性等优点,在建筑、汽车及广告等多个领域发挥着重要作用。具体型号的选择应根据实际需求和应用场景进行综合考虑。
[url=http://www.mjgou.com/forum-17-1.html][size=10971][color=Red]法拉利膜材中国代理商 - 膜结构网[/color][/size][/url]
AutoClose凸角多边形自动闭合(第2种办法)

该用户从未签到

主题

0

回帖

29

积分

新手上路

积分
29
发表于 2024-8-6 10:42:43 | 显示全部楼层
希运膜材,作为比利时希运工业集团(Sioen Industries)的核心产品之一,在涂层织物领域享有很高的声誉。以下是对希运膜材的详细分析:
[b]一、公司背景与实力[/b]
希运工业集团是比利时涂层织物专业的生产商,拥有超过20个分厂,主要经营范围包括涂层、服装和化工三个部分。集团在全球拥有约4000多名优秀员工,通过不断融会贯通和改革创新,不仅拥有世界最精湛的生产技艺,还开发出了许多尖端的涂层产品。其原材料自产化,确保了产品质量的一贯性和最佳状况,使希运产品在全球市场中占据领先地位。
[b]二、产品特点[/b]
高强度与柔韧性:希运膜材是一种由聚酯、聚酰胺、聚乙烯等多种材料复合而成的高分子材料,具有高强度和优异的柔韧性。这种特性使得膜材能够形成复杂的曲面造型,满足各种建筑设计需求。
耐久性与防火性:希运膜材具有耐久性强的特点,能够抵抗紫外线、化学腐蚀等外部环境的侵蚀,延长使用寿命。同时,其防火等级通常为B1级,属于难燃材料,提高了建筑的安全性。
自洁性:部分希运膜材表面经过特殊处理,具有良好的自洁性能。雨水在其表面聚成水珠流下,自然清洗膜材表面,减少清洁成本。
光学性能:希运膜材对自然光的透射率较高,同时能够滤除大部分紫外线,防止内部物品褪色。透射光在结构内部产生均匀的漫射光,无阴影、无眩光,具有良好的显色性。
保温与隔热性能:希运膜材具有优异的保温和隔热性能,能够调节建筑内部温度,提高能源利用效率。
环保性:希运膜材注重环保性能,部分产品可回收再利用,符合现代绿色建筑的发展趋势。
[b]三、应用领域[/b]
希运膜材的应用领域非常广泛,主要包括以下几个方面:
建筑领域:希运膜材被广泛用于膜结构建筑、帐篷、遮阳篷等场合。其轻质、高强度的特性使得膜结构建筑更加经济、美观且实用。
广告与运输领域:希运膜材在广告牌、车厢顶盖、集装箱顶盖等场合也有应用。其耐久性和自洁性使得广告画面更加持久鲜艳,同时降低维护成本。
休闲与安全领域:希运膜材还用于充气玩具、游泳池、防护材料、工业用布等休闲和安全领域。其柔韧性好、耐磨损的特点使得产品更加安全可靠。
[b]四、技术创新与发展[/b]
希运工业集团一直致力于技术创新和产品研发,不断推出适应市场需求的新产品。其涂层技术精湛,产品质量上乘,得到了国内外用户的广泛认可。同时,希运还注重环保和可持续发展,积极推广绿色建筑材料和技术。
[b]五、总结[/b]
希运膜材作为一种高性能的涂层织物材料,在多个领域展现出卓越的性能和广泛的应用价值。其高强度、柔韧性、耐久性、自洁性等特点使得产品更加符合现代建筑和工业应用的需求。随着技术的不断进步和市场的不断发展,希运膜材的应用前景将更加广阔。

 

 

 

 

AutoClose凸角多边形自动闭合(第2种办法)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|中国膜结构网|中国膜结构协会|进口膜材|国产膜材|ETFE|PVDF|PTFE|设计|施工|安装|车棚|看台|污水池|中国膜结构网_中国空间膜结构协会

GMT+8, 2024-11-1 13:33 , Processed in 0.155286 second(s), 27 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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