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

            eryar

            PipeCAD - Plant Piping Design Software.
            RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
            posts - 603, comments - 590, trackbacks - 0, articles - 0

            OpenCASCADE中散亂Edge生成Wire

            Posted on 2018-05-20 21:50 eryar 閱讀(2219) 評論(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)

             

            久久er热视频在这里精品| 久久av高潮av无码av喷吹| 久久久精品免费国产四虎| 欧洲精品久久久av无码电影| 狠狠色婷婷久久综合频道日韩| 99久久香蕉国产线看观香| 蜜臀久久99精品久久久久久小说 | 97久久天天综合色天天综合色hd| 中文字幕热久久久久久久| 国产精品对白刺激久久久| 久久精品无码一区二区三区日韩| 亚洲日本久久久午夜精品| 国产精品一区二区久久不卡| 99热热久久这里只有精品68| 久久久噜噜噜久久中文字幕色伊伊| 狠狠88综合久久久久综合网| 欧美久久综合九色综合| 久久香蕉超碰97国产精品 | 国产精品久久久久蜜芽| 久久人妻AV中文字幕| 国产精品视频久久久| 久久亚洲AV无码精品色午夜| 精品久久久无码人妻中文字幕豆芽| 青春久久| 国产精品美女久久久久AV福利| 一本一道久久综合狠狠老| 久久精品成人欧美大片| 久久青青草原综合伊人| 看久久久久久a级毛片| 久久午夜免费视频| 日本精品久久久久久久久免费| 天天久久狠狠色综合| 97久久久精品综合88久久| 亚洲精品乱码久久久久久蜜桃不卡| 午夜精品久久久久久影视777| 香港aa三级久久三级| 青青国产成人久久91网| 青青草原1769久久免费播放| 青青草国产成人久久91网| 国产福利电影一区二区三区久久久久成人精品综合 | 人妻久久久一区二区三区|