找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 817|回复: 8

[求助]:斑竹请进,问题难了我好几天~~

[复制链接]
发表于 2003-8-20 18:54:24 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
斑竹那有没有 AcGeInterval 求交、并、差的例子,我怎么求出来的结果始终没有有效值???
如果有话请发往 amyandjans@sohu.com 谢谢了~~~
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2003-8-20 19:00:17 | 显示全部楼层
最初由 jans_boy 发布
[B]斑竹那有没有 AcGeInterval 求交、并、差的例子,我怎么求出来的结果始终没有有效值???
如果有话请发往 amyandjans@sohu.com 谢谢了~~~ [/B]


把你求交、并、差的代码帖出来,这样大家也好帮你分析问题的原因!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2003-8-21 08:44:14 | 显示全部楼层
CView *pView = acedGetAcadDwgView();

        if(pView == NULL) return;

        CRect rect;
        pView->GetClientRect (&rect);

        ads_name ssname;

        acedDwgPoint ptToLe;
        acedDwgPoint ptBoRi;

        acedCoordFromPixelToWorld(rect.TopLeft (), ptToLe);
        acedCoordFromPixelToWorld(rect.BottomRight (), ptBoRi);

        if(acedSSGet("W", ptToLe, ptBoRi, NULL, ssname) != RTNORM) return;

        long length;
        if(acedSSLength(ssname, &length) == RTNORM)
        {
                AcGeVoidPointerArray curveSet;
                actrTransactionManager->startTransaction();

                for(int i=0; i<length; i++)
                {
                        ads_name   tempName;
                        AcDbObjectId tempId;

                        if(acedSSName(ssname, i, tempName) == RTNORM)
                        {
                                acdbGetObjectId(tempId, tempName);
                                AcDbEntity *pEnt = NULL;
                                if(actrTransactionManager->getObject((AcDbObject *&)pEnt, tempId, AcDb::kForRead) == Acad::eOk)
                                {
                                        addToPtrArray(pEnt, curveSet);        //此处返回的是转换后的 AcGeCurve 数组
                                }
                                if(pEnt != NULL) pEnt->close();
                        }
                }

                int geLength = curveSet.length();
                if(geLength < 2) return;

                AcGeInterval otherInter;
                ((AcGeCurve3d *)curveSet[0])->getInterval(otherInter);

                for(int n=1; n<geLength; n++)
                {
                        AcGeInterval resultInter;
                        AcGeInterval tempInter;
                        ((AcGeCurve3d *)curveSet[n])->getInterval(tempInter);

                        double std; double end;
                        otherInter.getBounds(std, end);
                        acutPrintf("\n 0 >> start: %lf, end: %lf", std, end);

                        tempInter.getBounds(std, end);
                        acutPrintf("\n 1 >> start: %lf, end: %lf", std, end);

                        Adesk::Boolean er = otherInter.intersectWith(tempInter, resultInter);

                        if(er)
                        {
                                resultInter.getBounds(std, end);
                                acutPrintf("\n result >> start: %lf, end: %lf", std, end);
                                acutPrintf("\n insertsectWidth is %s", "TRUE");
                        }
                        else
                                acutPrintf("\n insertsectWidth is %s", "FALSE");
                       
                        otherInter = resultInter;
                }
        }
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-8-21 08:55:14 | 显示全部楼层
最初由 jans_boy 发布
[B]CView *pView = acedGetAcadDwgView();

        if(pView == NULL) return;

        CRect rect;
        pView->GetClientRect (&rect);

        ads_name ssname;

        acedDwgPoint ptToLe;
        acedDwgPoint ptBoRi;

        acedCoordFro... [/B]


把你的代码修改一下,现在还有语法错误呢!你看看下边那句:
最起码你要让大家能够编译通过吧!这样才好帮你找问题所在啊!!

for(int i=0; i {
ads_name tempName;
AcDbObjectId tempId;
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2003-8-21 09:00:53 | 显示全部楼层
工程附件
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-8-21 09:18:41 | 显示全部楼层
最初由 jans_boy 发布
[B]工程附件 [/B]


说说你的这个工程主要完成一个什么功能,最好把你的编程思路和大家说说!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2003-8-21 09:32:38 | 显示全部楼层
现在只是测试 AcGeInterval 类的使用,就是想得到视图可见的两个实体的交集,但是在调试的过程中,交集的 AcGeInterval::getBounds() 函数返回值总是无效的,例如:

otherInter.getBounds() 返回的范围是 0, 134.56
tempInter.getBounds() 返回的范围是 0, 234.34

调用 otherInter.intersectWith(tempInter, resultInter);

resultInter.getBounds() 返回值却是 0, 134.56

而两曲线肯定是相交的,这让我百思不得其解,难道是我理解错了,我理解 resultInter.getBounds()返回的数据就是两条曲线的相交点的参数 param 值。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-2 17:36:05 | 显示全部楼层
是呀,怎么不对,望斑竹指教
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-6 13:20:59 | 显示全部楼层
期待
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-22 05:27 , Processed in 0.445517 second(s), 49 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表