国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JavaScript實現封閉區域布爾運算的示例代碼

2024-05-06 16:45:02
字體:
來源:轉載
供稿:網友

這篇文章主要介紹多段線實現布爾運算的方法

先上代碼

function getOperatedCurves(sourceCurs: Curve[], targetCus: Curve[])  {    let source: Polyline | Circle = (sourceCurs[0] instanceof Circle) ? sourceCurs[0] as Circle : new Polyline().Combine(sourceCurs)[0];    let target: Polyline | Circle = (targetCus[0] instanceof Circle) ? targetCus[0] as Circle : new Polyline().Combine(targetCus)[0];    try    {      if (!source.IsClose || !target.IsClose) throw new Error("不是封閉曲線");    }    catch (err)    {      console.log(err);    }    let interPts = source.IntersectWith(target, IntersectOption.OnBothOperands);    let sourceContainerTarget = isTargetCurInSourceCur(source, target);    let targetContainerSource = isTargetCurInSourceCur(target, source);    let isContainer = sourceContainerTarget || targetContainerSource;    let intersectionList: Curve[] = []; //交集    let unionList: Curve[] = []; //并集    let subList: Curve[] = []; //補集    /*    *兩封閉區域有交點并且不是包含關系,則通過交點把區域分割    */    if (interPts.length && !isContainer)    {      let pars1 = interPts.map(p => source.GetParamAtPoint(p)).sort((a, b) => a - b);      let pars2 = interPts.map(p => target.GetParamAtPoint(p)).sort((a, b) => a - b);      let cus1: Array<Polyline | Arc> = source.GetSplitCurves(pars1);      cus1.forEach(pl =>      {        if (isTargetCurInSourceCur(target, pl))        {          intersectionList.push(pl);        }        else        {          subList.push(pl);          unionList.push(pl);        }      })      let cus2: Array<Polyline | Arc> = target.GetSplitCurves(pars2);      cus2.forEach(pl =>      {        if (isTargetCurInSourceCur(source, pl))        {          intersectionList.push(pl);          subList.push(pl);        }        else        {          unionList.push(pl);        }      })    }    else    {      if (isContainer)      {        if (sourceContainerTarget)        {          intersectionList.push(target);          subList.push(source, target);          unionList.push(source);        }        else        {          unionList.push(target);          intersectionList.push(source);        }      }      else      {        unionList.push(source, target)        subList.push(source);      }    }    return {      intersectionList, unionList, subList    }  }

由于一些曲線類實現方法不一,這里主要說一些實現布爾運算的思路

  1. 判斷2封閉曲線是否是被包含的關系
  2. 獲取2封閉曲線的所有交點,這里交點可能是圓和線,線和線,圓和圓的,求交點的方法網上應該很多,以后有時間也會寫寫用JavaScript實現方式
  3. 根據所有的交點把2封閉曲線分割為多個部分
  4. 對分割后的線段進行整理,其中相交部分是曲線在對方曲線內部的部分,合并是互不在對方曲線內部的部分,相減類似不想說了,具體看代碼,如果是被包含狀態則更加就簡單了

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乌拉特后旗| 西宁市| 邻水| 洛扎县| 五寨县| 泸水县| 新绛县| 阜康市| 阿拉善盟| 桃源县| 博乐市| 佛教| 阳高县| 慈溪市| 桂阳县| 娄底市| 舞阳县| 卢氏县| 涡阳县| 揭阳市| 漳平市| 临汾市| 通海县| 中山市| 方山县| 兴业县| 报价| 金坛市| 民乐县| 东乡县| 玛沁县| 富裕县| 嘉禾县| 达州市| 昂仁县| 东乌珠穆沁旗| 江西省| 桃园市| 加查县| 镇平县| 汾阳市|