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

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 閱讀(2238) 評論(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是有順序要求的。當(dāng)給定的邊沒有按順序添加到WIRE之前,需要自己將EDGE按順序處理。OpenCASCADE中也提供了對EDGE按順序進行排序的功能,方便WIRE的生成。

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

2. Code 

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

如下圖所示為一個封閉的WIRE,根據(jù)這些尺寸標(biāo)注,生成WIRE的EDGE。

wps_clip_image-18201

實現(xiàn)上述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數(shù)組,再添加兩個圓弧到EDGE數(shù)組。再使用類ShapeAnalysis_WireOrder來對EDGE數(shù)組進行排序,將排序后的EDGE數(shù)組去生成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首尾相連,感興趣的讀者可以結(jié)合源碼學(xué)習(xí)下。



為了方便大家在移動端也能看到我的博文和討論交流,現(xiàn)已注冊微信公眾號,歡迎大家掃描下方二維碼關(guān)注。
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>
            久久大香伊蕉在人线观看热2| 亚洲国产综合在线| 国产日韩欧美不卡在线| 欧美理论电影在线观看| 久久美女性网| 另类图片国产| 快播亚洲色图| 亚洲经典视频在线观看| 亚洲日本中文| 亚洲精选国产| 中文亚洲欧美| 校园激情久久| 久久在线视频在线| 欧美日韩免费观看一区二区三区| 欧美日本精品| 国产日韩精品一区二区三区在线| 国产一区二区三区精品欧美日韩一区二区三区| 国产欧美日韩精品丝袜高跟鞋 | 亚洲国产精品va在线观看黑人| 久久久久久久91| 欧美黄色成人网| 99精品99久久久久久宅男| 亚洲一区二区三区免费观看| 久久精品国产99| 欧美激情第二页| 国产精品人人做人人爽| 在线日韩av片| 亚洲一区二区毛片| 老色批av在线精品| 一区二区三区精密机械公司| 久久精品免费电影| 欧美视频在线观看| 在线看日韩av| 午夜一区不卡| 欧美国产亚洲另类动漫| 亚洲一区二区三区在线观看视频| 老鸭窝毛片一区二区三区| 欧美天堂亚洲电影院在线播放| 黑人巨大精品欧美一区二区小视频 | 国内伊人久久久久久网站视频 | 亚洲婷婷综合久久一本伊一区| 一区二区三区高清| 久久久久久久综合| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美日韩午夜剧场| 在线观看日韩av先锋影音电影院| 亚洲主播在线观看| 亚洲国产日本| 另类图片国产| 黄色一区三区| 性伦欧美刺激片在线观看| 亚洲乱码精品一二三四区日韩在线| 久久av一区二区三区| 国产精品推荐精品| 在线亚洲激情| 亚洲黄色毛片| 狼人社综合社区| 狠久久av成人天堂| 久久久av网站| 欧美一区二区| 国产小视频国产精品| 香蕉免费一区二区三区在线观看| 亚洲欧洲偷拍精品| 欧美精品高清视频| 亚洲风情在线资源站| 老**午夜毛片一区二区三区| 久久久久中文| 亚洲国产日韩欧美| 欧美激情中文不卡| 牛牛影视久久网| 日韩亚洲欧美精品| 日韩一区二区电影网| 欧美日韩免费高清一区色橹橹| 9l视频自拍蝌蚪9l视频成人| 亚洲精品久久7777| 欧美日韩国语| 欧美在线地址| 久久精品视频免费播放| 亚洲欧洲一区二区在线观看| 亚洲黄网站在线观看| 欧美日韩在线一二三| 欧美一区二区三区播放老司机| 在线综合视频| 激情小说亚洲一区| 欧美高清在线| 欧美三级视频在线| 久久精品1区| 久久综合狠狠综合久久综青草| 亚洲黄色av一区| 夜夜嗨av一区二区三区免费区| 国产女人aaa级久久久级| 久久精品国产清高在天天线| 久久久久久一区二区| 亚洲网站视频| 亚洲精品日韩激情在线电影| 中文亚洲字幕| 国产伊人精品| 亚洲高清网站| 国产伦精品一区二区三区免费| 久久久精品一品道一区| 免费在线看一区| 欧美一区免费视频| 玖玖综合伊人| 欧美在线视频一区| 蜜臀av性久久久久蜜臀aⅴ| 亚洲一区免费视频| 久久视频国产精品免费视频在线| 99精品国产在热久久| 久久国产精品久久久久久电车| 亚洲精品资源美女情侣酒店| 欧美一区二区在线看| 一本久久a久久免费精品不卡| 销魂美女一区二区三区视频在线| 亚洲精品久久久久久久久久久久久 | 亚洲欧洲三级电影| 国产视频久久久久久久| 亚洲精品孕妇| 亚洲高清资源| 久久国产精品99国产| 亚洲欧美精品| 欧美日韩精选| 欧美高清视频一区二区| 黑人一区二区| 欧美一区二区三区四区视频| 亚洲视频在线一区观看| 欧美大片网址| 麻豆精品视频在线观看| 国产日韩精品入口| 一本一本a久久| 亚洲视频在线一区| 欧美日韩亚洲综合一区| 亚洲第一在线视频| 亚洲欧洲一区二区三区| 久久久久久免费| 美女主播一区| 黄色av成人| 美日韩精品免费| 黄色av一区| 欧美在线亚洲在线| 久久精品国产2020观看福利| 国产精品色婷婷| 亚洲女性裸体视频| 亚洲女同在线| 国产精品香蕉在线观看| 午夜精品久久久久| 久久国产精品72免费观看| 国产欧美日韩一区二区三区在线 | 久久午夜电影| 亚洲国产激情| 在线视频一区二区| 国产精品久久影院| 亚洲欧美一区二区精品久久久| 欧美一区二区三区在线观看视频| 国产日韩欧美不卡在线| 久久激情网站| 亚洲电影免费观看高清完整版在线 | 久久久久久久久久久成人| 久久夜色精品国产噜噜av| 国产一区二区精品久久| 欧美电影免费观看| 99亚洲一区二区| 欧美视频一区二区| 欧美一区二区黄| 欧美激情一区二区三区高清视频| 亚洲精品国精品久久99热| 欧美区一区二区三区| 亚洲手机成人高清视频| 久久综合九色欧美综合狠狠| 在线看欧美视频| 国产精品国产| 久久久999国产| 最新国产乱人伦偷精品免费网站| 中文精品一区二区三区| 国产欧美日韩视频| 欧美成人一二三| 亚洲欧美在线视频观看| 亚洲国产精品日韩| 午夜久久久久| 亚洲丰满在线| 国产精品视频内| 男女av一区三区二区色多| 亚洲在线视频观看| 欧美国产一区二区三区激情无套| 亚洲免费一在线| 亚洲大片在线| 国产区亚洲区欧美区| 欧美激情网友自拍| 亚洲欧美欧美一区二区三区| 亚洲欧洲精品一区二区三区不卡| 性欧美1819性猛交| 一本色道综合亚洲| 影音先锋久久久| 国产三级精品三级| 欧美日韩一区二区三区在线观看免| 久久精视频免费在线久久完整在线看 | 老司机久久99久久精品播放免费| 亚洲少妇一区| 亚洲激情校园春色| 久久性色av| 久久久欧美精品|