乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 77|回复: 4

怎么在VBA循环中定义图层颜色啊

[复制链接]

29

主题

128

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
244
发表于 2010-6-4 11:15:00 | 显示全部楼层 |阅读模式
我编了个画纵断面的VBA,可是想在循环画地面线的时候,想利用循环语句为各种地面线赋予不同的图层并以颜色分开,但是执行结果都却是一个颜色。请高人指点,不胜感激。

'画地面线
   
    Dim point1() As Double
    ReDim point1(h)
    Dim t As Double
For l = 2 To 6
Set newLayer = ThisDrawing.Layers("l")
   ThisDrawing.ActiveLayer = newLayer
    newLayer.color = l  
point1(0) = jd(0)
point1(1) = jd(1) + (xlSheet.Cells(2, l).Value - min) / by * 1000 + 20
'point1(2) = 0
u = 3
For t = 1 To k - 2
If u
回复

使用道具 举报

25

主题

219

帖子

6

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
319
发表于 2010-6-4 14:38:00 | 显示全部楼层
Set newLayer = ThisDrawing.Layers("l")
加了“”,I不会变的啊。你的对象也都在一个层上吧!

回复

使用道具 举报

29

主题

128

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
244
发表于 2010-6-4 15:04:00 | 显示全部楼层
谢谢指点,我的意思是假如有6种地面线,循环绘制的时候自动新建6种地面线图层,并且每个图层颜色区别开。怎么处理,谢谢高人
回复

使用道具 举报

72

主题

2726

帖子

9

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3014
发表于 2010-6-4 18:35:00 | 显示全部楼层
ThisDrawing.Layers(CStr(l))
回复

使用道具 举报

29

主题

128

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
244
发表于 2010-6-6 14:54:00 | 显示全部楼层

谢谢lzh741206,我后来用数组分别给每个需要画的纵断面线赋予值,然后再语句中调用。谢谢你给的提示。


Dim varData(5) As Variant    '利用数组为纵断线设置图层提供基础
For i = 2 To 6
varData(i - 2) = xlSheet.Cells(1, i).Value
Next i

For l = 2 To 6
Set layObj = ThisDrawing.Layers.Add(varData(l - 2))
    ThisDrawing.ActiveLayer = Layers(varData(l - 2)) ' newLayer
    ActiveLayer.color = l
point1(0) = jd(0)
point1(1) = jd(1) + (xlSheet.Cells(2, l).Value - min) / by * 1000 + 15
'point1(2) = 0
u = 3
For t = 1 To k - 2
If u
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-1 12:45 , Processed in 0.946616 second(s), 62 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表