-
- 素材大。
- 229.5 KB
- 素材授權:
- 免費下載
- 素材格式:
- .ppt
- 素材上傳:
- ppt
- 上傳時間:
- 2016-04-02
- 素材編號:
- 51858
- 素材類別:
- 培訓教程PPT
-
素材預覽
這是一個關于objectarx視頻教程培訓PPT(部分ppt內容已做更新升級),主要介紹了ObjectARX應用、ObjectARX概述、ObjectARX開發(fā)特點、ObjectARX類庫構成等內容。培訓是給新員工或現有員工傳授其完成本職工作所必需的正確思維認知、基本知識和技能的過程。是一種有組織的知識傳遞、技能傳遞、標準傳遞、信息傳遞、管理訓誡行為。其中以技能傳遞為主,側重上崗前進行。為了達到統一的科學技術規(guī)范、標準化作業(yè),通過目標規(guī)劃設定知識和信息傳遞、技能熟練演練、作業(yè)達成評測、結果交流公告等現代信息化的流程,讓員工通過一定的教育訓練技術手段,達到預期的水平,提高目標。目前國內培訓以技能傳遞為主,時間在側重上崗前。
objectarx視頻教程培訓PPT是由紅軟PPT免費下載網推薦的一款培訓教程PPT類型的PowerPoint.
ObjectARX Training
華中科技大學CAD中心
武漢天喻軟件有限責任公司
2010年2月
ObjectARX應用的介紹
ObjectARX是一個僅在AutoCAD上進行二次開發(fā)的一套開發(fā)環(huán)境,通俗點講就是一系列的API
ObjectARX的應用舉例:
擴展AutoCAD功能
為各種工程設計開發(fā)便利的工具
ObjectARX概述
ARX——AutoCAD Runtime eXtension
DBX ——DataBase eXtension
ARX = .DLL + 2 exported functions
{ acrxEntryPoint & acrxGetApiVersion }
ObjectARX開發(fā)特點
不同的ACAD版本用不同的開發(fā)包及開發(fā)環(huán)境
ACAD2000~ACAD2002 : VC++ 6.0
ACAD2004~ACAD2006 : VS.NET 2002
ACAD2007~ACAD2009 : VS.NET 2005
ACAD2010~ : VS.NET 2008
ACAD2007開始字符串采用UNICODE編碼
ARX之間不能連續(xù)依賴
A.arx依賴B.arx, B.arx依賴C.dbx,則A.arx不能加載
與ACAD已有功能地位一致
ObjectARX類庫構成
AcRx:用于幫定一個應用程序以及運行類的注冊和識別。
AcEd:用于注冊自定義命令和AutoCAD事件通告。
AcDb:AutoCAD圖形數據庫。
AcGi: 用于AutoCAD 的圖形類。
AcGe:用于AutoCAD 的線型和幾何對象通用類。
ADS: AutoCAD 的早期版本C語言函數庫。
ObjectARX類結構
類圖classmap.dwg
位置:\ObjectARX 2006\classmap
用ObjectARX能做些什么?
訪問、編輯和擴展AutoCAD圖形數據庫
和AutoCAD系統相互通信
使用MFC創(chuàng)建用戶接口
支持多文檔應用
創(chuàng)建自定義類和自定義實體
可以開發(fā)復雜的應用
和其他開發(fā)環(huán)境進行協作
培訓安排-1
一、基礎
AUTOCAD數據庫結構及操作,ads_name-句柄-ID及轉換,aced常用函數,WCS/UCS及轉換,菜單/工具條/對話框制作
二、自定義對象
顯示/存儲/夾點/移動/拷貝/范圍/list/捕捉點/炸開/相交點/sub事件
三、自定義對象生成與編緝
雙擊修改/Jig/屬性頁
培訓安排-2
四、一些重要對象
字典/層/線型/字體樣式
五、擴展數據
六、反應器
八、總結
所需基礎
ACAD基本操作
C++
VC
MFC(界面)
COM(屬性頁等)
STL(提高效率)
AutoCAD圖形數據庫概述
AutoCAD圖形實際上是一系列存放在一個AcDbDatabase類型的對象中的AcDb對象。
一個dwg就是一個數據庫
具備數據庫的基本組織結構。
包括九個符號表和一個命名對象詞典
AutoCAD圖形數據庫結構
AcDbDatabase數據庫
|------AcDb符號表
| |------塊表(AcDbBlockTable)
| |------尺寸標注樣式表(AcDbDimStyleTable)
| |------層表(AcDbLayerTable)
| |------線型表(AcDbLinetypeTable)
| |------已注冊應用程序表(AcDbRegAppTable)
| |------字體樣式表(AcDbTextStyleTable)
| |------用戶坐標系表(AcDbUCSTable)
| |------視口表(AcDbViewportTable)
| |------視圖表(AcDbViewTable)
|-------命名對象詞典
訪問:AcDbDatabase::getSymbolTable
向數據庫中添加實體
Acad::ErrorStatus addEntityToModelSpace(AcDbEntity * pEnt, AcDbObjectId & EntId)
{
Acad::ErrorStatus eRet;
AcDbDatabase * pDb = acdbHostApplicationServices()->workingDatabase();
AcDbBlockTable *pBlockTable;
eRet = pDb->getBlockTable(pBlockTable, AcDb::kForRead);
if ( eRet != Acad::eOk)
{
return eRet;
}
AcDbBlockTableRecord *pBlockTableRecord;
eRet = pBlockTable->getAt(ACDB_MODEL_SPACE, pBlockTableRecord, AcDb::kForWrite);
if ( eRet != Acad::eOk)
{
pBlockTable->close();
return eRet;
}
pBlockTable->close();
eRet = pBlockTableRecord->appendAcDbEntity(EntId, pEnt);
if ( eRet != Acad::eOk)
{
pBlockTableRecord->close();
return eRet;
}
pBlockTableRecord->close();
return Acad::eOk;
}
怎樣遍歷AutoCAD圖形數據庫?
void FindObjectId(AcDbObjectId & objId)
{
AcDbDatabase * pDb = acdbHostApplicationServices()->workingDatabase();
AcDbBlockTable *pBlockTable;
pDb->getBlockTable(pBlockTable, AcDb::kForRead);
AcDbBlockTableRecord *pBlockTableRecord;
pBlockTable->getAt(ACDB_MODEL_SPACE, pBlockTableRecord, AcDb:: kForRead);
pBlockTable->close();
AcDbBlockTableRecordIterator *pIter;
pBlockTableRecord- >newIterator(pIter); // Create an iterator
for (pIter->start(); !pIter->done(); pIter->step())
{
….........
AcDbEntity *pEntity;
if (pIter->getEntity(pEntity, AcDb::kForRead) != Acad::eOk) continue;
If(pEntity->isKindOf(AcDbCircle::desc()) objId = pEntity->ObjectId();
}
pBlockTableRecord- >close();
}
怎樣創(chuàng)建和使用已有的AutoCAD圖形數據庫?
要使用AcDbDatabase數據庫,與使用其它數據庫一樣,首先要聲明一個數據庫對象。AcDbDatabase類的聲明,調用類的構造函數:
AcDbDatabase ::AcDbDatabase(bool buildDefaultDrawing = true, bool noDocument = false);
其中,buildDefaultDrawing參數控制是否創(chuàng)建一個包括所有默認數據記錄的數據庫。
該參數的默認值為true,這樣在AcDbDatabase數據庫創(chuàng)建時,將在新建的數據庫中包含一個AutoCAD圖形數據庫必須包含的基本數據要素,這些要素包括九個符號表及其初始記錄(比如0層、STANDARD文字樣式等),命名對象詞典(組詞典和多線樣式詞典)以及必要的系統變量設置。這樣就可以向新建的數據庫中添加各種實體和對象。如:AcDbDatabase *pDb= new AcDbDatabase(true);
若指定該參數為false,AutoCAD將創(chuàng)建一個完全空的AcDbDatabase數據庫。這樣的AcDbDatabase數據庫不能直接向其中添加實體或對象,需讀入一個圖形文件來拓展該圖形數據庫,然后再逐步添加或修改數據庫中的實體或對象。
讀入圖形數據庫使用函數:AcadErrorStatus AcDbDatabase::readDwgFile(const char* fileName );
若要使用已有的圖形,比如“test.dwg”文件,則使用下列代碼:
AcDbDatabase *pDb= new AcDbDatabase(false);
pDb->readDwgFile(“test.dwg”);
AcDbDatabase構造函數的noDocument參數控制打開的數據庫是否與當前文檔關聯,此參數用于“多文檔處理”中。
注意:在這種情況下,AcDbdatabase()的參數必須指定為false(當然,0或者Adesk::kFalse都可以)。因為使用pDb->readDwgFile()函數時,pDb必須是一個完全空白的數據庫,也就是說,哪怕使用了AcDbDatabase(false);新建數據庫后,只要對數據庫進行了操作,就不能再使用readDwgFile()函數,否則會導致嚴重的內存錯誤。
數據庫對象AcDbObject概述
每一個數據庫對象具有以下三種表示方法:
句柄 —— AcDbHandle
對象id —— AcDbObjectId
指針 —— AcDbObect *
三者之間的相互關系
之間相互關系和轉換
1. AcDbHandle -> AcDbObjectId
AcDbDatabase ::getAcDbObjectId(&AcDbObjectId ,FALSE, AcDbHandle );
2. AcDbObjectId -> AcDbHandle
AcDbHandle = AcDbObjectId::handle ();
3.AcDbObjectId -> AcDbObject *
acdbOpenObject(AcDbObject *&,AcDbObjectId,AcDb::OpenMode);
4.AcDbObject * -> AcDbHandle
AcDbHandle = AcDbObject::getAcDbHandle();
5.ads_name 和 AcDbObjcetId
一個ads_name 是 一個包含兩個long型元素的數組
這個數組的第一個元素就是AcDbObjcetId
6. ads_name 和 AcDbObjcetId相互轉換
acdbGetAdsName(ads_name, objId);
acdbGetObjectId(objId, ads_name);
怎樣訪問數據庫對象?
打開對象的方法:
acdbOpenObject() 該函數為模板函數,能打開任意對象
acdbOpenAcDbObject()
acdbOpenAcDbEntity()
打開對象的模式:
AcDb::kForRead //只讀
AcDb::kForWrite //可寫
AcDb::kForNotify //通知
升級和降級訪問:
AcDbObject::upgradeOpen(); //升級為寫
AcDbObject::downgradeOpen(); //降級為讀
刪除對象
AcDbObject::erase()
用事務方式訪問
事務
AcTransaction * AcTransactionManager::startTransaction
AcTransactionManager::endTransaction()
AcTransactionManager::abortTransaction(),
virtual Acad::ErrorStatus getObject(AcDbObject*& obj, AcDbObjectId objectId, AcDb::OpenMode mode, bool openErasedObject = false)
對象訪問限制
如果一個對象被寫打開,則在關閉前不能再被讀打開或寫打開
如果一個對象被讀打開,則在關閉前不能再被寫打開,但可被讀打開(一個對象最多可同時被打開128次)
對象類型識別
desc():
a static member function that returns the class descriptor object of a particular (known) class.
cast():
a static member function that returns an object of the specified type, or NULL if the object is not of the required class (or a derived class).
isKindOf():
returns whether an object belongs to the specified class (or a derived class).
isA():
returns the class descriptor object of an object whose class is unknown.
AcRxClass
例如:
AcDbEntity* curEntity = somehowGetAndOpenAnEntity();
if (curEntity->isKindOf(AcDbEllipse::desc())) { }
If(curEntity->isA() == AcDbEllipse::desc()){ }
AcDbLine * pLine = AcDbLine ::cast(curEntity )
AutoCAD里的交互
AcEd 全局函數
String, number acquisition
acedGetInt used to get an integer valueacedGetReal used to get a real valueacedGetString used to get a stringacedGetDist used to get the distance between two points
Point, angle acquisition
acedGetAngle used to get a angle valueacedGetPoint used to pick a pointacedGetCorner
Entity selection
acedEntSel used to select a single entityacedNEntSel used to select a single, nested entityacedNEntSelP used to select a single, nested entityacedSSGet used to select multiple entities
Others
acedGetKword used to get a key wordacedInitGet used to initialize acedGetXXXX functionsacedGetFileD used to retrieve file selection from a file dialog
向ACAD發(fā)送命令
acedCommand:立即執(zhí)行
acedCommand(RTSTR, "zoom", RTSTR, "e", 0);
sendStringToExecute:作為下一個命令執(zhí)行
CString strCmd;
strCmd.Format("_HNBMReservedAreaModified %d %d ", (long)ReservedAreaHandle, nType);
acDocManager->sendStringToExecute(acDocManager->curDocument(), strCmd, false, true, false);
共同點:都不能執(zhí)行有用戶交互的命令
WCS,UCS,OCS(ECS)
規(guī)則:數據庫中對象保存的點坐標是WCS坐標(建議);而一些acedXX函數(如acedGetPoint,acedEntSel等)、list命令一般是UCS坐標。
WCS與UCS相互轉換
//UCS坐標系
fromrb.restype = RTSHORT;
fromrb.resval.rint = 1;
//WCS坐標系
torb.restype = RTSHORT;
torb.resval.rint = 0;
acedTrans(pt_ucs,&fromrb,&torb,FALSE,resultPt);
acdbUcs2Wcs
acdbWcs2Ucs
AcDbEntity::getEcs
UCS常用函數及類
函數:Acad::ErrorStatus acedGetCurrentUCS(AcGeMatrix3d& mat);
(以下函數和類可看作符號表的操作模式)
函數:Acad::ErrorStatus getSymbolTable(AcDbUCSTable*& pTable,AcDb::OpenMode mode);
類:AcDbUCSTable
類:AcDbUCSTableRecord
ARX應用向導
應用向導:ObjectARX 2006的在\ObjectARX 2006\utils\ObjARXWiz目錄下。
功能:與MFC應用向導類似
產生工程
產生特定類及函數
ARX,DBX加載/卸載
加載
ap(appload)
arx
其它方式(lisp文件,注冊表等)
卸載
ap
arx
ARX軟件結構
加載:On_kInitAppMsg
卸載:On_kUnloadAppMsg
命令映射(arx2006或以上):
static void INTECAD_INTESelect(void)
{
}
ACED_ARXCOMMAND_ENTRY_AUTO(CINTECADApp, INTECAD, _INTESelect, INTESelect, ACRX_CMD_TRANSPARENT, NULL)
ARX & MFC
ObjectARX 完全支持MFC。
兩個MFC基類 AdUi and AcUi。
注意:在調用資源時加上這句話 CAcModuleResourceOverride resOverride;
對話框
資源轉換,多個ARX時可能需要
CAcModuleResourceOverride resOverride;
或
AfxSetResourceHandle (_hdllInstance) ;
AfxSetResourceHandle (acedGetAcadResourceInstance ()) ;
菜單與工具條
通過菜單文件
COM方式添加
例1:基本操作
建立應用程序
建立命令
實現功能:選中一實體,然后輸出其信息
例2:重復產生同半徑的圓
對話框輸入半徑
用鼠標指定圓心
數據庫結構查看工具
ARXDBG工具的使用
位置:\ObjectARX 2006\samples\database\ARXDBG
文檔:ArxDbg.doc
本節(jié)結束
下節(jié)將介紹自定義實體的內容
自定義對象類
一般從 AcDbObject 或AcDbEntity派生
AcDbObject:不須顯示,如字典對象
AcDbEntity:可顯示/操作的實體
從其他(如AcDbLine等實體類)派生:根據需要
自定義類可繼續(xù)從另一個自定義繼承,從而繼承體系成樹狀結構
編寫時遵守一定的規(guī)則
放在DBX工程中
自定義類特點
頭文件
ACRX_DECLARE_MEMBERS
ACDB_REGISTER_OBJECT_ENTRY_AUTO
版本
CPP文件
ACRX_DXF_DEFINE_MEMBERS
AcDbProxyEntity::kNoOperation
assertReadEnabled ()與assertWriteEnabled () ;
讀寫控制
顯示刷新
UNO/REDO
DBX加載/卸載
在ARX中調用
acrxLoadModule/acrxUnloadModule
ARX在使用DBX的LIB庫時,可能會出現諸如:acrxGetApiVersion找不到或ARX加載失敗的問題.解決方法:
在ARX和DBX工程中都增加def文件,文件內容如下:
EXPORTS
acrxEntryPoint PRIVATE
acrxGetApiVersion PRIVATE
自定義對象-讀入/寫出
作用
文件(DWG,DXF)讀寫
UNDO/REDO
CLONE
函數
virtual Acad::ErrorStatus dwgInFields(AcDbDwgFiler* filer);
virtual Acad::ErrorStatus dwgOutFields(AcDbDwgFiler* filer) const;
virtual Acad::ErrorStatus dxfInFields(AcDbDxfFiler* filer);
virtual Acad::ErrorStatus dxfOutFields(AcDbDxfFiler* filer) const;
AcDbDwgFiler
類中常用函數
virtual Acad::ErrorStatus readInt32(Adesk::Int32*)
virtual Acad::ErrorStatus writeInt32(Adesk::Int32)
virtual Acad::ErrorStatus readString(char**)
virtual Acad::ErrorStatus writeString(const char*)
virtual Acad::ErrorStatus readPoint3d(AcGePoint3d*)
virtual Acad::ErrorStatus writePoint3d(const AcGePoint3d&)
virtual Acad::ErrorStatus readAcDbHandle(AcDbHandle*)
virtual Acad::ErrorStatus writeAcDbHandle(const AcDbHandle&)
virtual Acad::ErrorStatus readBytes(void *, Adesk::UInt32)
virtual Acad::ErrorStatus writeBytes(const void *, Adesk::UInt32)
讀字符串
char *str=NULL;
pFiler->readString(&str);
m_strPanelType=str;
acutDelString(str);
自定義對象-顯示
函數:
virtual Adesk::Boolean worldDraw( AcGiWorldDraw* mode);
virtual void viewportDraw(AcGiViewportDraw* mode);
區(qū)別
worldDraw函數用來生成跟視圖無關的幾何圖形,它只生成一組幾何圖形,其他的因為視圖的變化而導致的幾何圖形變化都由AutoCAD來自動調整,舉個例子,你生成一個立方體,這個立方體從不同的角度看所看到的外形是不一樣的,但是worldDraw只生成一個角度的幾何圖形,其他的都由AutoCAD來自動的調整了。
viewportDraw則不同,它可以根據不同的視圖生成不同的幾何圖形,當你的視圖改變的時候,它自動將幾何圖形調整到正確的狀態(tài)。有時候這兩個函數需要配合使用,例如,如果你畫圓,那就可以用worldDraw,因為無論你怎么變換視圖圓還是圓。但是如果你生成一些表示立體的幾何圖形有時候就需要借助于viewportDraw了,因為對于立體圖形來說不同的視圖看到的是不一樣的。舉個例子來說明其區(qū)別就是worldDraw畫出來的立體圖形,你改變了角度(也算viewport改變)后看到的有可能就不是立體圖形了,但是你用viewportDraw畫出來的就不會出現這樣的問題。
AcGiWorldDraw與AcGiViewportDraw
類似,但AcGiViewportDraw有視口相關的矩陣和方向函數
通過geometry得到繪圖類AcGiWorldGeometry 的對象
通過subEntityTraits得到環(huán)境設置類AcGiSubEntityTraits 對象
AcGiWorldGeometry與AcGiGeometry
circle
circularArc
Polyline(多段線)
polygon
text
pline(多義線,類似于AcDbPolyline)
AcGiSubEntityTraits
常用函數
virtual void setColor(const Adesk::UInt16 color) = 0;
virtual void setTrueColor(const AcCmEntityColor& color) = 0;
virtual void setLayer(const AcDbObjectId layerId) = 0;
virtual void setLineType(const AcDbObjectId linetypeId) = 0;
virtual void setFillType(const AcGiFillType) = 0;
virtual void setLineWeight(const AcDb::LineWeight lw) = 0;
virtual void setLineTypeScale(double dScale = 1.0) = 0;
注意
一個自定義對象的不同部分可分屬不同層
是否填充只針對circle,polygon等封閉圖形
例1 自定義實體-讀寫/顯示
生成一等邊三角形的自定義實體
中心
外接圓半徑
方位角
自定義對象-夾點
virtual Acad::ErrorStatus getGripPoints(AcGePoint3dArray& gripPoints, AcDbIntArray& osnapModes, AcDbIntArray& geomIds) const;
virtual Acad::ErrorStatus moveGripPointsAt( const AcDbIntArray& indices, const AcGeVector3d& offset);
自定義對象-移動
virtual Acad::ErrorStatus transformBy( const AcGeMatrix3d& xform);
自定義對象-拷貝
virtual Acad::ErrorStatus deepClone(AcDbObject* pOwnerObject, AcDbObject*& pClonedObject, AcDbIdMapping& idMap, Adesk::Boolean isPrimary = true) const;
virtual Acad::ErrorStatus wblockClone(AcRxObject* pOwnerObject, AcDbObject*& pClonedObject, AcDbIdMapping& idMap, Adesk::Boolean isPrimary = true) const;
自定義對象-炸開
virtual Acad::ErrorStatus explode(AcDbVoidPtrArray& entitySet) const;
自定義對象-捕捉點
virtual Acad::ErrorStatus getOsnapPoints( AcDb::OsnapMode osnapMode, int gsSelectionMark, const AcGePoint3d& pickPoint, const AcGePoint3d& lastPoint, const AcGeMatrix3d& viewXform, AcGePoint3dArray& snapPoints, AcDbIntArray& geomIds) const;
自定義對象-范圍
virtual Acad::ErrorStatus getGeomExtents(AcDbExtents& extents) const;
自定義對象-list
作用:調試檢查用.
virtual void list() const;
自定義對象-相交點
virtual Acad::ErrorStatus intersectWith(const AcDbEntity* pEnt,AcDb::Intersect intType,AcGePoint3dArray& points,int thisGsMarker = 0,int otherGsMarker = 0) const;
自定義對象- sub事件
virtual Acad::ErrorStatus subErase(Adesk::Boolean erasing);
virtual Acad::ErrorStatus subOpen(AcDb::OpenMode mode);
virtual Acad::ErrorStatus subClose();
理解拖動夾點與平移實體的工作方式
在拖動夾點時,ACAD調用自定義對象重載的moveGripPointsAt函數。但這時你要注意:此時的this指針指向的自定義對象A并非數據庫中待修改的對象B,A只是ACAD復制的一個用于操作的臨時對象,它的所有持久性(即保存到文件中的)參數與B相同,非持久性參數保持構造函數時的值。A并沒有被加入到數據庫中,所以在moveGripPointsAt不能通過database()函數獲取數據庫指針;A中的參數沒有累積性,即在moveGripPointsAt中更改了一個類成員變量m的值,下一次調用moveGripPointsAt時,m的值與B中m值相同,而不是修改過的值。
transformBy與moveGripPointsAt類似。
本節(jié)結束
下節(jié)將介紹自定義對象生成與編緝
雙擊修改
動態(tài)生成(Jig)
屬性頁
實體的雙擊修改
在ARX工程中:從AcDbDoubleClickEdit派生并重載函數:
virtual void startEdit(AcDbEntity *pEnt, AcGePoint3d pt);
virtual void finishEdit(void);
在On_kInitAppMsg中:
if(!acrxDynamicLinker->loadModule(/*MSG0*/"ACDBLCLKEDITPE.ARX",Adesk::kFalse))
{
AfxMessageBox("'ACDBLCLKEDITPE.ARX' Load Failed");
}
// Initialize Double Click Editing
AcDbDoubleClickEdit::rxInit();
acrxBuildClassHierarchy();
TYTriangleDoubleClickEdit *pTriangleDoubleClickEdit=new TYTriangleDoubleClickEdit;
TYTriangle::desc()->addX(AcDbDoubleClickEdit::desc(),pTriangleDoubleClickEdit);
實體的雙擊修改
On_kUnloadAppMsg函數中:
TYTriangle::desc()->delX(AcDbDoubleClickEdit::desc());
startEdit函數
文檔加鎖
設置資源
顯示對話框
修改實體
文檔解鎖
例1:自定義實體的雙擊修改
可改:
外接圓半徑
填充
動態(tài)創(chuàng)建
AcEdJig
virtual DragStatus sampler () ;
virtual Adesk::Boolean update () ;
virtual AcDbEntity *entity () const ;
DragStatus drag();
AcEdJIg中的用戶輸入函數
DragStatus acquireString(char *str);
DragStatus acquireAngle(double &ang);
DragStatus acquireAngle(double &ang, const AcGePoint3d& basePnt);
DragStatus acquireDist(double &dist);
DragStatus acquireDist(double &dist, const AcGePoint3d& basePnt);
DragStatus acquirePoint(AcGePoint3d&);
DragStatus acquirePoint(AcGePoint3d&, const AcGePoint3d&basePnt);
注意:不能使用acedXXX函數
AcEdJig:其它函數
const char* keywordList();
void setKeywordList(const char*);
const char* dispPrompt();
void setDispPrompt(const char*, ...);
AcEdJig::CursorType specialCursorType();
void setSpecialCursorType(CursorType);
AcEdJig::UserInputControls userInputControls();
void setUserInputControls(AcEdJig::UserInputControls);
例2:動態(tài)生成自定義實體
用向導生成或手工書寫
向導生成的AcEdJig派生類有錯:
頭文件中除去ACRX_DECLARE_MEMBERS
CPP文件中除去ACRX_CONS_DEFINE_MEMBERS
練習
自定義實體
具有N條邊的多邊形
畫出多邊形及外接圓
可輸入邊數N和外接圓半徑
動態(tài)創(chuàng)建
在創(chuàng)建過程中顯示圖形
在創(chuàng)建過程中顯示并可修改尺寸(選作)
雙擊修改
屬性頁
優(yōu)點:
可批量修改多個實體的屬性
操作步驟少
與ACAD的已有操作更加一致
缺點:
實現有點復雜
用戶操作習慣問題
生成工程
標準ATL工程
生成ATL類
派生
接口
IDL
DBX中實體類中:
頭文件:
static bool s_bHasClsid;
static CLSID s_clsid;
實現:
initCLSID()
getClassID
屬性名稱及分組
GetDisplayName
GetCategoryName
ShowProperty
預定義值
GetPredefinedStrings
GetPredefinedValue
顯示對話框
MapPropertyToPage
IOPMPropertyDialog
字典
字典內可保存多個從AcDbObject派生的對象
可用于保存全局變量,選項設置
AcDbDictionary *pNameDict;
AcDbDictionary *pNameList;
pDb->getNamedObjectsDictionary(pNameDict,AcDb::kForWrite);
if (pNameDict->getAt("TYSOFTHNBMCAD_DICT",(AcDbObject*&)pNameList, AcDb::kForWrite) == Acad::eKeyNotFound)
{
pNameList = new AcDbDictionary;
AcDbObjectId DictId;
pNameDict->setAt("TYSOFTHNBMCAD_DICT", pNameList, DictId);
}
pNameDict->close();
///打開或創(chuàng)建控制信息對象
AcDbObjectId objId;
HNBMDictItem *pDictItem;
if((pNameList->getAt("TYSOFTHNBMCAD_DICT_ITEM", objId))
== Acad::eKeyNotFound)
{
pDictItem = new HNBMDictItem;
Acad::ErrorStatus err=pNameList->setAt("TYSOFTHNBMCAD_DICT_ITEM", pDictItem, objId);
if(err!=Acad::eOk)
{
acutPrintf("\nerror in set archinfo!");
delete pDictItem;
pNameList->close();
return;
}
pDictItem->close();
}
pNameList->close();
AcDbDictionary *pNameDict;
AcDbDictionary *pNameList;
pDb->getNamedObjectsDictionary(pNameDict,AcDb::kForRead);
if (pNameDict->getAt("TYSOFTHNBMCAD_DICT",(AcDbObject*&)pNameList,
AcDb::kForRead) == Acad::eKeyNotFound)
{
pNameDict->close();
return NULL;
}
pNameDict->close();
AcDbObjectId objId;
HNBMDictItem *pDictItem;
if((pNameList->getAt("TYSOFTHNBMCAD_DICT_ITEM", objId))== Acad::eKeyNotFound)
{
pNameList->close();
return NULL;
}
pNameList->close();
if (acdbOpenObject((AcDbObject*&)pDictItem, objId,AcDb::kForRead) == Acad::eOk)
{
return pDictItem;
}
層
AcDbLayerTable *pLayerTable;
es=pDB->getSymbolTable(pLayerTable, AcDb::kForWrite);
if(es!=Acad::eOk)
{
pLinetypeTable->close();
return;
}
if(!pLayerTable->has("木作線(RoomLine)"))
{
pLayerTableRecord =new AcDbLayerTableRecord;
pLayerTableRecord->setName("木作線(RoomLine)");
pLayerTableRecord->setIsFrozen(false);
pLayerTableRecord->setIsOff(false);
pLayerTableRecord->setIsLocked(false);
pLayerTableRecord->setVPDFLT(false);
color.setColorIndex(3);
pLayerTableRecord->setColor(color);
pLinetypeTable->getAt("Continuous", LinetypeId);
pLayerTableRecord->setLinetypeObjectId(LinetypeId);
pLayerTableRecord->setLineWeight(AcDb::kLnWtByLwDefault);
pLayerTable->add(pLayerTableRecord);
pLayerTableRecord->close();
}
pLayerTable->close();
線型
pDB->loadLineTypeFile("DASHED", "acad.lin");//虛線
pDB->loadLineTypeFile(“CENTER”, “acad.lin”);//中心線
AcDbLinetypeTable *pLinetypeTable=NULL;
Acad::ErrorStatus es=pDB->getSymbolTable(pLinetypeTable, AcDb::kForRead);
if(es!=Acad::eOk)
return;
AcDbLayerTable *pLayerTable;
es=pDB->getSymbolTable(pLayerTable, AcDb::kForRead);
if(es!=Acad::eOk)
{
pLinetypeTable->close();
return;
}
AcDbObjectId LinetypeId;
pLinetypeTable->getAt("CENTER", LinetypeId);
pLineTypeTable->close();
文字樣式
AcDbTextStyleTable *pTextStyleTable=NULL;
Acad::ErrorStatus es=pDB->getSymbolTable(pTextStyleTable, AcDb::kForWrite);
if(es==Acad::eOk)
{
if(!pTextStyleTable->has("宋體-35"))
{
AcDbTextStyleTableRecord *pTextStyleTableRecord=new AcDbTextStyleTableRecord;
pTextStyleTableRecord->setName("宋體-35");
pTextStyleTableRecord->setFont("宋體", FALSE, FALSE, GB2312_CHARSET, DEFAULT_PITCH|FF_ROMAN);
pTextStyleTableRecord->setTextSize(3.5);
pTextStyleTableRecord->setXScale(0.8);
pTextStyleTable->add(pTextStyleTableRecord);
pTextStyleTableRecord->close();
}
if(!pTextStyleTable->has("HZ-35"))
{
AcDbTextStyleTableRecord *pTextStyleTableRecord=new AcDbTextStyleTableRecord;
pTextStyleTableRecord->setName("HZ-35");
pTextStyleTableRecord->setFileName("txt.shx");
pTextStyleTableRecord->setBigFontFileName("hztxt.shx");
pTextStyleTableRecord->setTextSize(3.5);
pTextStyleTableRecord->setXScale(0.8);
Acad::ErrorStatus es=pTextStyleTable->add(pTextStyleTableRecord);
pTextStyleTableRecord->close();
}
pTextStyleTable->close();
}
擴展數據
XData 容量受限制,只能存儲<=16K
AcDbObject::xData ()
AcDbObject::setXData()
(entget( car ( entsel))' ("*") )
封裝類:AcXdLocalVar
XRecord 容量不受限制
本質上沒有區(qū)別,存貯的都是resbuf結構的鏈表
如果對象是自定義實體,存儲非圖形數據也可以作為該實體對象的屬性存儲起來
XDATA舉例
(-3 ("INTECAD_HUST_CAD_CENTER" (1000 .
"BILLITEM") (1002 . "{") (1000 . "index") (1070 . 1) (1000 . "code") (1000 .
"C5A") (1000 . "name") (1000 . "E5A") (1000 . "quantity") (1000 . "G5A") (1000
. "lineblock") (1005 . "0") (1000 . "circle") (1005 . "21B") (1002 . "}") (1000
. "OBJECT") (1002 . "{") (1000 . "OBJECTID") (1000 . "BILLITEM") (1002 . "}"))))
為一鏈表,表頭為RegAppName,每一節(jié)點為一resbuf的結構,此結構為聯合數據結構,可存字符串,整數等類型
struct resbuf *pRb, *pTemp;
pRb = pObj->xData("architech_3d_code";);
if (pRb != NULL)
{
// If xdata is present, then walk to the end of the list.
for (pTemp = pRb; pTemp->rbnext != NULL; pTemp = pTemp->rbnext)
;
}
else
{
//以調用過acdbRegApp(“architech_3d_code”);
pRb = acutNewRb(AcDb::kDxfRegAppName);
pTemp = pRb;
pTemp->resval.rstring = (TCHAR*) new TCHAR[GetArchitechCodeName().GetLength() + 1];
_tcscpy(pTemp->resval.rstring, GetArchitechCodeName());
}
// Add user-specified std::TSTDSTRING to the xdata.
pTemp->rbnext = acutNewRb(AcDb::kDxfXdAsciiString);
pTemp = pTemp->rbnext;
pTemp->resval.rstring = (TCHAR*) new TCHAR[_tcslen(resString) + 1];
_tcscpy(pTemp->resval.rstring, resString);
// The following code shows the use of upgradeOpen() to change the entity from read to write.
pObj->upgradeOpen();
pObj->setXData(pRb);
acutRelRb(pRb);
XRecord創(chuàng)建
創(chuàng)建對象的擴展字典
AcDbObject::createExtensionDictionary();
AcDbObjectId AcDbObject::extensionDictionary();
生成AcDbXrecord并加入字典
AcDbXrecord *pXrec = new AcDbXrecord
acdbOpenObject(pDict, dictObjId, AcDb::kForWrite);
pDict->setAt("ASDK_XREC1", pXrec, xrecObjId);
用鏈表填充AcDbXrecord
pXrec->setFromRbChain(*head);
反應器
非持久性(transient Reactor)
數據庫反應器:AcDbDatabaseReactor
文檔反應器:AcApDocManagerReactor
其它
持久性(persistent Reactor)
數據庫中的對象之間
區(qū)別:是否能保存到數據庫中
持久反應器-建立
TYTriangle *pTriangle=new TYTriangle;
AcDbObjectId TriangleId;
AppendEntityToDb(pTriangle, NULL, &TriangleId);
pTriangle->close();
AcDbLine *pL=new AcDbLine(AcGePoint3d(0, 50, 0), AcGePoint3d(100, 50, 0));
AppendEntityToDb(pL);
pL->addPersistentReactor(TriangleId);
pL->close();
持久反應器-事件處理
void TYTriangle::modified (const AcDbObject* dbObj)
{
if(dbObj->isKindOf(AcDbLine::desc()))
{
AcDbLine *pLine=AcDbLine::cast(dbObj);
AcGeVector3d dir=pLine->startPoint()-pLine->endPoint();
double dblAngle=AcGeVector3d::kXAxis.angleTo(dir, AcGeVector3d::kZAxis);
Adesk::Boolean kWritable;
Acad::ErrorStatus es=upgradeFromNotify(kWritable);
if(es==Acad::eOk)
{
if(isWriteEnabled())
{
SetStartAngle(dblAngle);
}
downgradeToNotify(kWritable);
}
}
}
AutoCAD二次開發(fā)特點總結
ObjectARX:面向對象,功能強大,事實上的工業(yè)標準(類似者:ZRX,CRX)
學習材料豐富,代碼多,開發(fā)人員多,交流方便,入門容易
市場需求大
進入門檻低
是用于學習和練習C++和CAD開發(fā)的不錯選擇
~完~
謝謝各位!培訓ppt課件模板:這是培訓ppt課件模板,包括了文章背景知識,認字識詞朗誦,課文賞析,拓展訓練/分組練習等內容,歡迎點擊下載。
幼兒教師師德培訓ppt1:這是幼兒教師師德培訓ppt1,包括了引言,幼兒園教師師德現狀,幼兒園師德建設存在的問題,原因分析,對策建議等內容,歡迎點擊下載。
釘釘培訓ppt:這是釘釘培訓ppt,包括了釘釘軟件介紹,釘釘常用功能,公司啟用釘釘考勤操作指南,公司啟用釘釘時間等內容,歡迎點擊下載。