用RoundRect函数画圆角矩形,但出现了怪的现象……

xiongzai 2005-05-21 05:52:17
Option Explicit

Private Declare Function RoundRect Lib "GDI32" (ByVal hDC As Long, ByVal x1 As Long, ByVal y1 As Long, ByVal x2 As Long, ByVal y2 As Long, ByVal x3 As Long, ByVal y3 As Long) As Long

Dim x1, y1, x2, y2

Private Sub Picture1_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single)
x1 = X
y1 = Y
x2 = X
y2 = Y
Picture1.ScaleMode = 3
Picture1.FillColor = vbBlue
Picture1.FillStyle = 0
End Sub

Private Sub Picture1_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)
x2 = X
y2 = Y
End Sub

Private Sub Picture1_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single)
Picture1.ForeColor = vbRed
RoundRect Picture1.hDC, x1, y1, x2, y2, 10, 10 '调用API函数进行绘图
End Sub
'---------------------------------------------------------
'这什么画第一个的时候总是从右下角跑出来的?
'第二个开始就正常了……
'搞了半天都不明所以。
...全文
215 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiongzai 2005-05-21
  • 打赏
  • 举报
回复
谢了……
搞定
laviewpbt 2005-05-21
  • 打赏
  • 举报
回复
把这句 Picture1.ScaleMode = 3 方在 x1 = X前面就可以了

造成你说的那中情况的原因就是因为单位不一致。

1,486

社区成员

发帖
与我相关
我的任务
社区描述
VB API
社区管理员
  • API
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧