许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  CATIA Automation编程初探

CATIA Automation编程初探

阅读数 36
点赞 0
article_banner

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


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


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


1 利用 IDispatch 接口来编程


[cpp] view plaincopyprint?


  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。

[cpp] view plaincopyprint?


  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 接口来编程


[cpp] view plaincopyprint?


  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。

[cpp] view plaincopyprint?


  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 V5 Automation 教程
免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删


相关文章
技术文档
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空