青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

eryar

PipeCAD - Plant Piping Design Software.
PlantAssistant - Translate AVEVA RVM/SP3D VUE to glTF, STEP, etc.
posts - 606, comments - 590, trackbacks - 0, articles - 0

OpenCASCADE中散亂Edge生成Wire

Posted on 2018-05-20 21:50 eryar 閱讀(2254) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

OpenCASCADE中散亂Edge生成Wire

eryar@163.com

Abstract. In OpenCASCADE a wire can be built from any number of edges in sequence. If edges are not in sequence, you must sort them in order.

Key Words. Edge, Wire, Wire order

1. Introduction

在OpenCASCADE中生成WIRE時要求添加到WIRE中的邊EDGE是有順序要求的。當給定的邊沒有按順序添加到WIRE之前,需要自己將EDGE按順序處理。OpenCASCADE中也提供了對EDGE按順序進行排序的功能,方便WIRE的生成。

本文給出將散亂的EDGE排序后生成WIRE的實現代碼,這個功能用處還是很大的。

2. Code 

在模型檢查模塊TKShHealing中,OpenCASCADE提供了類ShapeAnalysis_WireOrder用來將用于生成WIRE的一系列EDGE進行排序。這個類的實現原理是根據EDGE的起點、終點坐標來進行連接,生成順序。

如下圖所示為一個封閉的WIRE,根據這些尺寸標注,生成WIRE的EDGE。

wps_clip_image-18201

實現上述Wire的程序代碼如下所示:

/*
The MIT License (MIT)
---------------------
Copyright(C) 2018 Shing Liu(eryar@163.com)
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files(the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and / or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions :
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/
#include <vector>
#include <gp_Pnt.hxx>
#include <gp_Circ.hxx>
#include <TopTools_ListOfShape.hxx>
#include <BRep_Tool.hxx>
#include <BRepTools.hxx>
#include <BRepBuilderAPI_MakeEdge.hxx>
#include <BRepBuilderAPI_MakeWire.hxx>
#include <ShapeAnalysis_Edge.hxx>
#include <ShapeAnalysis_WireOrder.hxx>
#pragma comment(lib, "TKernel.lib")
#pragma comment(lib, "TKMath.lib")
#pragma comment(lib, "TKG2d.lib")
#pragma comment(lib, "TKG3d.lib")
#pragma comment(lib, "TKGeomBase.lib")
#pragma comment(lib, "TKGeomAlgo.lib")
#pragma comment(lib, "TKBRep.lib")
#pragma comment(lib, "TKTopAlgo.lib")
#pragma comment(lib, "TKShHealing.lib")
void test(void)
{
    std::vector<TopoDS_Edge> anEdges;
    // 5 Segment edges.
    BRepBuilderAPI_MakeEdge anEdgeMaker1(
        gp_Pnt(-1650.0, 2857.88383249, 0.0),
        gp_Pnt(-750.0, 1299.03810568, 0.0));
    BRepBuilderAPI_MakeEdge anEdgeMaker2(
        gp_Pnt(1299.03810568, 750.0, 0.0),
        gp_Pnt(2857.88383249, 1650.0, 0.0));
    BRepBuilderAPI_MakeEdge anEdgeMaker3(
        gp_Pnt(2857.88383249, 1650.0, 0.0),
        gp_Pnt(8000.0, 1650.0, 0.0));
    BRepBuilderAPI_MakeEdge anEdgeMaker4(
        gp_Pnt(8000.0, 1650.0, 0.0),
        gp_Pnt(8000.0, -3300.0, 0.0));
    BRepBuilderAPI_MakeEdge anEdgeMaker5(
        gp_Pnt(8000.0, -3300.0, 0.0),
        gp_Pnt(0.0, -3300.0, 0.0));
    anEdges.push_back(anEdgeMaker1.Edge());
    anEdges.push_back(anEdgeMaker2.Edge());
    anEdges.push_back(anEdgeMaker3.Edge());
    anEdges.push_back(anEdgeMaker4.Edge());
    anEdges.push_back(anEdgeMaker5.Edge());
    // 2 Arc edges.
    gp_Circ aCircle1(gp::XOY(), 1500.0);
    gp_Circ aCircle2(gp::XOY(), 3300.0);
    BRepBuilderAPI_MakeEdge anEdgeMaker6(aCircle1,
        gp_Pnt(-750.0, 1299.03810568, 0.0),
        gp_Pnt(1299.03810568, 750.0, 0.0));
    BRepBuilderAPI_MakeEdge anEdgeMaker7(aCircle2,
        gp_Pnt(-1650.0, 2857.88383249, 0.0),
        gp_Pnt(0.0, -3300.0, 0.0));
    anEdges.push_back(anEdgeMaker6.Edge());
    anEdges.push_back(anEdgeMaker7.Edge());
    // Get edges order for the wire.
    ShapeAnalysis_Edge anEdgeAnalyser;
    ShapeAnalysis_WireOrder aWireOrder;
    for (std::vector<TopoDS_Edge>::const_iterator i = anEdges.begin();
        i != anEdges.end(); ++i)
    {
        TopoDS_Vertex aVf = anEdgeAnalyser.FirstVertex(*i);
        TopoDS_Vertex aVl = anEdgeAnalyser.LastVertex(*i);
        gp_Pnt aPf = BRep_Tool::Pnt(aVf);
        gp_Pnt aPl = BRep_Tool::Pnt(aVl);
        aWireOrder.Add(aPf.XYZ(), aPl.XYZ());
    }
    // 
    TopTools_ListOfShape aOrderedEdges;
    for (Standard_Integer e = 1; e <= aWireOrder.NbEdges(); ++e)
    {
        const TopoDS_Edge& anEdge = anEdges.at(e - 1);
        aOrderedEdges.Append(anEdge);
    }
    BRepBuilderAPI_MakeWire aWireMaker;
    aWireMaker.Add(aOrderedEdges);
    if (aWireMaker.IsDone())
    {
        BRepTools::Write(aWireMaker.Shape(), "d:/wire.brep");
    }
}
int main(int argc, char* argv[])
{
    test();
    return 0;
}

程序先添加5條線段到EDGE數組,再添加兩個圓弧到EDGE數組。再使用類ShapeAnalysis_WireOrder來對EDGE數組進行排序,將排序后的EDGE數組去生成WIRE。如果生成WIRE成功,會在D盤得到一個wire.brep文件。在Draw中加載后顯示如下圖所示:

wps_clip_image-1190

生成WIRE后,繼而可以生成FACE,對FACE進行拉伸可以得到拉伸體,如下圖所示:

wps_clip_image-9137

3. Conclusion

OpenCASCADE中生成WIRE時對添加的EDGE是有順序的要求。如何對散亂的EDGE進行排序以達到生成WIRE的要求呢?OpenCASCADE在TKShHealing模塊中提供了對EDGE排序的功能。

對EDGE排序的功能原理很簡單,就是將所有的EDGE首尾相連,感興趣的讀者可以結合源碼學習下。



為了方便大家在移動端也能看到我的博文和討論交流,現已注冊微信公眾號,歡迎大家掃描下方二維碼關注。
Shing Liu(eryar@163.com)

 

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久全国免费视频| 欧美国产视频一区二区| 国产视频亚洲精品| 欧美自拍丝袜亚洲| 久久se精品一区精品二区| 国产一区欧美| 欧美aaa级| 欧美日韩亚洲不卡| 午夜国产精品影院在线观看| 欧美一区二区免费视频| 一色屋精品视频在线观看网站| 免费欧美视频| 欧美日本免费一区二区三区| 亚洲欧美日韩国产中文在线| 久久成人羞羞网站| 亚洲精品影院| 亚洲综合视频网| 1769国产精品| 中国成人亚色综合网站| 国产一区二区精品久久91| 男女精品网站| 国产精品都在这里| 蜜桃av综合| 欧美视频三区在线播放| 久久青草久久| 欧美色精品在线视频| 久久久午夜视频| 欧美日韩国产高清| 久久亚洲不卡| 国产精品久久久一本精品| 欧美凹凸一区二区三区视频| 国产精品草草| 亚洲国产精品传媒在线观看| 欧美午夜精品久久久久久浪潮| 久久婷婷人人澡人人喊人人爽| 欧美精品九九| 美女脱光内衣内裤视频久久网站| 欧美日韩免费在线| 欧美国产精品va在线观看| 国产精品一二| 亚洲欧洲午夜| 在线观看日韩av电影| 亚洲一区二区三区精品视频| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美亚洲免费在线| 亚洲——在线| 欧美精品尤物在线| 亚洲福利专区| 亚洲第一视频网站| 久久国产精品一区二区三区| 午夜精品久久久久久99热| 欧美大片免费观看| 欧美不卡视频| 精品成人一区二区三区| 羞羞漫画18久久大片| 亚洲女人天堂av| 欧美日韩综合一区| 亚洲日本一区二区| av成人免费观看| 欧美久久电影| 亚洲精品久久久久| aa亚洲婷婷| 欧美精品激情blacked18| 亚洲国产1区| 亚洲伦理自拍| 欧美精品一区在线发布| 亚洲日本免费| 亚洲午夜av| 国产精品久久午夜| 亚洲女人小视频在线观看| 欧美一区2区三区4区公司二百| 国产精品成人免费| 亚洲欧美激情四射在线日 | 欧美日韩国产综合视频在线| 欧美黄色日本| 亚洲精品一区二区三区99| 欧美激情成人在线| 一区二区激情| 久久国产精品一区二区| 国内成+人亚洲+欧美+综合在线| 先锋影音国产精品| 久久综合久久美利坚合众国| 精品999网站| 牛人盗摄一区二区三区视频| 亚洲精品视频一区二区三区| 亚洲男人第一网站| 国产综合久久久久影院| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲日本va午夜在线影院| 亚洲一区二区三区涩| 国产在线麻豆精品观看| 免费观看在线综合| 一区二区三区产品免费精品久久75 | 国产精品第三页| 久久成人精品电影| 亚洲日本理论电影| 欧美在线视频在线播放完整版免费观看| 国产一区二区三区视频在线观看| 久久久国产精品一区二区中文| 欧美激情一区二区久久久| 亚洲综合精品| 亚洲国产成人91精品| 国产精品久久91| 麻豆国产精品va在线观看不卡 | 欧美一级片一区| 亚洲第一福利视频| 国产精品av免费在线观看| 久久天天躁狠狠躁夜夜av| 中文国产成人精品| 欧美激情中文不卡| 欧美中文字幕在线观看| 日韩视频一区二区三区| 国内精品久久久久久影视8| 欧美人与禽性xxxxx杂性| 欧美影片第一页| 99成人免费视频| 欧美国产免费| 久久夜色精品国产欧美乱| 亚洲欧美国产高清| 亚洲日本国产| 一区精品久久| 国产亚洲福利| 国产精品久久久久久久久婷婷| 欧美成人精品1314www| 久久超碰97人人做人人爱| 亚洲一区二区三区国产| 日韩特黄影片| 91久久极品少妇xxxxⅹ软件| 久久国产88| 亚洲欧美中日韩| 亚洲图片欧洲图片av| 亚洲毛片av| 亚洲精品一区二区三区av| 亚洲国产精品va在看黑人| 国产亚洲一区在线| 国产欧美日韩麻豆91| 国产精品久久久久久模特| 欧美日韩一二三四五区| 欧美激情片在线观看| 久久免费精品日本久久中文字幕| 香蕉久久精品日日躁夜夜躁| 亚洲免费综合| 欧美亚洲综合在线| 欧美一区二区福利在线| 欧美一区午夜精品| 亚洲欧美电影在线观看| 亚洲男女自偷自拍| 欧美一二三区精品| 久久国产福利| 久久综合九色欧美综合狠狠| 久久综合色播五月| 美女视频网站黄色亚洲| 欧美成人免费全部观看天天性色| 欧美国产日本韩| 欧美日韩免费观看一区二区三区| 欧美日韩直播| 国产欧美一区二区三区在线看蜜臀| 国产欧美一二三区| 红桃视频一区| 亚洲每日更新| 午夜精品免费在线| 久久久伊人欧美| 欧美成年人视频网站| 亚洲精品国产精品国自产观看| 亚洲理伦电影| 午夜精品在线| 久久综合久色欧美综合狠狠 | 欧美fxxxxxx另类| 欧美美女bb生活片| 国产女人aaa级久久久级| 经典三级久久| 在线亚洲观看| 久久精品国产2020观看福利| 免费久久99精品国产自| 亚洲精品日韩在线| 午夜精品福利一区二区蜜股av| 久久久最新网址| 欧美午夜电影一区| 精品成人一区二区| 亚洲一级一区| 美女在线一区二区| 一区二区三区黄色| 久久久久久香蕉网| 美女视频黄 久久| 亚洲欧洲精品成人久久奇米网| 亚洲第一区在线观看| 宅男66日本亚洲欧美视频| 久久精品一区二区三区四区| 欧美日韩成人一区| 一区二区三区中文在线观看 | 欧美三级中文字幕在线观看| 狠狠色噜噜狠狠狠狠色吗综合| 9色国产精品| 毛片基地黄久久久久久天堂 | 久久九九久精品国产免费直播| 亚洲福利av| 久久久久久久综合| 国产欧美精品日韩| 一区二区三区不卡视频在线观看| 久久午夜激情|