-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathScrollBox.ctl
323 lines (278 loc) · 10.1 KB
/
ScrollBox.ctl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
VERSION 5.00
Begin VB.UserControl ScrollBox
AutoRedraw = -1 'True
ClientHeight = 2550
ClientLeft = 0
ClientTop = 0
ClientWidth = 2925
LockControls = -1 'True
ScaleHeight = 170
ScaleMode = 3 'Pixel
ScaleWidth = 195
ToolboxBitmap = "ScrollBox.ctx":0000
Begin VB.Timer ScrollTimer
Enabled = 0 'False
Interval = 100
Left = 420
Top = 1980
End
Begin VB.PictureBox picText
AutoRedraw = -1 'True
BorderStyle = 0 '没有
CausesValidation= 0 'False
Height = 1725
Left = 180
ScaleHeight = 115
ScaleMode = 3 'Pixel
ScaleWidth = 173
TabIndex = 0
Top = 90
Visible = 0 'False
Width = 2595
End
End
Attribute VB_Name = "ScrollBox"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = True
Attribute VB_PredeclaredId = False
Attribute VB_Exposed = False
' 滚动框控件
' 版本: 1.5
' 作者: 赵畅
' 日期: 2003.4.19
Option Explicit
Private Declare Function BitBlt Lib "gdi32" (ByVal hDestDC As Long, ByVal X As Long, ByVal Y As Long, ByVal nWidth As Long, ByVal nHeight As Long, ByVal hSrcDC As Long, ByVal xSrc As Long, ByVal ySrc As Long, ByVal dwRop As Long) As Long
Public Enum eBackStyle
'透明 = 0
'不透明 = 1
bsTransparent = 0
bsOpaque = 1
End Enum
Public Enum eBorderStyle
'无边框 = 0
'有边框 = 1
bsNone = 0
bsFixed = 1
End Enum
Dim PosY As Single
'Dim MouseX As Single
Dim MouseY As Single
Dim MouseMoving As Boolean
'缺省属性值:
Const m_def_TextHeight = 100
'属性变量:
Dim m_TextHeight As Single
'事件声明:
Public Event ScrollUp(Position As Single)
Private Sub UserControl_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single)
If (Button And vbLeftButton) = vbLeftButton Then
Me.Scroll = False
Set UserControl.MouseIcon = HandDownCursor
Call SetCapture(UserControl.hWnd)
MouseY = Y
MouseMoving = True
End If
End Sub
Private Sub UserControl_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)
If (Button And vbLeftButton) = vbLeftButton And MouseMoving And GetCapture() = UserControl.hWnd Then
Call ScrollBy(MouseY - Y)
MouseY = Y
End If
End Sub
Private Sub UserControl_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single)
If (Button And vbLeftButton) = vbLeftButton And MouseMoving Then
Set UserControl.MouseIcon = HandUpCursor
Me.Scroll = True
MouseMoving = False
End If
End Sub
Private Sub ScrollTimer_Timer()
ScrollTimer.Enabled = False
RaiseEvent ScrollUp(PosY + ScaleHeight)
Call ScrollBy(1)
ScrollTimer.Enabled = True
End Sub
Private Sub ScrollBy(ByVal Position As Single)
On Error Resume Next
If Position < 1 Then Exit Sub
Call BitBlt(UserControl.hDC, 0, 0, ScaleWidth, ScaleHeight, picText.hDC, 0, PosY, SRCCOPY)
PosY = PosY + Position
If PosY > picText.ScaleHeight - UserControl.ScaleHeight Then
UserControl.Line (0, picText.ScaleHeight - PosY)-(UserControl.ScaleWidth, UserControl.ScaleHeight), Me.BackColor, BF
End If
If PosY > picText.ScaleHeight Then
PosY = -ScaleHeight
End If
Call UserControl.Refresh
End Sub
Private Sub UserControl_Initialize()
Call picText.Move(0, 0, ScaleWidth) ', ScaleHeight
Set UserControl.MouseIcon = HandUpCursor
UserControl.MousePointer = vbCustom
Call UserControl.Cls
End Sub
'为用户控件初始化属性
Private Sub UserControl_InitProperties()
m_TextHeight = m_def_TextHeight
End Sub
'从存贮器中加载属性值
Private Sub UserControl_ReadProperties(PropBag As PropertyBag)
On Error Resume Next
UserControl.BackColor = PropBag.ReadProperty("BackColor", &H8000000F)
picText.BackColor = PropBag.ReadProperty("BackColor", &H8000000F)
UserControl.Enabled = PropBag.ReadProperty("Enabled", True)
UserControl.BackStyle = PropBag.ReadProperty("BackStyle", 1)
UserControl.BorderStyle = PropBag.ReadProperty("BorderStyle", 0)
ScrollTimer.Enabled = PropBag.ReadProperty("Scroll", False)
ScrollTimer.Interval = PropBag.ReadProperty("Speed", 100)
picText.ForeColor = PropBag.ReadProperty("ForeColor", &H80000008)
m_TextHeight = PropBag.ReadProperty("TextHeight", m_def_TextHeight)
picText.CurrentX = PropBag.ReadProperty("CurrentX", 0)
picText.CurrentY = PropBag.ReadProperty("CurrentY", 0)
Call picText.Move(0, 0, ScaleWidth, m_TextHeight)
End Sub
'将属性值写到存储器
Private Sub UserControl_WriteProperties(PropBag As PropertyBag)
On Error Resume Next
Call PropBag.WriteProperty("BackColor", UserControl.BackColor, &H8000000F)
Call PropBag.WriteProperty("Enabled", UserControl.Enabled, True)
Call PropBag.WriteProperty("BackStyle", UserControl.BackStyle, 1)
Call PropBag.WriteProperty("BorderStyle", UserControl.BorderStyle, 0)
Call PropBag.WriteProperty("Scroll", ScrollTimer.Enabled, False)
Call PropBag.WriteProperty("Speed", ScrollTimer.Interval, 100)
Call PropBag.WriteProperty("ForeColor", picText.ForeColor, &H80000008)
Call PropBag.WriteProperty("TextHeight", m_TextHeight, m_def_TextHeight)
Call PropBag.WriteProperty("CurrentX", picText.CurrentX, 0)
Call PropBag.WriteProperty("CurrentY", picText.CurrentY, 0)
End Sub
'注意!不要删除或修改下列被注释的行!
'MappingInfo=UserControl,UserControl,-1,BackColor
Public Property Get BackColor() As OLE_COLOR
Attribute BackColor.VB_Description = "返回/设置对象中文本和图形的背景色。"
BackColor = UserControl.BackColor
End Property
Public Property Let BackColor(ByVal New_BackColor As OLE_COLOR)
UserControl.BackColor() = New_BackColor
picText.BackColor() = New_BackColor
PropertyChanged "BackColor"
End Property
'
'注意!不要删除或修改下列被注释的行!
'MappingInfo=UserControl,UserControl,-1,Enabled
Public Property Get Enabled() As Boolean
Attribute Enabled.VB_Description = "返回/设置一个值,决定一个对象是否响应用户生成事件。"
Enabled = UserControl.Enabled
End Property
Public Property Let Enabled(ByVal New_Enabled As Boolean)
UserControl.Enabled() = New_Enabled
PropertyChanged "Enabled"
End Property
'
'注意!不要删除或修改下列被注释的行!
'MappingInfo=UserControl,UserControl,-1,BackStyle
Public Property Get BackStyle() As eBackStyle
Attribute BackStyle.VB_Description = "指出 Label 或 Shape 的背景样式是透明的还是不透明的。"
BackStyle = UserControl.BackStyle
End Property
Public Property Let BackStyle(ByVal New_BackStyle As eBackStyle)
UserControl.BackStyle() = New_BackStyle
PropertyChanged "BackStyle"
End Property
'注意!不要删除或修改下列被注释的行!
'MappingInfo=UserControl,UserControl,-1,BorderStyle
Public Property Get BorderStyle() As eBorderStyle
Attribute BorderStyle.VB_Description = "返回/设置对象的边框样式。"
BorderStyle = UserControl.BorderStyle
End Property
Public Property Let BorderStyle(ByVal New_BorderStyle As eBorderStyle)
UserControl.BorderStyle() = New_BorderStyle
PropertyChanged "BorderStyle"
End Property
'注意!不要删除或修改下列被注释的行!
'MemberInfo=0
Public Function TextOut(Text As String)
picText.Print Text;
End Function
'注意!不要删除或修改下列被注释的行!
'MappingInfo=picText,picText,-1,Font
Public Property Get Font() As Font
Attribute Font.VB_Description = "返回一个 Font 对象。"
Attribute Font.VB_UserMemId = -512
Set Font = picText.Font
End Property
'注意!不要删除或修改下列被注释的行!
'MappingInfo=picText,picText,-1,Cls
Public Sub Cls()
Attribute Cls.VB_Description = "清除窗体、图像或图片框中在运行时生成的图形和文本。"
ScrollTimer.Enabled = False
Call UserControl.Cls
Call picText.Cls
Call UserControl.Refresh
PosY = -ScaleHeight
End Sub
''
'注意!不要删除或修改下列被注释的行!
'MappingInfo=ScrollTimer,ScrollTimer,-1,Enabled
Public Property Get Scroll() As Boolean
Attribute Scroll.VB_Description = "是否开始滚动,设计时不可用。"
Scroll = ScrollTimer.Enabled
End Property
Public Property Let Scroll(ByVal New_Scroll As Boolean)
If Not Ambient.UserMode Then
Call Err.Raise(387)
Else
ScrollTimer.Enabled() = New_Scroll
PropertyChanged "Scroll"
End If
End Property
'注意!不要删除或修改下列被注释的行!
'MappingInfo=ScrollTimer,ScrollTimer,-1,Interval
Public Property Get Speed() As Long
Attribute Speed.VB_Description = "滚动速度,数值越大速度越慢。"
Speed = ScrollTimer.Interval
End Property
Public Property Let Speed(ByVal New_Speed As Long)
ScrollTimer.Interval() = New_Speed
PropertyChanged "Speed"
End Property
'注意!不要删除或修改下列被注释的行!
'MappingInfo=picText,picText,-1,ForeColor
Public Property Get ForeColor() As OLE_COLOR
Attribute ForeColor.VB_Description = "返回/设置对象中文本和图形的前景色。"
ForeColor = picText.ForeColor
End Property
Public Property Let ForeColor(ByVal New_ForeColor As OLE_COLOR)
picText.ForeColor() = New_ForeColor
PropertyChanged "ForeColor"
End Property
'注意!不要删除或修改下列被注释的行!
'MemberInfo=12,0,0,100
Public Property Get TextHeight() As Single
Attribute TextHeight.VB_Description = "文本总体高度。"
TextHeight = m_TextHeight
End Property
Public Property Let TextHeight(ByVal New_TextHeight As Single)
m_TextHeight = New_TextHeight
Call picText.Move(0, 0, ScaleWidth, m_TextHeight)
PropertyChanged "TextHeight"
End Property
'注意!不要删除或修改下列被注释的行!
'MappingInfo=picText,picText,-1,CurrentX
Public Property Get CurrentX() As Single
Attribute CurrentX.VB_Description = "返回/设置下次 print 或 draw 方法的水平坐标。"
CurrentX = picText.CurrentX
End Property
Public Property Let CurrentX(ByVal New_CurrentX As Single)
picText.CurrentX() = New_CurrentX
PropertyChanged "CurrentX"
End Property
'注意!不要删除或修改下列被注释的行!
'MappingInfo=picText,picText,-1,CurrentY
Public Property Get CurrentY() As Single
Attribute CurrentY.VB_Description = "返回/设置下次 print 或 draw 方法的垂直坐标。"
CurrentY = picText.CurrentY
End Property
Public Property Let CurrentY(ByVal New_CurrentY As Single)
picText.CurrentY() = New_CurrentY
PropertyChanged "CurrentY"
End Property