找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1451|回复: 2

[求助]:Excel转cad问题(AddMText的控制)

[复制链接]
发表于 2006-12-31 22:47:30 | 显示全部楼层 |阅读模式

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

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

×
Excel单元格内容转到cad里面用的命令是

RetVal = object.AddMText(InsertionPoint, Width, Text)

在由插入点和边框宽度所定义的矩形中创建多行文字。

其中InsertionPoint

Variant[变体] (三元素双精度数组); 仅用于输入
多行文字边框的插入点。

对于多行文本来说有9个点,即左上、顶中、右上、左中、正中、右中、左下、底中、右下,

InsertionPoint好像是指的是左上这个点,能不能使得InsertionPoint=正中(或者其他点)呢?

我的目的是要水平居中同时垂直居中。

观看其他例子,现举其一:
     ElseIf xlRange.VerticalAlignment = xlCenter And xlRange.HorizontalAlignment = xlCenter Then
         mTextObj.AttachmentPoint = acAttachmentPointMiddleCenter
         tPt = ThisDrawing.Utility.PolarPoint(iPt, -1.5707963, rh / 2)
         tPt = ThisDrawing.Utility.PolarPoint(tPt, 0, rw / 2)
基本都是把插入点计算成表格的水平居中并且垂直居中的点的坐标,然后对齐正中点,使得文本放入表格居中。但是在cad2002以上TextObj.AttachmentPoint只是文本的附着点,不能象R14那样移动文本,必须通过计算InsertionPoint来控制文本的插入的对齐位置,多行文本的InsertionPoint如果必须是左上这个点,那么需要水平居中并且垂直居中的话,InsertionPoint就需要计算成
=(该单元格的高度-多行文本的高度)/2
问题是多行文本的高度如何计算呢?牵扯到行间距如何计算?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2007-1-19 18:06:28 | 显示全部楼层
顶呀
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-28 13:19 , Processed in 0.345433 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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