微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

教你如何用VB做控件*.ocx

教你如何用VB做控件*.ocx
一个控件有很多事件如:Click、MouseDown、MouseUp、MouseMove等。要触发这些事件都需要你加入代码。在控件的声明处加入Public Event Click()就表明该控件有一“Click”事件。自己编写的控件有什么事件就在声明处加几条事件


如今OCX控件在编程中已占领了很重要的地位,我们可以利用OCX控件完成一些相当复杂的编程操作.同时OCX 控件还有利于主程序的简单化、功能的重用、隐常程序实现细节、便于升级、传播方便等优点。现在我们可以利用VB 5.0方便的制作出自己的OCX控件供我们在编程中使用同时还可以把它送给你周围喜欢编程的朋友!

下面列出制作OCX控件的步骤:
一:新建OCX   打开VB 5.0选择新建工程在对话框中选择ActiveX 控件(如图一(map1.gif))打开后会见一空的文档这就是 OCX控件的初始界面。想看一看空OCX控件的效果吗?选择“添加工程”选中标准EXE,这时你就可以像调用其它控件一样在左边的工具栏里选择刚才新建的OCX控件图标放在标准的EXE文档中看一看有什么效果!(什么也没有!) 自然因为刚才的OCX文档是空的嘛(废话太多,数个痰盂向我飞来)!
二:创建界面
  一般我们用VB创建OCX控件都是在我们的控件里添加其它的控件来组合成一个完整的控件(也可以让它只完成某种算法)比如:你可以在上面添加一按钮、编辑框这时你再用第一部的方法看一看效果,是不是控件上多了一个按钮和一个编辑框。
三:OCX属性
  一个OCX控件有许多的属性,比如控件背景是否透明(BackStyle),控件是否可以获得焦点 (CanGetFocus)等。这些属性都可以在控件的“属性框”中找到。
四:添加事件
  一个控件有很多事件如:Click、MouseDown、MouseUp、MouseMove等。要触发这些事件都需要你加入代码。在控件的声明处加入Public Event Click()就表明该控件有一“Click”事件。自己编写的控件有什么事件就在声明处加几条事件。关于触发事件是使用“RaiseEvent”语句来完成的如:RaiseEvent 事件名(参数)。
五:用户属性
  一个控件应有许多属性用户设置如:控件的背景色、控件要显示的图形等。它们通常用Property Get和 Property Let两条语句来完成。前者表示给用户显示一个属性的值,后者表示用户设置一个属性的值。
六:保存属性和读取属性
  当属性用户更改后需要将该属性值保存,以便控件运行时读取更改后的属性值。它们分别用 ReadProperty和WriteProperty两种方法来完成。前者表示读取一个属性值,后者表示写入一个属性值。

  好了一个简单的OCX控件制作方法大概就需要以上几步就可完成。下面本人将编写一个简单的OCX控件供大家参考。此控件的功能是在控件中显示一个圆,当鼠标移到控件上的时候控件上的圆便会在鼠标不离开控件的前提下跟随鼠标移动。

  新建一OCX控件,将控件的BorderStyle属性改为1,再加入一SHAPE控件将其形状改为Circle(如图二(map2.gif)) 添加以下代码

VB code
  
  
Public Event Click() 注释:定义该控件要产生的事件 Dim CircleX As Integer ,CircleY As Integer Private Sub UserControl_Click()   RaiseEvent Click 注释:触发Click事件 End Sub Private Sub UserControl_Initialize()   CircleX = Shape1.Width / 2   CircleY = Shape1.Height / 2 End Sub Private Sub UserControl_MouseDown(Button As Integer ,Shift As Integer ,X As Single ,Y As Single )   Shape1.BackColor = RGB ( 0 , 0 , 255 ) End Sub Private Sub UserControl_MouseMove(Button As Integer ,Y As Single ) Dim MoveX As Integer ,MoveY As Integer   MoveX = X - Shape1.Width / 2   MoveY = Y - Shape1.Height / 2    If (MoveX < 0 ) Or (MoveX + Shape1.Width > UserControl.ScaleWidth) Or _     (MoveY < 0 ) Or (MoveY + Shape1.Height > UserControl.ScaleHeight) Then Exit Sub   Shape1.Move MoveX,MoveY End Sub Private Sub UserControl_MouseUp(Button As Integer ,Y As Single )   Shape1.BackColor = RGB ( 255 , 0 ) End Sub Property Get PosX() As Integer 注释:取得CircleX的值显示用户   PosX = CircleX End Property Property Let PosX(ByVal New_X As Integer ) 注释:把用户写入的值设置到OCX控件内部    If (New_X < Shape1.Width / 2 ) Or _     (New_X > UserControl.ScaleWidth - Shape1.Width / 2 ) Then     MsgBox ( " 圆的X值超出界限了 " )    Else     CircleX = New_X      Call UserControl_Resize    End If End Property Property Get PosY() As Integer   PosY = CircleY End Property Property Let PosY(ByVal New_Y As Integer )    If (New_Y < Shape1.Height / 2 ) Or _     (New_Y > UserControl.ScaleHeight - Shape1.Height / 2 ) Then     MsgBox ( " 圆的Y值超出界限了 " )    Else     CircleY = New_Y      Call UserControl_Resize    End If End Property Private Sub UserControl_ReadProperties(PropBag As propertybag)   CircleX = PropBag.ReadProperty( " CircleX " ,Shape1.Width / 2 ) 注释:将用户设置的值读出来   CircleY = PropBag.ReadProperty( " CircleY " ,Shape1.Height / 2 ) 注释:同上    Call UserControl_Resize End Sub Private Sub UserControl_Resize()   Shape1.Move CircleX,CircleY End Sub Private Sub UserControl_WriteProperties(PropBag As propertybag)    Call PropBag.WriteProperty( " CircleX " ,CircleX,Shape1.Width / 2 ) 注释:将用户设置的值保存    Call PropBag.WriteProperty( " CircleY " ,CircleY,Shape1.Height / 2 ) 注释:同上 End Sub

麻雀虽小,五脏俱全。这个OCX控件完成的任务虽然简单,但是OCX控件的基本操作全都有喔! 有兴趣的朋友不妨一试

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强制返回为文本 -------------------------------- 数字类型的格式化 --------------------------------     固定格式参数:     General Number 普通数字,如可以用来去掉千位分隔号     format$("100,1
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办法, Format 或者FormatDateTime 竟然结果和系统设置的区域语言的日期和时间格式相关。意思是尽管你用诸如 Format(Now, "MM/dd/yyyy"),如果系统的设置格式区域语言的日期和时间格式分隔符是"-",那他还会显示为 MM-dd-yyyy     只有拼凑: <%response.write
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace My ‘全局错误处理,新的解决方案直接添加本ApplicationEvents.vb 到工程即可 ‘添加后还需要一个From用来显示错误。如果到这步还不会则需要先打好基础啦 ‘======================================================== ‘以下事件
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用的爽呀,这篇文章写与2011年,看来我以前没有认真去找这个方法呀。 https://blog.csdn.net/chzjxgd/article/details/6176325 金蝶K3 BOS的插件官方是用VB6编写的,如果  能用.Net下的语言工具开发BOS插件是一件很愉快的事情,其中缘由不言而喻,而本文则是个人首创,实现在了用V
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选中的单元格进行处理 Dim m As Range, tmpStr As String, s As String Dim x As Integer, y As Integer, subStr As String If MsgBox("确定要分列处理吗?请确定分列的数据会覆盖它后面的单元格!", _
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single) 2 Dim path As String, hash As String 3 For Each fil
  Imports MySql.Data.MySqlClient Public Class Form1 ‘ GLOBAL DECLARATIONS Dim conString As String = "Server=localhost;Database=net2;Uid=root;Pwd=123456;" Dim con As New MySqlConnection
‘導入命名空間 Imports ADODB Imports Microsoft.Office.Interop   Private Sub A1() Dim Sql As String Dim Cnn As New ADODB.Connection Dim Rs As New ADODB.Recordset Dim S As String   S = "Provider=OraOLEDB.Oracl
Imports System.IO Imports System.Threading Imports System.Diagnostics Public Class Form1 Dim A(254) As String    Function ping(ByVal IP As Integer) As String Dim IPAddress As String IPAddress = "10.0.
VB运行EXE程序,并等待其运行结束 参考:https://blog.csdn.net/useway/article/details/5494084 Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long Pr