zoukankan      html  css  js  c++  java
  • ObjectArx的一次常用方法

    1.画一条直线

        static void ArxProject1_DrawLine(void)
        {
    
            
            //定义两点确定一条直线
            AcGePoint3d ptStart( 0 , 0 , 0);
            AcGePoint3d ptEnd( 100 , 100 , 0);
            AcDbLine* lnNew = new AcDbLine( ptStart , ptEnd);
            
         //获取当前图形数据库 AcDbBlockTable
    * pBlockTable = NULL; acdbHostApplicationServices()->workingDatabase()->getBlockTable(pBlockTable , AcDb::kForWrite); AcDbBlockTableRecord* pBlockTableRecord = NULL; pBlockTable->getAt(ACDB_MODEL_SPACE , pBlockTableRecord , AcDb::kForWrite);      
         //插入当前的图形数据库 AcDbObjectId lnId; pBlockTableRecord
    ->appendAcDbEntity( lnId , lnNew);     
         //关闭对象 lnNew
    ->close(); pBlockTableRecord->close(); pBlockTable->close(); }

    2.画一段圆弧

        static void ArxProject1_DrawArc(void)
        {
            //三点创建一个圆弧
            AcGePoint2d ptStartPoint( 0 , 100 );
            AcGePoint2d ptEndPoint( 0 , 100 );
            AcGePoint2d ptCenterPoint(0 , 0);
    
            AcGeVector2d vecStart(ptStartPoint.x - ptCenterPoint.x ,  ptStartPoint.y - ptCenterPoint.y);
            AcGeVector2d vecEnd(ptEndPoint.x - ptCenterPoint.x ,  ptEndPoint.y - ptCenterPoint.y);
            double StartAng = vecStart.angle();
            double EndAng = vecEnd.angle();
            
            AcGePoint3d pt( 0 , 0, 0);
            AcGeVector3d vec( 0 , 0 ,1);
            AcDbArc* Acr = NULL;
            Acr = new AcDbArc(pt ,vec ,  100, StartAng , EndAng);
    
            AcDbBlockTable* pBlockTable = NULL;
            ErrorStatus es =  acdbHostApplicationServices()->workingDatabase()->getBlockTable(pBlockTable , AcDb::kForWrite);
    
            AcDbBlockTableRecord* pBlockTableRecord = NULL;
            es = pBlockTable->getAt(ACDB_MODEL_SPACE , pBlockTableRecord,  AcDb::kForWrite);
            
            AcDbObjectId oid;
            es = pBlockTableRecord->appendAcDbEntity(oid , Acr);
    
            Acr->close();
            pBlockTableRecord->close();
            pBlockTable->close();
    
        }

    3.创建一个块,并把它插入到当前的模型空间

        static void ArxProject1_CreateNewBlock(void)
        {
            // Add your code for command ArxProject1._CreateNewBlock here
            ErrorStatus es ;
            
            AcDbBlockTable* pBlockTable = NULL;
            acdbHostApplicationServices()->workingDatabase()->getBlockTable(pBlockTable , AcDb::kForWrite);
    
            AcDbBlockTableRecord* pBlockTableRecord = new AcDbBlockTableRecord();
            pBlockTableRecord->setName(_T("Hest"));
            
            AcDbObjectId BlockTableOid;
            pBlockTable->add(BlockTableOid , pBlockTableRecord);
    
            AcDbPolyline* pPloyLine= new AcDbPolyline();
            AcGePoint2d pt1(0 , 0);
            AcGePoint2d pt2(100,200);
            pPloyLine->addVertexAt( 0 , pt1);;
            pPloyLine->addVertexAt( 1 , pt2);
            AcDbObjectId oid;
            pBlockTableRecord->appendAcDbEntity(oid , pPloyLine);
    
            pPloyLine->close();
            pBlockTableRecord->close();
            pBlockTable->close();
        }
    
        // - ArxProject1._BlockInsert command (do not rename)
        static void ArxProject1_BlockInsert(void)
        {
            // Add your code for command ArxProject1._BlockInsert here
            AcDbBlockTable* pBlockTable = NULL;
            acdbHostApplicationServices()->workingDatabase()->getBlockTable(pBlockTable , AcDb::kForRead);
            if (!pBlockTable->has(_T("Hest")))
            {
                acutPrintf(_T("不存在块Hest"));
                pBlockTable->close();
                return;
            }
    
            ads_point pt;
            if (acedGetPoint( NULL , _T("
    请输入插入点") , pt) != RTNORM)
            {
                pBlockTable->close();
                return;
            }
            
            AcGePosition3d pt3d = asPnt3d(pt); 
            AcDbObjectId oid;
            pBlockTable->getAt(_T("Hest") , oid );
            AcDbBlockReference* pBlockRef = new AcDbBlockReference( pt3d , oid);
    
            AcDbBlockTableRecord* pBlockTableRecord = NULL;
            pBlockTable->getAt(ACDB_MODEL_SPACE , pBlockTableRecord , AcDb::kForWrite);
            AcDbObjectId refid;
            pBlockTableRecord->appendAcDbEntity(refid , pBlockRef);
    
            pBlockRef->close();
            pBlockTableRecord->close();
            pBlockTable->close();
        }

    4.创建一个新的图层

        static void ArxProject1_CreateNewBlock(void)
        {
            // Add your code for command ArxProject1._CreateNewBlock here
            ErrorStatus es ;
            
            AcDbBlockTable* pBlockTable = NULL;
            acdbHostApplicationServices()->workingDatabase()->getBlockTable(pBlockTable , AcDb::kForWrite);
    
            AcDbBlockTableRecord* pBlockTableRecord = new AcDbBlockTableRecord();
            pBlockTableRecord->setName(_T("Hest"));
            
            AcDbObjectId BlockTableOid;
            pBlockTable->add(BlockTableOid , pBlockTableRecord);
    
            AcDbPolyline* pPloyLine= new AcDbPolyline();
            AcGePoint2d pt1(0 , 0);
            AcGePoint2d pt2(100,200);
            pPloyLine->addVertexAt( 0 , pt1);;
            pPloyLine->addVertexAt( 1 , pt2);
            AcDbObjectId oid;
            pBlockTableRecord->appendAcDbEntity(oid , pPloyLine);
    
            pPloyLine->close();
            pBlockTableRecord->close();
            pBlockTable->close();
        }
    
        // - ArxProject1._BlockInsert command (do not rename)
        static void ArxProject1_BlockInsert(void)
        {
            // Add your code for command ArxProject1._BlockInsert here
            AcDbBlockTable* pBlockTable = NULL;
            acdbHostApplicationServices()->workingDatabase()->getBlockTable(pBlockTable , AcDb::kForRead);
            if (!pBlockTable->has(_T("Hest")))
            {
                acutPrintf(_T("不存在块Hest"));
                pBlockTable->close();
                return;
            }
    
            ads_point pt;
            if (acedGetPoint( NULL , _T("
    请输入插入点") , pt) != RTNORM)
            {
                pBlockTable->close();
                return;
            }
            
            AcGePosition3d pt3d = asPnt3d(pt); 
            AcDbObjectId oid;
            pBlockTable->getAt(_T("Hest") , oid );
            AcDbBlockReference* pBlockRef = new AcDbBlockReference( pt3d , oid);
    
            AcDbBlockTableRecord* pBlockTableRecord = NULL;
            pBlockTable->getAt(ACDB_MODEL_SPACE , pBlockTableRecord , AcDb::kForWrite);
            AcDbObjectId refid;
            pBlockTableRecord->appendAcDbEntity(refid , pBlockRef);
    
            pBlockRef->close();
            pBlockTableRecord->close();
            pBlockTable->close();
        }

    5.插入一个外部的dwg文件,以块的方式

        static void ArxProject1_InsertDwg(void)
        {
            // Add your code for command ArxProject1._InsertDwgB here
            AcDbDatabase* pNewDb = new AcDbDatabase(Adesk::kFalse);
            AcApDocument* pcurDoc = NULL;
            pcurDoc = curDoc();
            if (pcurDoc == NULL)
            {
                assert(FALSE);
                return;
            }
            acDocManager->lockDocument(pcurDoc);
            Acad::ErrorStatus es;
            es = pNewDb->readDwgFile(_T("D://测试数据//528500-2524250-250-250.dwg")  , _SH_DENYNO , FALSE);
            if (es != ErrorStatus::eOk) 
            {
                acutPrintf(_T("Read Dwg fail"));
                return ;
            }
            AcDbDatabase* pCurDb = acdbHostApplicationServices()->workingDatabase();
            AcDbObjectId oid;
            es  = pCurDb->insert(oid , _T("InsertDwg") , pNewDb ,true);
            if (es != ErrorStatus::eOk)
            {
                assert(FALSE);
                return;
            }
            
            AcDbBlockReference* pRef = new AcDbBlockReference();
            pRef->setBlockTableRecord(oid);
            AcDbBlockTable* pBolck = NULL;
            pCurDb->getBlockTable(pBolck , AcDb::kForWrite);
            AcDbBlockTableRecord* pBolckRecord = NULL;
            pBolck->getAt(ACDB_MODEL_SPACE , pBolckRecord , AcDb::kForWrite);
            AcDbObjectId refid;
            pBolckRecord->appendAcDbEntity(refid , pRef);
            pRef->close();
            pRef = NULL;
            pBolck->close();
            pBolck = NULL;
            pBolckRecord->close();
            pBolckRecord = NULL;
            acDocManager->unlockDocument(pcurDoc);
        
        }

    6.插入一张图片作为外部参照

        static void ArxProject1_InsertImg(void)
        {
                CString strImgPath = _T("C:\opencv\samples\cpp\tutorial_code\images\yellowball.jpg");
                AcDbObjectId oid;
                //insertIMGFile( oid , _T("0") , strImgPath , _T("yellowball") , AcGePoint2d( 0 , 0 ) , AcGePoint2d( 100 , 100));
                InsPic(strImgPath);
                return ;
    
        }
            
        static bool InsPic(CString strPath)
        {    
            #if _MSC_VER >= 1600
            if (!acrxDynamicLinker->loadModule(_T("acISMobj19.dbx"), true))
            {
                acutPrintf(_T("无法加载acISMobj19.dbx
    "));
            }
            #elif _MSC_VER >= 1500
            if (!acrxDynamicLinker->loadModule(_T("acISMobj18.dbx"), true))
            {
                acutPrintf(_T("无法加载acISMobj18.dbx
    "));
            }
            #elif _MSC_VER >= 1400
            //一定要加载此文件,否则加载影像图时会失败
            if (!acrxDynamicLinker->loadModule(_T("acISMobj17.dbx"), true))
            {
                acutPrintf(_T("无法加载acISMobj17.dbx
    "));
            }
            #elif _MSC_VER >= 1300
            if (!acrxDynamicLinker->loadModule(_T("acISMobj16.dbx"), true))
            {
                acutPrintf(_T("无法加载acISMobj16.dbx
    "));
            }
            #else
            if (!acrxDynamicLinker->loadModule(_T("acISMobj15.dbx"), true))
            {
                acutPrintf(_T("无法加载acISMobj15.dbx
    "));
            }
            #endif
            AcDbObjectId imgDicId =
                    AcDbRasterImageDef::imageDictionary(acdbHostApplicationServices()
                    ->workingDatabase());
    
            Acad::ErrorStatus es;
            if (imgDicId.isNull())
            {
                    es = AcDbRasterImageDef::createImageDictionary(acdbHostApplicationServices()
                            ->workingDatabase(), imgDicId);
            }
    
            AcDbDictionary *pDic = NULL;
            es = acdbOpenObject((AcDbObject*&)pDic, imgDicId, AcDb::kForWrite);
    
            AcDbRasterImageDef *pImgDef = new AcDbRasterImageDef;
    
            es = pImgDef->setSourceFileName(strPath);
            es = pImgDef->load();
    
            CString strImg;
            es = AcDbRasterImageDef::suggestName(pDic, strPath, strImg.GetBuffer(256));
    
            AcDbObjectId entId;
    
            bool bHas = pDic->has(strImg);
    
            if (!bHas)
            {
                    es = pDic->setAt(strImg, pImgDef, entId);
            }
    
            else
            {
                    pDic->close();
                    delete pImgDef;
                    return false;
            }
            pDic->close();
            pImgDef->close();
    
            AcDbRasterImage *pImg = new AcDbRasterImage;
    
             AcGeVector3d uVec,vVec; 
             uVec.set(50, 0,0);          
             uVec.set(0, 150, 0);          
             AcGePoint3d pt(100, 100, 0);  
            BOOL bSet = pImg->setOrientation(pt, uVec, vVec);
            pImg->setFade(5);
            pImg->setContrast(9);
            
    
            es = pImg->setImageDefId(entId);
            
            AcDbBlockTable* pBlockTable = NULL;
            es = acdbHostApplicationServices()->workingDatabase()->getBlockTable( pBlockTable , AcDb::kForWrite);
            if(es != ErrorStatus::eOk)
                return FALSE;
    
            AcDbBlockTableRecord* pBlockTableRecord = NULL;
            es = pBlockTable->getAt(ACDB_MODEL_SPACE , pBlockTableRecord , AcDb::kForWrite);
            if(es != ErrorStatus::eOk)
                return false;
    
            AcDbObjectId oid;
            es = pBlockTableRecord->appendAcDbEntity(oid , pImg);
            if(es != ErrorStatus::eOk)
                return false;
            AcDbObjectId entIdx  = pImg->objectId();
    
            pImg->close();
            return true;
    }

    7.插入dwg作为外部参照

        static void ArxProject1_Addxref(void)
        {
            // Add your code for command ArxProject1._Addxref here
            AcDbObjectId oid;
            ACHAR lpszBlockName[255];
            ACHAR* lpszFileName = _T("C:\XREGER.dwg");
            ErrorStatus es = acedXrefAttach( lpszFileName , lpszBlockName);
            if (es != ErrorStatus::eOk)
            {
                acutPrintf(_T("添加Xref失败!
    "));
            }
        }
  • 相关阅读:
    汇编学习笔记(3)[bx]和loop
    C++面试题-概念篇(一)
    命名空间的冷思考
    背包以及装备模块封装的思考
    虚函数,纯虚函数以及虚继承
    组件化开发在游戏开发当中的思考和汇总
    Netty和MINA之间的比较思考
    学习C++与Java之间的区别
    C++服务器年前总结
    C++Builder如何将当前时间与字符串相互转换
  • 原文地址:https://www.cnblogs.com/luzhiw/p/4043723.html
Copyright © 2011-2022 走看看