CATIA Automation 编程初探

本文介绍了如何使用C++通过IDispatch接口、CATIA自带的TLB转化以及CAA来实现CATIA的自动化开发,以画圆为例详细展示了开发过程,并提供了相关代码实例。

最近开始对 CATIA 进行一些自动化的开发,本来想找 CAA 来进行研究,可惜一直没时间和机会去找,暂时就利用 CATIA Automation 来开发了。

由于利用 VB 或 VB.NET 将CATIA 脚本转化为程序确实方便,不过利用C++来操作更适合于我这种开发者。

方法有好多种,这里以画圆作为一个简单例子。

1 利用 IDispatch 接口来编程

  1. HRESULThr;
  2. CLSIDAppClsid;
  3. IDispatch*pApp;
  4. ::CoInitialize(NULL);
  5. //
  6. ::CLSIDFromProgID(L"CATIA.Application",&AppClsid);//gettheuniqueidofCATIA
  7. //
  8. hr=CoCreateInstance(AppClsid,NULL,CLSCTX_LOCAL_SERVER,IID_IDispatch,(void**)&pApp);
  9. VARIANTresult,buffer;
  10. VariantInit(&result);
  11. VARIANTarg2;
  12. VariantInit(&arg2);
  13. arg2.vt=VT_BOOL;
  14. arg2.boolVal=TRUE;
  15. hr=AutoWrap(DISPATCH_PROPERTYPUT|DISPATCH_METHOD,&result,pApp,L"Visible",1,arg2);
  16. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,pApp,L"Documents",0);//herethereisnoargument,soweput0
  17. buffer.vt=VT_DISPATCH;
  18. buffer.pdispVal=result.pdispVal;
  19. IDispatch*documents=buffer.pdispVal;
  20. VARIANTarg1;
  21. VariantInit(&arg1);
  22. arg1.vt=VT_BSTR;
  23. arg1.bstrVal=::SysAllocString(L"Part");
  24. //VARIANTresult,buffer;
  25. VariantInit(&result);
  26. hr=AutoWrap(DISPATCH_METHOD,&result,documents,L"Add",1,arg1);
  27. buffer.vt=VT_DISPATCH;
  28. buffer.pdispVal=result.pdispVal;
  29. IDispatch*partDocument=buffer.pdispVal;
  30. //
  31. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,partDocument,L"Part",0);
  32. buffer.vt=VT_DISPATCH;
  33. buffer.pdispVal=result.pdispVal;
  34. IDispatch*part=buffer.pdispVal;
  35. //
  36. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,part,L"Bodies",0);
  37. buffer.vt=VT_DISPATCH;
  38. buffer.pdispVal=result.pdispVal;
  39. IDispatch*bodies=buffer.pdispVal;
  40. //
  41. VARIANTarg;
  42. VariantInit(&arg);
  43. arg.vt=VT_BSTR;
  44. arg.bstrVal=::SysAllocString(L"PartBody");
  45. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,bodies,L"Item",1,arg);
  46. buffer.vt=VT_DISPATCH;
  47. buffer.pdispVal=result.pdispVal;
  48. IDispatch*body=buffer.pdispVal;
  49. //
  50. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,body,L"Sketches",0);
  51. buffer.vt=VT_DISPATCH;
  52. buffer.pdispVal=result.pdispVal;
  53. IDispatch*sketches1=buffer.pdispVal;
  54. //
  55. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,part,L"OriginElements",0);
  56. buffer.vt=VT_DISPATCH;
  57. buffer.pdispVal=result.pdispVal;
  58. IDispatch*originElements=buffer.pdispVal;
  59. //
  60. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,originElements,L"PlaneXY",0);
  61. buffer.vt=VT_DISPATCH;
  62. buffer.pdispVal=result.pdispVal;
  63. IDispatch*reference1=buffer.pdispVal;
  64. //
  65. VARIANTarg3;
  66. VariantInit(&arg3);
  67. arg3.vt=VT_DISPATCH;
  68. arg3.pdispVal=reference1;
  69. hr=AutoWrap(DISPATCH_METHOD,&result,sketches1,L"Add",1,arg3);
  70. buffer.vt=VT_DISPATCH;
  71. buffer.pdispVal=result.pdispVal;
  72. IDispatch*sketch1=buffer.pdispVal;
  73. ////
  74. //SAFEARRAY*psa;
  75. //SAFEARRAYBOUNDrgsabound[1];
  76. //rgsabound[0].lLbound=0;
  77. //rgsabound[0].cElements=9;
  78. //psa=SafeArrayCreate(VT_VARIANT,1,rgsabound);
  79. //
  80. //hr=SafeArrayAccessData(psa);
  81. //hr=SafeArrayUnaccessData(psa);
  82. //VARIANTarray;
  83. //VariantInit(&array);
  84. //array.vt=VT_ARRAY;
  85. //array.pparray=&psa;
  86. //
  87. //hr=AutoWrap(DISPATCH_METHOD,&result,sketch1,L"SetAbsoluteAxisData",1,array);
  88. VARIANTarg4;
  89. VariantInit(&arg4);
  90. arg4.vt=VT_DISPATCH;
  91. arg4.pdispVal=sketch1;
  92. hr=AutoWrap(DISPATCH_PROPERTYPUT|DISPATCH_METHOD,&result,part,L"InWorkObject",1,arg4);
  93. //buffer.vt=VT_DISPATCH;
  94. //buffer.pdispVal=result.pdispVal;
  95. //IDispatch*sketch1=buffer.pdispVal;
  96. //
  97. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,sketch1,L"OpenEdition",0);
  98. buffer.vt=VT_DISPATCH;
  99. buffer.pdispVal=result.pdispVal;
  100. IDispatch*factory2D1=buffer.pdispVal;
  101. //
  102. VARIANTa1,a2,a3;
  103. VariantInit(&a1);
  104. VariantInit(&a2);
  105. VariantInit(&a3);
  106. a1.vt=VT_R4;a1.fltVal=50.f;
  107. a2.vt=VT_R4;a2.fltVal=0.f;
  108. a3.vt=VT_R4;a3.fltVal=0.f;
  109. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,factory2D1,L"CreateClosedCircle",3,a1,a2,a3);
  110. //
  111. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,sketch1,L"CloseEdition",0);
  112. //
  113. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,part,L"Update",0);
  114. if(pApp)pApp->Release();
  115. ::CoUninitialize();
        HRESULT hr;
        CLSID AppClsid;
        IDispatch *pApp;

        ::CoInitialize(NULL);
        
	//
	::CLSIDFromProgID (L"CATIA.Application", &AppClsid); //get the unique id of CATIA
        
		
	//
	hr = CoCreateInstance(AppClsid,NULL,CLSCTX_LOCAL_SERVER, IID_IDispatch, (void**)&pApp);


        VARIANT result, buffer;
        VariantInit(&result);


        VARIANT arg2;
        VariantInit(&arg2);
        arg2.vt = VT_BOOL;
        arg2.boolVal = TRUE;
        hr = AutoWrap(DISPATCH_PROPERTYPUT|DISPATCH_METHOD, &result, pApp, L"Visible", 1, arg2);


        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, pApp, L"Documents", 0);//here there is no argument, so we put 0
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *documents = buffer.pdispVal;

        VARIANT arg1;
        VariantInit(&arg1);
        arg1.vt = VT_BSTR;
        arg1.bstrVal = ::SysAllocString(L"Part");
        //VARIANT result, buffer;
        VariantInit(&result);
        hr = AutoWrap(DISPATCH_METHOD, &result, documents, L"Add", 1 , arg1);

        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *partDocument = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, partDocument, L"Part", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *part = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, part, L"Bodies", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *bodies = buffer.pdispVal;

        //
        VARIANT arg;
        VariantInit(&arg);
        arg.vt = VT_BSTR;
        arg.bstrVal = ::SysAllocString(L"PartBody");
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, bodies, L"Item", 1, arg);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *body = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, body, L"Sketches", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *sketches1 = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, part, L"OriginElements", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *originElements = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, originElements, L"PlaneXY", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *reference1 = buffer.pdispVal;

        //
        VARIANT arg3;
        VariantInit(&arg3);
        arg3.vt = VT_DISPATCH;
        arg3.pdispVal = reference1;
        hr = AutoWrap(DISPATCH_METHOD, &result, sketches1, L"Add", 1, arg3);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *sketch1 = buffer.pdispVal;

        ////
        //SAFEARRAY * psa;
        //SAFEARRAYBOUND rgsabound[1];

        //rgsabound[0].lLbound = 0;
        //rgsabound[0].cElements = 9;

        //psa = SafeArrayCreate(VT_VARIANT, 1, rgsabound);
        //


        //hr = SafeArrayAccessData(psa);


        //hr = SafeArrayUnaccessData(psa);

        //VARIANT array;
        //VariantInit(&array);
        //array.vt = VT_ARRAY;
        //array.pparray = &psa;
        //
        //hr = AutoWrap(DISPATCH_METHOD, &result, sketch1, L"SetAbsoluteAxisData", 1, array);
        VARIANT arg4;
        VariantInit(&arg4);
        arg4.vt = VT_DISPATCH;
        arg4.pdispVal = sketch1;
        hr = AutoWrap(DISPATCH_PROPERTYPUT|DISPATCH_METHOD, &result, part, L"InWorkObject", 1, arg4);
        //buffer.vt = VT_DISPATCH;
        //buffer.pdispVal = result.pdispVal;
        //IDispatch *sketch1 = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, sketch1, L"OpenEdition", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *factory2D1 = buffer.pdispVal;


        //
        VARIANT a1, a2, a3;
        VariantInit(&a1);
        VariantInit(&a2);
        VariantInit(&a3);
        a1.vt = VT_R4;a1.fltVal = 50.f;
        a2.vt = VT_R4;a2.fltVal = 0.f;
        a3.vt = VT_R4;a3.fltVal = 0.f;
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, factory2D1, L"CreateClosedCircle", 3, a1, a2, a3);
		
        //
	hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, sketch1, L"CloseEdition", 0);
		
	//
	hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, part, L"Update", 0);
		

       if (pApp) pApp->Release();
       ::CoUninitialize();

2 利用CATIA自带的TLB转化成 tlh/tli 来编程

先用VC的 #import 功能进行转化,主要的几个 TLB 为:

InfTypeLib.tlb

KweTypeLib.tlb

PSTypeLib.tlb

MecModTypeLib.tlb

CATGitTypeLib.tlb

试验的 CATIA V5 R18 版本在转换之后有些小错误,之后就可以方便地写代码了。VC6的话,需要把转换后的UTF8编码文件转换成ANSI。

  1. intmain(intargc,char*argv[])
  2. {
  3. ::CoInitialize(NULL);
  4. ApplicationPtrcatia;
  5. HRESULThr=S_OK;
  6. hr=catia.GetActiveObject("CATIA.Application");
  7. if(FAILED(hr))
  8. {
  9. hr=catia.CreateInstance("CATIA.Application");
  10. }
  11. catia->PutVisible(VARIANT_TRUE);
  12. //
  13. DocumentsPtrdocuments;
  14. documents=catia->GetDocuments();
  15. BSTRAddPart=_com_util::ConvertStringToBSTR("Part");
  16. PartDocumentPtrpartDocument;
  17. partDocument=documents->Add(&AddPart);
  18. PartPtrpart=partDocument->GetPart();
  19. BodiesPtrbodies=part->GetBodies();
  20. BodyPtrbody=part->GetMainBody();
  21. HybridBodiesPtrhybridBodies=part->GetHybridBodies();
  22. FactoryPtrshapeFactory=part->GetShapeFactory();
  23. HybridShapeFactoryPtrhybridShapeFactory=part->GetHybridShapeFactory();
  24. SketchesPtrsketches=body->GetSketches();
  25. OriginElementsPtroriginElements=part->GetOriginElements();
  26. AnyObjectPtrplaneXY=originElements->GetPlaneXY();
  27. ReferencePtrr1=part->CreateReferenceFromObject(planeXY);
  28. SketchPtrsketch=sketches->Add(r1);
  29. part->PutInWorkObject(sketch);
  30. Factory2DPtrfactory2D=sketch->OpenEdition();
  31. factory2D->CreateClosedCircle(0.0,0.0,50.0);
  32. sketch->CloseEdition();
  33. part->Update();
  34. ::CoUninitialize();
  35. return0;
  36. }
int main(int argc, char* argv[])
{
    ::CoInitialize(NULL);

    ApplicationPtr catia;

    HRESULT hr = S_OK;

    hr = catia.GetActiveObject("CATIA.Application");

    if (FAILED(hr))
    {
        hr = catia.CreateInstance("CATIA.Application");
    }

    catia->PutVisible(VARIANT_TRUE);

    //
    DocumentsPtr documents;
    documents = catia->GetDocuments();
    BSTR AddPart = _com_util::ConvertStringToBSTR("Part");
    PartDocumentPtr partDocument;
    partDocument = documents->Add(&AddPart);

    PartPtr part = partDocument->GetPart();
     BodiesPtr bodies = part->GetBodies();
     BodyPtr body = part->GetMainBody();
     HybridBodiesPtr hybridBodies = part->GetHybridBodies();

    FactoryPtr shapeFactory = part->GetShapeFactory();

     HybridShapeFactoryPtr hybridShapeFactory = part->GetHybridShapeFactory();

    SketchesPtr sketches = body->GetSketches();

    OriginElementsPtr originElements = part->GetOriginElements();

    AnyObjectPtr planeXY = originElements->GetPlaneXY();

    ReferencePtr r1 = part->CreateReferenceFromObject(planeXY);

    SketchPtr sketch = sketches->Add(r1);

    part->PutInWorkObject(sketch);

    Factory2DPtr factory2D = sketch->OpenEdition();

    factory2D->CreateClosedCircle(0.0, 0.0, 50.0);

    sketch->CloseEdition();

    part->Update();

    ::CoUninitialize();

    return 0;
}


3 利用 CAA

还没有找到CAA安装程序,以后再续

最近开始对 CATIA 进行一些自动化的开发,本来想找 CAA 来进行研究,可惜一直没时间和机会去找,暂时就利用 CATIA Automation 来开发了。

由于利用 VB 或 VB.NET 将CATIA 脚本转化为程序确实方便,不过利用C++来操作更适合于我这种开发者。

方法有好多种,这里以画圆作为一个简单例子。

1 利用 IDispatch 接口来编程

  1. HRESULThr;
  2. CLSIDAppClsid;
  3. IDispatch*pApp;
  4. ::CoInitialize(NULL);
  5. //
  6. ::CLSIDFromProgID(L"CATIA.Application",&AppClsid);//gettheuniqueidofCATIA
  7. //
  8. hr=CoCreateInstance(AppClsid,NULL,CLSCTX_LOCAL_SERVER,IID_IDispatch,(void**)&pApp);
  9. VARIANTresult,buffer;
  10. VariantInit(&result);
  11. VARIANTarg2;
  12. VariantInit(&arg2);
  13. arg2.vt=VT_BOOL;
  14. arg2.boolVal=TRUE;
  15. hr=AutoWrap(DISPATCH_PROPERTYPUT|DISPATCH_METHOD,&result,pApp,L"Visible",1,arg2);
  16. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,pApp,L"Documents",0);//herethereisnoargument,soweput0
  17. buffer.vt=VT_DISPATCH;
  18. buffer.pdispVal=result.pdispVal;
  19. IDispatch*documents=buffer.pdispVal;
  20. VARIANTarg1;
  21. VariantInit(&arg1);
  22. arg1.vt=VT_BSTR;
  23. arg1.bstrVal=::SysAllocString(L"Part");
  24. //VARIANTresult,buffer;
  25. VariantInit(&result);
  26. hr=AutoWrap(DISPATCH_METHOD,&result,documents,L"Add",1,arg1);
  27. buffer.vt=VT_DISPATCH;
  28. buffer.pdispVal=result.pdispVal;
  29. IDispatch*partDocument=buffer.pdispVal;
  30. //
  31. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,partDocument,L"Part",0);
  32. buffer.vt=VT_DISPATCH;
  33. buffer.pdispVal=result.pdispVal;
  34. IDispatch*part=buffer.pdispVal;
  35. //
  36. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,part,L"Bodies",0);
  37. buffer.vt=VT_DISPATCH;
  38. buffer.pdispVal=result.pdispVal;
  39. IDispatch*bodies=buffer.pdispVal;
  40. //
  41. VARIANTarg;
  42. VariantInit(&arg);
  43. arg.vt=VT_BSTR;
  44. arg.bstrVal=::SysAllocString(L"PartBody");
  45. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,bodies,L"Item",1,arg);
  46. buffer.vt=VT_DISPATCH;
  47. buffer.pdispVal=result.pdispVal;
  48. IDispatch*body=buffer.pdispVal;
  49. //
  50. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,body,L"Sketches",0);
  51. buffer.vt=VT_DISPATCH;
  52. buffer.pdispVal=result.pdispVal;
  53. IDispatch*sketches1=buffer.pdispVal;
  54. //
  55. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,part,L"OriginElements",0);
  56. buffer.vt=VT_DISPATCH;
  57. buffer.pdispVal=result.pdispVal;
  58. IDispatch*originElements=buffer.pdispVal;
  59. //
  60. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,originElements,L"PlaneXY",0);
  61. buffer.vt=VT_DISPATCH;
  62. buffer.pdispVal=result.pdispVal;
  63. IDispatch*reference1=buffer.pdispVal;
  64. //
  65. VARIANTarg3;
  66. VariantInit(&arg3);
  67. arg3.vt=VT_DISPATCH;
  68. arg3.pdispVal=reference1;
  69. hr=AutoWrap(DISPATCH_METHOD,&result,sketches1,L"Add",1,arg3);
  70. buffer.vt=VT_DISPATCH;
  71. buffer.pdispVal=result.pdispVal;
  72. IDispatch*sketch1=buffer.pdispVal;
  73. ////
  74. //SAFEARRAY*psa;
  75. //SAFEARRAYBOUNDrgsabound[1];
  76. //rgsabound[0].lLbound=0;
  77. //rgsabound[0].cElements=9;
  78. //psa=SafeArrayCreate(VT_VARIANT,1,rgsabound);
  79. //
  80. //hr=SafeArrayAccessData(psa);
  81. //hr=SafeArrayUnaccessData(psa);
  82. //VARIANTarray;
  83. //VariantInit(&array);
  84. //array.vt=VT_ARRAY;
  85. //array.pparray=&psa;
  86. //
  87. //hr=AutoWrap(DISPATCH_METHOD,&result,sketch1,L"SetAbsoluteAxisData",1,array);
  88. VARIANTarg4;
  89. VariantInit(&arg4);
  90. arg4.vt=VT_DISPATCH;
  91. arg4.pdispVal=sketch1;
  92. hr=AutoWrap(DISPATCH_PROPERTYPUT|DISPATCH_METHOD,&result,part,L"InWorkObject",1,arg4);
  93. //buffer.vt=VT_DISPATCH;
  94. //buffer.pdispVal=result.pdispVal;
  95. //IDispatch*sketch1=buffer.pdispVal;
  96. //
  97. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,sketch1,L"OpenEdition",0);
  98. buffer.vt=VT_DISPATCH;
  99. buffer.pdispVal=result.pdispVal;
  100. IDispatch*factory2D1=buffer.pdispVal;
  101. //
  102. VARIANTa1,a2,a3;
  103. VariantInit(&a1);
  104. VariantInit(&a2);
  105. VariantInit(&a3);
  106. a1.vt=VT_R4;a1.fltVal=50.f;
  107. a2.vt=VT_R4;a2.fltVal=0.f;
  108. a3.vt=VT_R4;a3.fltVal=0.f;
  109. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,factory2D1,L"CreateClosedCircle",3,a1,a2,a3);
  110. //
  111. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,sketch1,L"CloseEdition",0);
  112. //
  113. hr=AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD,&result,part,L"Update",0);
  114. if(pApp)pApp->Release();
  115. ::CoUninitialize();
        HRESULT hr;
        CLSID AppClsid;
        IDispatch *pApp;

        ::CoInitialize(NULL);
        
	//
	::CLSIDFromProgID (L"CATIA.Application", &AppClsid); //get the unique id of CATIA
        
		
	//
	hr = CoCreateInstance(AppClsid,NULL,CLSCTX_LOCAL_SERVER, IID_IDispatch, (void**)&pApp);


        VARIANT result, buffer;
        VariantInit(&result);


        VARIANT arg2;
        VariantInit(&arg2);
        arg2.vt = VT_BOOL;
        arg2.boolVal = TRUE;
        hr = AutoWrap(DISPATCH_PROPERTYPUT|DISPATCH_METHOD, &result, pApp, L"Visible", 1, arg2);


        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, pApp, L"Documents", 0);//here there is no argument, so we put 0
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *documents = buffer.pdispVal;

        VARIANT arg1;
        VariantInit(&arg1);
        arg1.vt = VT_BSTR;
        arg1.bstrVal = ::SysAllocString(L"Part");
        //VARIANT result, buffer;
        VariantInit(&result);
        hr = AutoWrap(DISPATCH_METHOD, &result, documents, L"Add", 1 , arg1);

        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *partDocument = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, partDocument, L"Part", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *part = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, part, L"Bodies", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *bodies = buffer.pdispVal;

        //
        VARIANT arg;
        VariantInit(&arg);
        arg.vt = VT_BSTR;
        arg.bstrVal = ::SysAllocString(L"PartBody");
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, bodies, L"Item", 1, arg);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *body = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, body, L"Sketches", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *sketches1 = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, part, L"OriginElements", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *originElements = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, originElements, L"PlaneXY", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *reference1 = buffer.pdispVal;

        //
        VARIANT arg3;
        VariantInit(&arg3);
        arg3.vt = VT_DISPATCH;
        arg3.pdispVal = reference1;
        hr = AutoWrap(DISPATCH_METHOD, &result, sketches1, L"Add", 1, arg3);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *sketch1 = buffer.pdispVal;

        ////
        //SAFEARRAY * psa;
        //SAFEARRAYBOUND rgsabound[1];

        //rgsabound[0].lLbound = 0;
        //rgsabound[0].cElements = 9;

        //psa = SafeArrayCreate(VT_VARIANT, 1, rgsabound);
        //


        //hr = SafeArrayAccessData(psa);


        //hr = SafeArrayUnaccessData(psa);

        //VARIANT array;
        //VariantInit(&array);
        //array.vt = VT_ARRAY;
        //array.pparray = &psa;
        //
        //hr = AutoWrap(DISPATCH_METHOD, &result, sketch1, L"SetAbsoluteAxisData", 1, array);
        VARIANT arg4;
        VariantInit(&arg4);
        arg4.vt = VT_DISPATCH;
        arg4.pdispVal = sketch1;
        hr = AutoWrap(DISPATCH_PROPERTYPUT|DISPATCH_METHOD, &result, part, L"InWorkObject", 1, arg4);
        //buffer.vt = VT_DISPATCH;
        //buffer.pdispVal = result.pdispVal;
        //IDispatch *sketch1 = buffer.pdispVal;

        //
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, sketch1, L"OpenEdition", 0);
        buffer.vt = VT_DISPATCH;
        buffer.pdispVal = result.pdispVal;
        IDispatch *factory2D1 = buffer.pdispVal;


        //
        VARIANT a1, a2, a3;
        VariantInit(&a1);
        VariantInit(&a2);
        VariantInit(&a3);
        a1.vt = VT_R4;a1.fltVal = 50.f;
        a2.vt = VT_R4;a2.fltVal = 0.f;
        a3.vt = VT_R4;a3.fltVal = 0.f;
        hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, factory2D1, L"CreateClosedCircle", 3, a1, a2, a3);
		
        //
	hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, sketch1, L"CloseEdition", 0);
		
	//
	hr = AutoWrap(DISPATCH_PROPERTYGET|DISPATCH_METHOD, &result, part, L"Update", 0);
		

       if (pApp) pApp->Release();
       ::CoUninitialize();

2 利用CATIA自带的TLB转化成 tlh/tli 来编程

先用VC的 #import 功能进行转化,主要的几个 TLB 为:

InfTypeLib.tlb

KweTypeLib.tlb

PSTypeLib.tlb

MecModTypeLib.tlb

CATGitTypeLib.tlb

试验的 CATIA V5 R18 版本在转换之后有些小错误,之后就可以方便地写代码了。VC6的话,需要把转换后的UTF8编码文件转换成ANSI。

  1. intmain(intargc,char*argv[])
  2. {
  3. ::CoInitialize(NULL);
  4. ApplicationPtrcatia;
  5. HRESULThr=S_OK;
  6. hr=catia.GetActiveObject("CATIA.Application");
  7. if(FAILED(hr))
  8. {
  9. hr=catia.CreateInstance("CATIA.Application");
  10. }
  11. catia->PutVisible(VARIANT_TRUE);
  12. //
  13. DocumentsPtrdocuments;
  14. documents=catia->GetDocuments();
  15. BSTRAddPart=_com_util::ConvertStringToBSTR("Part");
  16. PartDocumentPtrpartDocument;
  17. partDocument=documents->Add(&AddPart);
  18. PartPtrpart=partDocument->GetPart();
  19. BodiesPtrbodies=part->GetBodies();
  20. BodyPtrbody=part->GetMainBody();
  21. HybridBodiesPtrhybridBodies=part->GetHybridBodies();
  22. FactoryPtrshapeFactory=part->GetShapeFactory();
  23. HybridShapeFactoryPtrhybridShapeFactory=part->GetHybridShapeFactory();
  24. SketchesPtrsketches=body->GetSketches();
  25. OriginElementsPtroriginElements=part->GetOriginElements();
  26. AnyObjectPtrplaneXY=originElements->GetPlaneXY();
  27. ReferencePtrr1=part->CreateReferenceFromObject(planeXY);
  28. SketchPtrsketch=sketches->Add(r1);
  29. part->PutInWorkObject(sketch);
  30. Factory2DPtrfactory2D=sketch->OpenEdition();
  31. factory2D->CreateClosedCircle(0.0,0.0,50.0);
  32. sketch->CloseEdition();
  33. part->Update();
  34. ::CoUninitialize();
  35. return0;
  36. }
int main(int argc, char* argv[])
{
    ::CoInitialize(NULL);

    ApplicationPtr catia;

    HRESULT hr = S_OK;

    hr = catia.GetActiveObject("CATIA.Application");

    if (FAILED(hr))
    {
        hr = catia.CreateInstance("CATIA.Application");
    }

    catia->PutVisible(VARIANT_TRUE);

    //
    DocumentsPtr documents;
    documents = catia->GetDocuments();
    BSTR AddPart = _com_util::ConvertStringToBSTR("Part");
    PartDocumentPtr partDocument;
    partDocument = documents->Add(&AddPart);

    PartPtr part = partDocument->GetPart();
     BodiesPtr bodies = part->GetBodies();
     BodyPtr body = part->GetMainBody();
     HybridBodiesPtr hybridBodies = part->GetHybridBodies();

    FactoryPtr shapeFactory = part->GetShapeFactory();

     HybridShapeFactoryPtr hybridShapeFactory = part->GetHybridShapeFactory();

    SketchesPtr sketches = body->GetSketches();

    OriginElementsPtr originElements = part->GetOriginElements();

    AnyObjectPtr planeXY = originElements->GetPlaneXY();

    ReferencePtr r1 = part->CreateReferenceFromObject(planeXY);

    SketchPtr sketch = sketches->Add(r1);

    part->PutInWorkObject(sketch);

    Factory2DPtr factory2D = sketch->OpenEdition();

    factory2D->CreateClosedCircle(0.0, 0.0, 50.0);

    sketch->CloseEdition();

    part->Update();

    ::CoUninitialize();

    return 0;
}


3 利用 CAA

还没有找到CAA安装程序,以后再续

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值