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

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:33:09
字體:
來源:轉載
供稿:網友

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

先上代碼

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    }  }

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

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

圖片精選

主站蜘蛛池模板: 庆安县| 措勤县| 兴文县| 大庆市| 尖扎县| 西畴县| 酉阳| 宣城市| 丽水市| 阳信县| 宜都市| 彝良县| 三亚市| 平远县| 龙陵县| 惠安县| 永新县| 榆树市| 兴隆县| 萨迦县| 睢宁县| 长岛县| 敦煌市| 霞浦县| 河南省| 永城市| 阿坝县| 新平| 五寨县| 高要市| 濮阳市| 衡南县| 墨脱县| 青川县| 浦城县| 孟连| 长海县| 澄江县| 称多县| 和政县| 芜湖县|