乐筑天下

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

[讨论]矩阵

[复制链接]

72

主题

2726

帖子

9

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3014
发表于 2004-6-15 12:51:00 | 显示全部楼层 |阅读模式
才开始研究矩阵,发个矩阵实现移动、旋转、缩放的例子
三维的矩阵旋转还没想通,应该怎么实现?
Public Sub Test()
Dim dot(2) As Double
Dim pnt(2) As Double
pnt(0) = 2
pnt(1) = 3
pnt(2) = 3
ScaleByTransMat ThisDrawing.ModelSpace(0), pnt, 10
End Sub
Public Sub RotateByTransMat(ByVal Obj As AcadEntity, ByVal BasePoint As Variant, ByVal Angle As Double)
                         Dim pTransMat(3, 3) As Double
                         Dim pAngle As Double, pDistance As Double
                         pAngle = ThisDrawing.Utility.AngleFromXAxis(pnt, BasePoint)
                         pDistance = Sqr(BasePoint(0) ^ 2 + BasePoint(1) ^ 2)
                         pTransMat(0, 0) = Cos(Angle): pTransMat(0, 1) = -Sin(Angle): pTransMat(0, 3) = BasePoint(0) - Cos(pAngle + Angle) * pDistance
                         pTransMat(1, 0) = Sin(Angle): pTransMat(1, 1) = Cos(Angle): pTransMat(1, 3) = BasePoint(1) - Sin(pAngle + Angle) * pDistance
                         pTransMat(2, 2) = 1
                         pTransMat(3, 3) = 1
                         TestTrans pTransMat
                         Obj.TransformBy pTransMat
                         Obj.Update
End Sub
Public Sub ScaleByTransMat(ByVal Obj As AcadEntity, ByVal BasePoint As Variant, ByVal ScaleFactor As Double)
                         Dim pTransMat(3, 3) As Double
                         pTransMat(0, 0) = ScaleFactor: pTransMat(0, 3) = BasePoint(0) * (1 - ScaleFactor)
                         pTransMat(1, 1) = ScaleFactor: pTransMat(1, 3) = BasePoint(1) * (1 - ScaleFactor)
                         pTransMat(2, 2) = ScaleFactor: pTransMat(2, 3) = BasePoint(2) * (1 - ScaleFactor)
                         pTransMat(3, 3) = 1
                         TestTrans pTransMat
                         Obj.TransformBy pTransMat
                         Obj.Update
End Sub
Public Sub MoveByTransMat(ByVal Obj As AcadEntity, ByVal StartPoint As Variant, ByVal EndPoint As Variant)
                         Dim pTransMat(3, 3) As Double
                         pTransMat(0, 0) = 1: pTransMat(0, 3) = EndPoint(0) - StartPoint(0)
                         pTransMat(1, 1) = 1: pTransMat(1, 3) = EndPoint(1) - StartPoint(1)
                         pTransMat(2, 2) = 1: pTransMat(2, 3) = EndPoint(2) - StartPoint(2)
                         pTransMat(3, 3) = 1
                         TestTrans pTransMat
                         Obj.TransformBy pTransMat
                         Obj.Update
End Sub
Public Sub TestTrans(ByVal TransMat As Variant)
For i = 0 To 3
Debug.Print TransMat(i, 0) & "," & TransMat(i, 1) & "," & TransMat(i, 2) & "," & TransMat(i, 3)
Next i
End Sub
回复

使用道具 举报

6

主题

60

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
84
发表于 2004-6-15 14:11:00 | 显示全部楼层
可不可以生成个临时的块对象然后旋转后打碎呢?~~~~
是不是有些跑题~~~~
。。。。。。。。。。。。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-15 21:16 , Processed in 0.384104 second(s), 56 queries .

© 2020-2025 乐筑天下

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