您的位置:首页 > 新闻动态 > 技术文章

CATIA插件二次开发C#

来源: 2018/6/22      点击:

1. 引言

由于项目中要使用WISEGLOVE数据手套,近搜集整理了一些关于CATIA二次开发的资料,网络的相关资料比较有限,因此刚开始遇到了不少问题,通过分析一些示例,以及结合CATIA的宏录制功能生成的代码,才算是对CATIA的开发方式有所了解。现总结一下学习中遇到的相关问题及解决办法,以共享各位小朋友。

2. CATIA简介

CATIA(Computer Aided Three Dimensional Interactive Application)是法国达索公司的产品开发旗舰解决方案。作为PLM协同解决方案的一个重要组成部分,它可以帮助制造厂商设计他们未来的产品,并支持从项目前阶段、具体的设计、分析、模拟、组装到维护在内的全部工业设计流程。通过使企业能够重用产品设计知识,缩短开发周期,CATIA解决方案加快企业对市场的需求的反应。CATIA比较广泛的用于汽车、航空航天、轮船、军工、仪器仪表、建筑工程、电气管道、通信等方方面面(来源-百度百科-CATIA)。

3. CATIA开发模式

CATIA提供了AutomationAPI组件和组件应用架构(CAA,Component Application Architecture)两种开发模式。

3.1 Automation组件

Automation API具备与任何OLE所兼容的平台进行通讯能力,自动化(Automation)组件使用VBScript作为编辑工具。通过宏录制功能(Macro Record),可以记录用户的操作过程并自动生成VBScript代码。这种方式比较简单,在CATIA环境就中可完成。

3.2 组件应用架构(CAA)

CAA采用组件对象模型(COM)和对象的连接和嵌入(OLE)技术,COM作为一种软件架构具备了更好的模块独立性、可扩展性,使CAA的程序设计更加容易且趋于标准化,使程序的代码更加简洁明了。在CATIA运行的情况下,外部进程可以通过访问COM组件实现对CATIA的操作,如创建、修改CATIA环境和几何形体的数据、尺寸等。

4. 为什么采用C#作为开发语言

VBScript脚本方法过于简单,无法实现CATIA的某些功能,如碰撞检测功能,且无法与现有项目进行集成。CAA/C++模式是*复杂的开发模式,其可以实现几乎所有的CATIA功能,但是其过于复杂,需要一定的学习时间,无法很快进行功能实现。因此这两种实现方式都不是很适合。由于CATIA提供了COM支持,因此我们可以通过.Net平台引入COM组件进行开发,其有如下优势: 
1. 由于项目本身采用的是CSharp语言,因此能够很好的集成到项目中,并且能够满足项目需求。 
2. 学习成本较低,通过对宏生成代码进行少许改造即可在.Net平台中运行。 
3. 可以将通用操作进行封装,方便今后项目的开发,降低开发成本。

5. 准备开发

5.1 所需软件

  • CATIA V5 R20
  • Visual Studio 2010

5.2 引入类库

在正确安装CATIA之后即可在项目中引用CATIA COM类库,其类库名称均以CATIA V5开头。在引用为类库后,我们即可进行开发工作。 


5.3 开发示例

该示例演示了如何连接CATIA,并生成一个新的Product。

namespace CATIATest
{
    class Program
    {
        static void Main(string[] args)
        {
            // 连接CATIA
            Application Catia =(Application)System.Runtime.InteropServices.Marshal.GetActiveObject("Catia.Application");
            // 获取当前活动ProductDocument
            ProductDocument pd = (ProductDocument)Catia.ActiveDocument;
            // 创建一个ID为newProduct的Product
            pd.Product.Products.AddNewProduct("newProduct");
        }
    }
}

【注意】在调试之前请确保CATIA已经运行,否则无法连接到CATIA,程序无法运行。

6. 开发中使用到的操作总结

6.1 加载CATIA文件

public void AddNewComponent(string filePath)
{
    object[] files = new object[1] { filePath };
    this.ActiveProductDocument.Product.Products.AddComponentsFromFiles(files, "All");
}

6.2 向当前Product中添加Part

// 向当前Product中添加一个指定长度的圆柱体
public void CreateCylinder(string name, double length)
{
    // 添加一个新零件
    Product product = this.ActiveProductDocument.Product.Products.AddNewComponent("Part", name);
    // 绘制圆
    Part part = ((PartDocument)this._catia.Documents.Item(name + ".CATPart")).Part;
    Sketch sketch = (part.Bodies.GetItem("零件几何体") as Body).Sketches.Add(
        (Reference)part.OriginElements.PlaneXY);
    sketch.SetAbsoluteAxisData(new object[] { 0, 0, 0, 1, 0, 0, 0, 1, 0 });
    part.InWorkObject = sketch;
    Factory2D factory = sketch.OpenEdition();
    Axis2D axis = (Axis2D)sketch.GeometricElements.GetItem("绝对轴");
    (axis.GetItem("横向") as Line2D).ReportName = 1;
    (axis.GetItem("纵向") as Line2D).ReportName = 2;
    Circle2D circle = factory.CreateClosedCircle(0, 0, 5);
    circle.CenterPoint = (Point2D)axis.GetItem("原点");
    circle.ReportName = 3;
    sketch.CloseEdition();
    part.Update();
    // 绘制圆柱
    (part.ShapeFactory as ShapeFactory).AddNewPad(sketch, length);
    part.Update();
}

6.3 查找Product

// 根据产品名称获取指定Product
public Product GetProduct(string productId)
{
    return (Product)this.ActiveProductDocument.Product.Products.GetItem(productId);
}

6.4 移除Product

protected void RemoveProduct(Product product)
{
    Selection selection = this.ActiveProductDocument.Selection;
    selection.Clear();
    selection.Add(product);
    selection.Delete();
}

6.5 碰撞检测

// 检测两个产品间是否存在冲突
public bool ConflictCheck(Product product1, Product product2)
{
    Groups groups = this.ActiveProductDocument.Product.GetTechnologicalObject("Groups") as Groups;
    Group first = groups.Add();
    Group second = groups.Add();
    first.AddExplicit(product1);
    second.AddExplicit(product2);
    Clash clash = (this.ActiveProductDocument.Product.GetTechnologicalObject("Clashes") as Clashes).Add();
    clash.ComputationType = CatClashComputationType.catClashComputationTypeBetweenTwo;
    clash.InterferenceType = CatClashInterferenceType.catClashInterferenceTypeContact;
    clash.FirstGroup = first;
    clash.SecondGroup = second;
    clash.Compute();
    Conflicts conflicts = clash.Conflicts;
    groups.Remove(first.get_Name());
    groups.Remove(second.get_Name());
    return conflicts.Count != 0;
}

6.6 自动调整视图

protected void AdapteAllView()
{
    this._catia.ActiveWindow.ActiveViewer.Reframe();
}

7. 其他功能探索

一般来说,对于CATIA中能够手工解决的问题均应能够通过编程的方式处理,我们可以通过以下三种途径获取编程帮助以及Sample。

  1. V5 Automation API 手册(推荐)
  2. CATIA 宏录制功能
  3. Baidu 以及 Google

方式一:在安装好CATIA后,再其安装目录中%Install Root%\Dassault Systemes\B20\intel_a\code\bin中已经包含了V5 Automation API .chm帮助文档。该文档中包含了全部的可用API及类继承结构,同时提供了丰富的代码示例供读者参考。 

方式二:通过启用CATIA的宏录制功能,可以获得所有操作的VBScript代码,我们可以参考该代码进行CSharp代码的开发。下图通过CATIA录制了一个绘制圆柱的过程,右侧窗口内显示的即为生成的VBScript代码。 

8. WISEGLOVE数据手套在CATIA中使用

按照上面的方法, 各位小朋友应该能和我们一样实现WISEGLOVE数据手套在CATIA中的应用。