VB.Net之Beta2全接触(一)随心所欲窗体外观转换实例

类别:.NET开发 点击:0 评论:0 推荐:

 

一鹤(hjz)_贺建中 撰写 http://www.yescnet.com

今天刚拿到beta2,因为不想邮购,一直等到现在,今天刚到手,就把“随心所欲窗体外观”程序拿来小试了一下(现在大部份的例程都很简单,Microsoft也只有一些Class A Class B 之类很抽象的示例,这个源码我当初在VB6中写出来,在beta1中足足写了一个月才成功,那时候不要说中文,连英文的帮助都找不到,不眠不休才搞定),这也是我比较满意的一个程序,如果用得好,足以制作出令人眩目的效果,所以我不想他失效,所以一定要试一试,一试才知道,在beta2中beta1的程序根本不能用了,要改的地方很多,很多默认的引用并不清楚,只好新建一个工程,重新写过,顺便把我遇到的问题注释在代码中间。痛苦的折腾了一番,终于成功。

全部代码如下:

请到我的网站去下源码吧(我现在还没有上网上传,我会把文章写好再上传源码,所以现在无法标明确切地址,好在首页更新一定有的,
要不我那里搜索功能也很强大,打入“窗体外观”的关键字肯定能找到的)


 

Public Class Form1
    Inherits System.Windows.Forms.Form  '继承一个窗体的类
    '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
    '注意注意beta2这里的变化
    'winforms类现在变成了windows.forms类
    '不要想升级或修改beta1的程序,因为很多的基类重新定义了
    '必须在beta2中新建,才能默认的有windws.forms这些引用
    '如果手工添加|删除引用也可以
    '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
    Dim Genie As AgentObjects.IAgentCtlCharacterEx  '声明一个agent的对象
    Const DATAPATH As String = "MERLIN.ACS" '加载动画数据
    Public frmpre As Form1 '声明一个新的窗体,请不要在这里使用初始化的方法或使用New方法
    Friend WithEvents AxAgent1 As AxAgentObjects.AxAgent
    Friend WithEvents lbExit As System.Windows.Forms.Label
    Friend WithEvents lbPre As System.Windows.Forms.Label
    Friend WithEvents lbShow As System.Windows.Forms.Label
    Friend WithEvents Label3 As System.Windows.Forms.Label
    Public Imindex As Short '声明一个整数
#Region " Windows Form Designer generated code "
    Sub New(Optional ByVal strImage As String = Nothing)
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
        '注意注意beta2这里的变化
        '构造函数NEW在beta2现在是在#Region的内部
        '构造函数NEW在beta2中不支持重载方法,但是我用一个Optional 参数很快解决了问题
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
        MyBase.New() '直接调用父类的new过程
        Dim form1 As Form1 = form1
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
        '注意注意beta2这里的变化
        '直接使用form1等于me会出错,默认的form1是一个类,不是一个实例
        '使用前要dim form1 as form1=form使声明为一个实例才能赋值
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
        form1 = Me '设定me关键字
        InitializeComponent() '下面是初始化组件,你也可以在下面使用call方法呼叫一个子过程(见前面的文章)
        If Not strImage Is Nothing Then
            '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
            '注意注意beta2这里的变化
            'strImage<> Nothing 会出错
            '请用 Not strImage Is Nothing
            '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
            lbExit.Visible = False : lbShow.Visible = False : lbPre.Visible = False : Label3.Visible = False '新窗体不显示控制
            Me.Top = Me.Top + 150 '新窗体的位置,top是距离屏幕顶部的高度
            Call SkinRegion(form1, strImage) '为窗体改变skin(外观)
        Else
            AxAgent1.Characters.Load("MERLIN", DATAPATH) '装载动画数据
            Genie = AxAgent1.Characters("MERLIN") '把Agent对象赋于声明的对象,简化书写的过程
            Genie.LanguageID = &H409S '设定语音ID
            Call SkinRegion(form1) '为窗体改变skin(外观)
        End If
    End Sub
    '上面使用overloads定义了两个不同的new过程,在new过程中使用重载可以间接地使一个类产生很好的可重用性,如果你不明白为什么不写一个新的过程,而一定要使用重载
    '那么你看看这里的用法,一定会有所启发的。
    Public Overloads Sub Dispose() '释放资源,终止程序
        MyBase.Dispose() '调用父类的方法
        Region1.Dispose() '释放GDI资源
        Genie = Nothing '释放动画占用的资源
        'components.Dispose() '释放组件占用的资源
    End Sub
    '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
    '注意注意beta2这里的变化
    'Dispose现在是在#Region的内部
    '在程序中调用components.Dispose()会出错,可能beta2需要这个对象直到最终销毁
    '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
    'Required by the Windows Form Designer
    Private components As System.ComponentModel.Container
    'NOTE: The following procedure is required by the Windows Form Designer
    'It can be modified using the Windows Form Designer. 
    'Do not modify it using the code editor.
    <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()
        Dim resources As System.Resources.ResourceManager = New System.Resources.ResourceManager(GetType(Form1))
        Me.Label3 = New System.Windows.Forms.Label()
        Me.lbExit = New System.Windows.Forms.Label()
        Me.lbShow = New System.Windows.Forms.Label()
        Me.lbPre = New System.Windows.Forms.Label()
        Me.AxAgent1 = New AxAgentObjects.AxAgent()
        CType(Me.AxAgent1, System.ComponentModel.ISupportInitialize).BeginInit()
        Me.SuspendLayout()
        '
        'Label3
        '
        Me.Label3.BackColor = System.Drawing.Color.FromArgb(CType(255, Byte), CType(255, Byte), CType(192, Byte))
        Me.Label3.BorderStyle = System.Windows.Forms.BorderStyle.Fixed3D
        Me.Label3.Location = New System.Drawing.Point(200, 16)
        Me.Label3.Name = "Label3"
        Me.Label3.Size = New System.Drawing.Size(168, 88)
        Me.Label3.TabIndex = 4
        '
        'lbExit
        '
        Me.lbExit.BackColor = System.Drawing.Color.FromArgb(CType(192, Byte), CType(192, Byte), CType(255, Byte))
        Me.lbExit.Location = New System.Drawing.Point(80, 72)
        Me.lbExit.Name = "lbExit"
        Me.lbExit.Size = New System.Drawing.Size(56, 16)
        Me.lbExit.TabIndex = 1
        Me.lbExit.Text = "退出程序"
        '
        'lbShow
        '
        Me.lbShow.BackColor = System.Drawing.Color.FromArgb(CType(192, Byte), CType(192, Byte), CType(255, Byte))
        Me.lbShow.Location = New System.Drawing.Point(80, 24)
        Me.lbShow.Name = "lbShow"
        Me.lbShow.Size = New System.Drawing.Size(56, 16)
        Me.lbShow.TabIndex = 3
        Me.lbShow.Text = "散散心吧"
        '
        'lbPre
        '
        Me.lbPre.BackColor = System.Drawing.Color.FromArgb(CType(192, Byte), CType(192, Byte), CType(255, Byte))
        Me.lbPre.Location = New System.Drawing.Point(80, 48)
        Me.lbPre.Name = "lbPre"
        Me.lbPre.Size = New System.Drawing.Size(56, 16)
        Me.lbPre.TabIndex = 2
        Me.lbPre.Text = "外观应用"
        '
        'AxAgent1
        '
        Me.AxAgent1.Enabled = True
        Me.AxAgent1.Location = New System.Drawing.Point(224, 176)
        Me.AxAgent1.Name = "AxAgent1"
        Me.AxAgent1.OcxState = CType(resources.GetObject("AxAgent1.OcxState"), System.Windows.Forms.AxHost.State)
        Me.AxAgent1.Size = New System.Drawing.Size(56, 40)
        Me.AxAgent1.TabIndex = 0
        '
        'Form1
        '
        Me.AutoScaleBaseSize = New System.Drawing.Size(6, 14)
        Me.BackColor = System.Drawing.Color.FromArgb(CType(192, Byte), CType(192, Byte), CType(255, Byte))
        Me.BackgroundImage = CType(resources.GetObject("$this.BackgroundImage"), System.Drawing.Bitmap)
        Me.ClientSize = New System.Drawing.Size(432, 287)
        Me.Controls.AddRange(New System.Windows.Forms.Control() {Me.Label3, Me.lbShow, Me.lbPre, Me.lbExit, Me.AxAgent1})
        Me.FormBorderStyle = System.Windows.Forms.FormBorderStyle.None
        Me.MaximizeBox = False
        Me.MinimizeBox = False
        Me.Name = "Form1"
        Me.StartPosition = System.Windows.Forms.FormStartPosition.Manual
        Me.Text = "Form1"
        CType(Me.AxAgent1, System.ComponentModel.ISupportInitialize).EndInit()
        Me.ResumeLayout(False)

    End Sub

#End Region

    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
        '注意注意beta2这里的变化
        '默认的给了你一个VB6中的load过程
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
    End Sub

    '上面的是非编辑模块,就不用看了
    Protected Sub lbExit_Click_1(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles lbExit.Click
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
        '注意注意beta2这里的变化
        'Click的参数不一样了
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
        If Not frmpre Is Nothing Then '如果加载了新窗体
            '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
            '请用Not frmpre Is Nothing 不要使用frmpre<>nothing
            '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
            frmpre.Dispose() '终止新窗体
            frmpre = Nothing '释放占用的资源
        End If
        Me.Dispose() '终止程序
        End  '彻底终止程序(如果程序无法退出,请使用此关键字)
    End Sub


    '下面是动画过程,在前面的文章中很详细,可以不用看了!
    Protected Sub lbshow_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles lbShow.Click

        Genie.Left = 500 '设定agent的位置
        Genie.Show() '使用show方法显示agent
        Genie.MoveTo(12, 180) 'moveto方法是移动agent到一个位置,如果加上定时器,你可以很容易地让他在屏幕上 乱跑()
        MessageBox.Show("如果你是MM,请按Ctrl+Alt+Del关闭 " & Chr(10) & Chr(13) & "您真的要继续吗, 等到我不 动再说!")
        Genie.Speak("ni hao") '发出声音
        MessageBox.Show("你好") '对话框,更多的参数请看以前的相关文章
        Genie.Speak("WO SHI HAO KAN DI") '发出声音
        MessageBox.Show("我是好看的") '对话框,更多的参数请看以前的相关文章
        Genie.Speak("NI SHI NAN KAN DI") '发出声音
        MessageBox.Show("你是难看的") '对话框,更多的参数请看以前的相关文章
        Genie.Speak("ZIA JIE MIMI  ") '发出声音
        MessageBox.Show("再见 MM") '对话框,更多的参数请看以前的相关文章
        Genie.Play("Wave") '挥手致意
        '众MM请勿生气
        '上面是开一个小玩笑,如果要真正的读中文,就用下面的
        'Genie.Speak("CNstring ",CNstring.wav) '这里的CNstring就是中文的语音文件
        Genie.Hide() '使用hide方法隐藏agent
    End Sub

    Protected Sub lbpreClick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles lbPre.Click

        If Not frmpre Is Nothing Then frmpre.Dispose() '如果新窗体已经存在,清除之
        Dim strIm As String '定义一个字符类型变量
        If Imindex <> 6 Then '反过来想,就是说如果到了6就从头开始,因这我只有这么几张图片了
            Imindex = Imindex + 1
        Else
            Imindex = 1 '从头开始
        End If
        strIm = "SK" & Imindex.ToString 'tostring的意思是从字符类型转为数字类型
        '在VB.net中label控件有image控件一样的作用,不但可以显示文本而且可以显示图片,而在VB6中是只能显示图片的
        Label3.Image = Label3.Image.FromFile(System.Windows.Forms.Application.StartupPath & "\" & strIm & ".GIF") 'formfile是从一个路径装载图片
        'System.WinForms.Application.StartUpPath的意思是当前目录,同VB6中的App.Path
        '请注意调试过程中使用的当前目录是在bin目录下,在下一个版本有可能更改
        frmpre = New Form1(strIm) '初始化一个实例(对象)
        frmpre.Visible = True '显示新窗体,如果没有这个只怕你什么也看不到!
    End Sub

 

    '下面是移动窗体的代码,请参考前面的文章
    Private Sub Form1_MouseDown(ByVal eventSender As System.Object, ByVal eventArgs As System.Windows.Forms.MouseEventArgs)
        Me.Capture = False '释放鼠标捕获
        ' Me.SendMessage(&HA1S, 2, 0) '这是VB6中最有名的API消息函数
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
        '注意注意beta2这里的变化
        'sendmessage以前的用法不能用了,看了一下MSDN,居然全是Beta1的内容,我倒!
        '&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
    End Sub
    '下面是鼠标移动_MouseMove时发生的事件了
    Public Sub lbpre_MouseMove(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbPre.MouseMove
        lbPre.BackColor = System.Drawing.Color.Black '设置颜色
        lbPre.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub
    Public Sub lbExit_MouseMove(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbExit.MouseMove
        lbExit.BackColor = System.Drawing.Color.Black '设置颜色
        lbExit.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub
    Public Sub lbshow_MouseMove(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbShow.MouseMove
        lbShow.BackColor = System.Drawing.Color.Black '设置颜色
        lbShow.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub
    '下面是鼠标按下_MouseMove时发生的事件了
    Public Sub lbpre_MouseDown(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbPre.MouseDown
        lbPre.BackColor = System.Drawing.Color.Blue '设置颜色
        lbPre.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub
    Public Sub lbExit_MouseDown(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbExit.MouseDown
        lbExit.BackColor = System.Drawing.Color.Blue '设置颜色
        lbExit.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub
    Public Sub lbShow_MouseDown(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbShow.MouseDown
        lbShow.BackColor = System.Drawing.Color.Blue '设置颜色
        lbShow.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub

    Public Sub lbpre_MouseUp(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbPre.MouseUp
        lbPre.BackColor = System.Drawing.Color.Black '设置颜色
        lbPre.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub
    Public Sub lbExit_MouseUp(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbExit.MouseUp
        lbExit.BackColor = System.Drawing.Color.Black '设置颜色
        lbExit.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub
    Public Sub lbShow_MouseUp(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles lbShow.MouseUp
        lbShow.BackColor = System.Drawing.Color.Black '设置颜色
        lbShow.ForeColor = System.Drawing.Color.AliceBlue '设置颜色
    End Sub
    '下面是鼠标离开_MouseLeave时发生的事件了
    Public Sub lbShow_MouseLeave(ByVal sender As Object, ByVal e As System.EventArgs) Handles lbShow.MouseLeave
        lbShow.BackColor = System.Drawing.Color.BlanchedAlmond '设置颜色
        lbShow.ForeColor = System.Drawing.Color.Black '设置颜色
    End Sub
    Public Sub lbExit_MouseLeave(ByVal sender As Object, ByVal e As System.EventArgs) Handles lbExit.MouseLeave
        lbExit.BackColor = System.Drawing.Color.BlanchedAlmond '设置颜色
        lbExit.ForeColor = System.Drawing.Color.Black '设置颜色
    End Sub
    Public Sub lbpre_MouseLeave(ByVal sender As Object, ByVal e As System.EventArgs) Handles lbPre.MouseLeave
        lbPre.BackColor = System.Drawing.Color.BlanchedAlmond '设置颜色
        lbPre.ForeColor = System.Drawing.Color.Black '设置颜色
    End Sub

 

 

End Class

'&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
'注意注意beta2这里的变化
'大家注意到没有?只有这个我写的这个千变万化窗体的模块不需要任何修改,呵呵,可以骄傲一下了
'&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

'###################################################################################################################
'!!!0001!!!04!!!26!!!!!!
'建议不要修改此模块 以免产生不必要的错误(此代码已相当完美) 如欲修改请先备份  _______VB.Net中文站 hejianzhong
'此模块可真接粘贴到您的程序中使用。
'不要删除此信息,我免费为您提供此代码,想得到的回报就是最起码的尊重,虽然最终用户并不能看到,我仍感到欣慰
'!!!0001!!!04!!!26!!!!!!
Public Module SKin
    Declare Function SendMessage Lib "user32" Alias _
       "SendMessageA" (ByVal hWnd As Long, ByVal wMsg As Long, _
          ByVal wParam As Long, ByVal lParam As Long) As Long


    Public Rect1 As New Rectangle(0, 0, 0, 0)
    Public Region1 As New System.Drawing.Region(Rect1)
    Public Sub SkinRegion(ByVal SKform As Form, Optional ByVal skinNaSKform As String = Nothing)
        Dim X, Y, transPix, opaciPix, BgWidth, BgHeight As Integer
        Dim rect2 As New Rectangle()
        Dim FirARGB As Integer = Getpixel(SKform, 1, 1)
        Dim Region1 As New System.Drawing.Region(Rect1)
        Rect1 = Nothing
        'SKform.Visible = False 
        If skinNaSKform <> Nothing Then SKform.BackgroundImage = SKform.BackgroundImage.FromFile(System.Windows.Forms.Application.StartupPath & "\" & skinNaSKform & ".gif")
        BgWidth = SKform.BackgroundImage.Width
        BgHeight = SKform.BackgroundImage.Height
        SKform.Height = BgHeight
        SKform.Width = BgWidth
        For Y = 1 To BgHeight - 1 '这里参考了VB6中的扫描方法,请参考相关资料
            X = 0
            Do
                X = X + 1
                While (Getpixel(SKform, X, Y) = FirARGB) And (X < BgWidth)
                    X = X + 1
                End While
                transPix = X
                While (Getpixel(SKform, X, Y) <> FirARGB) And (X < BgWidth)
                    X = X + 1
                End While
                opaciPix = X - 1
                If transPix <= opaciPix Then
                    rect2 = rect2.FromLTRB(transPix - 1, Y - 1, opaciPix, Y)
                    Region1.Union(rect2)
                    rect2 = Nothing
                End If
            Loop Until X >= BgWidth
        Next Y
        SKform.Region = Region1
        SKform.Refresh()
        'SKform.Visible = True 
    End Sub
    Public Function Getpixel(ByVal SKform As Form, ByVal x As Integer, ByVal y As Integer) As Integer
        Dim pm As Bitmap = SKform.BackgroundImage
        Try
            Return pm.GetPixel(x, y).ToArgb
        Catch
            Exit Function
        End Try
    End Function
End Module
'###################################################################################################################

'&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
'借光借光,转载请不要删了我的网址
'CNET中文网 ◇ VB.NET中文网
'主站:
'http://www.yescnet.com
'镜像:
'http://user.7host.com/yescnet
'http://perso.kilio.com/yescnet
'http://www.yescnet.net
'http://www.websamba.com/yescnet
'请到我的网站下载本文章的示例源码

'&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&

全文(完)


 

附:走近VB.Net(Beta1之十一) 随心所欲窗体外观(skin精彩源码)

这是beta1的源码,大家比较吧

前几天因为应付约稿,答应的这个源码推迟了几天,今天熬夜把他写出来,请见谅。另外我想说一些题外话,前时我曾在文章中说过,说VB.Net的面向对象抄袭java,delphi没有实际根据(你总不能把面象对象理解成linux核心一样的源码技术,他主要还是一种指导思想),这句话本身就有了逻辑性的错误,请问java与delphi是谁抄谁呢?答案只能是SmallTalk的面向对象更早(见王国荣的文章)。 VC的面向对象大家闭口不提,然而我个人认为在windows编程上(不包括网络应用)VC仍是最强大的语言,而VC的程序员几乎没有人出来说这些无聊的话。那么是谁在说呢......

这个说法最早源于国外的文章(指在网络应用上有涉嫌模仿Java,如果是编写windows程序则毫无根据),而作者在后来的撰文中很清楚的告诉大家纠正此说法。我也一再提到过。可有 人视若无睹。大家现在就说VB.Net如何如何太早了一点,我们都是在实践摸索,用都不会用,就毫无根据的揣测有些不智。很多学java的告诉你先学java再学VB.Net.这有些不可思议,起码到目前,没有看到java程序员写出我们可以拿来学的VB.Net程序。因为有了面象对象的思想不等于有了一切。

现在面向对象真有些神化了,这不可思议,程序员不是哲人,是要通宵达旦的工作学习创造,好象一点也不浪漫!而现在竟被一部分人浪漫了。

不论微软如何的称颂他的网络功能,我相信在不久的将来,VB.Net必将成为最快速,最重要,也最适用windows平台的应用程序编程语言(我没有涉及网络应用)。当然决不可能是最强大的,这世界好象没有谁最强大!而且我对他的网络应用不感兴趣。每个人都有自已的路。正如大家都说VB如何的适宜于开发数据库。但是你相不相信一个人从不接触数据库可以写出让人很看好的程 序,每个人有权利选择自已的路! 如果你对网络应用毫无兴趣,java还会是一个好的选择吗?

我个人认为无论是java,delphi,还是VB.Net甚至C++,各有各的长处。各有各的用途。无优劣之分,编程最重要的是灵感,是广博的视野,是宽大的襟怀。任何想贬低别人的人,正暴露自已的浅见与无知。我虽然是学VB的,但我在进入delphi的论坛以后,我亦为之感动,这里也有很多兢兢业业,无私奉献的值得尊敬与学习的人。工具永远不能征服人性!外国人没有因这纸是中国人造的而不用,亦没有因火药是中国人发明的而羞愧,也没有因这二进制的起源于中国而牢骚,科学是跨越国界的,不应被蒙上政治色彩。

我曾在一个专门介绍比尔盖茨的网站看了一下他的生平,想来看过的人不少。看了他一生的奋斗历程,我们还能说什么呢?

以上是个人的浅见(鉴于本人对delphi,java的无知,对VB.Net的初识以及对面象对象技术的部分误解),只是谈谈感受,请勿借题发挥,大作文章。我写这些是防止一些错得离谱的歪论误导初学者。另外我一再鼓励大家研究一下,弄出一些实际的心得来。我因为自身的限制与没有相互的研讨,所以每一篇文章写出来所付出的努力不亚于写一个工程。所以请转载文章的在跟我联系以后 在文中明确按本文结尾处样式注明我的网站名,网址 。这里先向您致谢了!

另外鉴于一些初学者的要求,以及前辈的指点,我在源码中对入门级的知识进行了注解,如果您认为这些对您是多余的,请谅解还有很多人看不懂。

' 本源码出自VB.Net中文站 http://vbnetcn.126.com hejianzhong 请尊重作者劳动不要修改此信息(ai.....................)

'

' -------------------------------------------------------------------------------------------------------------------

' 请首先清添加lable(lbExit,lbPre,lbShow)控件

' 请在属性栏设置这三个lable控件的BackColr(背景色)为system.desktop 即在出现的取色对话框中选择system标签下的desktop颜色

' 下一步,添加AxAgent控件这个请参考拙作《走近VB.Net(九) AxAgent动画窗体的实现》

' 设置窗体背景图片为SK1.GIF 请在 BackgroundImage 属性栏设置

' 所有需要的图片用photoshop做出来,如果你不会做可到《VB.Net中文论坛》去找我帮你做。

' 设置lbExit的Text属性(指在标签上显示的文本)为“退出”

' 设置lbPre的Text属性(指在标签上显示的文本)为“窗体”

' 设置lbShow的Text属性(指在标签上显示的文本)为“动画”

' 设置所有label的 TextAlign(文本的排列方式)为center(居中)

Option Strict Off '关闭Option Strict

Imports System.ComponentModel '引用族名

Imports System.Drawing '引用族名

Imports System.WinForms '引用族名

Public Class Form1

Inherits System.WinForms.Form '继承一个窗体的类

Dim Genie As AgentObjects.IAgentCtlCharacterEx '声明一个agent的对象

Const DATAPATH As String = "MERLIN.ACS" '加载动画数据

Public frmpre As Form1 '声明一个新的窗体,请不要在这里使用初始化的方法或使用New方法

Public Imindex As Short '声明一个整数

Public Overloads Sub New() '每一个类一般都有一个new过程,在新建一个对象(使用new方法)时调用

MyBase.New() '直接调用父类的new过程

Form1 = Me '设定me关键字

InitializeComponent() '下面是初始化组件,你也可以在下面使用call方法呼叫一个子过程(见前面的文章)

axAgent1.Characters.Load("MERLIN", DATAPATH) '装载动画数据

Genie = axAgent1.Characters("MERLIN") '把Agent对象赋于声明的对象,简化书写的过程

Genie.LanguageID = &H409S '设定语音ID

Call SkinRegion(form1) '为窗体改变skin(外观)

End Sub

Overloads Sub new(ByVal strImage As String)

MyBase.New() '直接调用父类的new过程

Form1 = Me '设定me关键字

InitializeComponent() '下面是初始化组件,你也可以在下面使用call方法呼叫一个子过程(见前面的文章)

lbExit.Visible = False : lbShow.Visible = False : lbpre.Visible = False : label3.Visible = False '新窗体不显示控制

Me.top = Me.top + 150 '新窗体的位置,top是距离屏幕顶部的高度

Call SkinRegion(form1, strImage) '为窗体改变skin(外观)

End Sub

'上面使用overloads定义了两个不同的new过程,在new过程中使用重载可以间接地使一个类产生很好的可重用性,如果你不明白为什么不写一个新的过程,而一定要使用重载

'那么你看看这里的用法,一定会有所启发的。

Public Overrides Sub Dispose() '释放资源,终止程序

MyBase.Dispose() '调用父类的方法

Region1.Dispose() '释放GDI资源

genie = Nothing '释放动画占用的资源

components.Dispose() '释放组件占用的资源

End Sub

'下面的是非编辑模块,就不用看了

#Region " Windows Form Designer generated code "

'Required by the Windows Form Designer

Private components As System.ComponentModel.Container

Private WithEvents lbShow As System.WinForms.Label

Private WithEvents Label3 As System.WinForms.Label

Private WithEvents LinkLabel3 As System.WinForms.LinkLabel

Private WithEvents lbExit As System.WinForms.Label

Private WithEvents lbpre As System.WinForms.Label

Private WithEvents AxAgent1 As AxAgentObjects.AxAgent

Dim WithEvents Form1 As System.WinForms.Form

'NOTE: The following procedure is required by the Windows Form Designer

'It can be modified using the Windows Form Designer.

'Do not modify it using the code editor.

Private Sub InitializeComponent()

Dim resources As System.Resources.ResourceManager = New System.Resources.ResourceManager(GetType(Form1))

Me.components = New System.ComponentModel.Container()

Me.lbpre = New System.WinForms.Label()

Me.lbShow = New System.WinForms.Label()

Me.Label3 = New System.WinForms.Label()

Me.AxAgent1 = New AxAgentObjects.AxAgent()

Me.LinkLabel3 = New System.WinForms.LinkLabel()

Me.lbExit = New System.WinForms.Label()

AxAgent1.BeginInit()

'@design Me.TrayHeight = 90

'@design Me.TrayLargeIcon = False

'@design Me.TrayAutoArrange = True

lbpre.Location = New System.Drawing.Point(32, 72)

lbpre.Text = "窗体"

lbpre.Size = New System.Drawing.Size(64, 24)

lbpre.TabIndex = 10

lbpre.BackColor = System.Drawing.SystemColors.Desktop

lbpre.TextAlign = System.WinForms.HorizontalAlignment.Center

lbShow.Location = New System.Drawing.Point(32, 24)

lbShow.Text = "动画"

lbShow.Size = New System.Drawing.Size(64, 24)

lbShow.TabIndex = 17

lbShow.BackColor = System.Drawing.SystemColors.Desktop

lbShow.TextAlign = System.WinForms.HorizontalAlignment.Center

Label3.Location = New System.Drawing.Point(176, 16)

Label3.Text = " "

Label3.Size = New System.Drawing.Size(176, 88)

Label3.BorderStyle = System.WinForms.BorderStyle.Fixed3D

Label3.TabIndex = 16

AxAgent1.Size = New System.Drawing.Size(56, 40)

AxAgent1.OcxState = CType(resources.GetObject("AxAgent1.OcxState"), System.WinForms.AxHost.State)

AxAgent1.TabIndex = 1

AxAgent1.Location = New System.Drawing.Point(232, 216)

LinkLabel3.Text = "LinkLabel3"

LinkLabel3.Size = New System.Drawing.Size(0, 16)

LinkLabel3.TabIndex = 15

LinkLabel3.TabStop = True

LinkLabel3.Location = New System.Drawing.Point(352, 88)

lbExit.Location = New System.Drawing.Point(32, 48)

lbExit.Text = "退出"

lbExit.Size = New System.Drawing.Size(64, 24)

lbExit.TabIndex = 11

lbExit.BackColor = System.Drawing.SystemColors.Desktop

lbExit.TextAlign = System.WinForms.HorizontalAlignment.Center

Me.Text = "Form1"

Me.AutoScaleBaseSize = New System.Drawing.Size(6, 14)

Me.BorderStyle = System.WinForms.FormBorderStyle.None

Me.BackgroundImage = CType(resources.GetObject("$this.BackgroundImage"), System.Drawing.Image)

Me.ClientSize = New System.Drawing.Size(392, 288)

Me.Controls.Add(lbShow)

Me.Controls.Add(Label3)

Me.Controls.Add(LinkLabel3)

Me.Controls.Add(lbExit)

Me.Controls.Add(lbpre)

Me.Controls.Add(AxAgent1)

AxAgent1.EndInit()

End Sub

#End Region

'上面的是非编辑模块,就不用看了

Protected Sub lbExit_Click(ByVal sender As Object, ByVal e As System.EventArgs)

If frmpre <> Nothing Then '如果加载了新窗体

frmpre.Dispose() '终止新窗体

frmpre = Nothing '释放占用的资源

End If

Me.Dispose() '终止程序

End '彻底终止程序(如果程序无法退出,请使用此关键字)

End Sub

'下面是动画过程,在前面的文章中很详细,可以不用看了!

Protected Sub lbshow_Click(ByVal sender As Object, ByVal e As System.EventArgs)

genie.Left = 500 '设定agent的位置

Genie.Show() '使用show方法显示agent

genie.MoveTo(12, 180) 'moveto方法是移动agent到一个位置,如果加上定时器,你可以很容易地让他在屏幕上 乱跑()

messagebox.Show("如果你是MM,请按Ctrl+Alt+Del关闭 " & chr(10) & chr(13) & "您真的要继续吗, 等到我不 动再说!")

Genie.Speak("ni hao") '发出声音

messagebox.Show("你好") '对话框,更多的参数请看以前的相关文章

Genie.Speak("WO SHI HAO KAN DI") '发出声音

messagebox.Show("我是好看的") '对话框,更多的参数请看以前的相关文章

Genie.Speak("NI SHI NAN KAN DI") '发出声音

messagebox.Show("你是难看的") '对话框,更多的参数请看以前的相关文章

Genie.Speak("ZIA JIE MIMI ") '发出声音

messagebox.Show("再见 MM") '对话框,更多的参数请看以前的相关文章

genie.Play("Wave") '挥手致意

'众MM请勿生气

'上面是开一个小玩笑,如果要真正的读中文,就用下面的

'Genie.Speak("CNstring ",CNstring.wav) '这里的CNstring就是中文的语音文件

genie.Hide() '使用hide方法隐藏agent

End Sub

Protected Sub lbpre_Click(ByVal sender As Object, ByVal e As System.EventArgs)

If frmpre <> Nothing Then frmpre.Dispose() '如果新窗体已经存在,清除之

Dim strIm As String '定义一个字符类型变量

If Imindex <> 6 Then '反过来想,就是说如果到了6就从头开始,因这我只有这么几张图片了

imindex = Imindex + 1

Else

IMINDEX = 1 '从头开始

End If

strIm = "SK" & imindex.ToString 'tostring的意思是从字符类型转为数字类型

'在VB.net中label控件有image控件一样的作用,不但可以显示文本而且可以显示图片,而在VB6中是只能显示图片的

Label3.image = label3.Image.FromFile(System.WinForms.Application.StartUpPath & "\" & strim & ".GIF") 'formfile是从一个路径装载图片

'System.WinForms.Application.StartUpPath的意思是当前目录,同VB6中的App.Path

'请注意调试过程中使用的当前目录是在bin目录下,在下一个版本有可能更改

frmpre = New form1(strim) '初始化一个实例(对象)

frmpre.Visible = True '显示新窗体,如果没有这个只怕你什么也看不到!

End Sub

'下面是移动窗体的代码,请参考前面的文章

Private Sub Form1_MouseDown(ByVal eventSender As System.Object, ByVal eventArgs As System.WinForms.MouseEventArgs)

Me.Capture = False '释放鼠标捕获

Me.SendMessage(&HA1S, 2, 0) '这是VB6中最有名的API消息函数

End Sub

'下面是鼠标移动_MouseMove时发生的事件了

Public Sub lbpre_MouseMove(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbpre.MouseMove

lbpre.BackColor = system.drawing.Color.Black '设置颜色

lbpre.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

Public Sub lbExit_MouseMove(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbExit.MouseMove

lbExit.BackColor = system.drawing.Color.Black '设置颜色

lbExit.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

Public Sub lbshow_MouseMove(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbshow.MouseMove

lbshow.BackColor = system.drawing.Color.BLack '设置颜色

lbshow.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

'下面是鼠标按下_MouseMove时发生的事件了

Public Sub lbpre_MouseDown(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbpre.MouseDown

lbpre.BackColor = system.drawing.Color.Blue '设置颜色

lbpre.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

Public Sub lbExit_MouseDown(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbExit.MouseDown

lbExit.BackColor = system.drawing.Color.Blue '设置颜色

lbExit.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

Public Sub lbShow_MouseDown(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbShow.MouseDown

lbshow.BackColor = system.drawing.Color.Blue '设置颜色

lbshow.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

Public Sub lbpre_MouseUp(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbpre.MouseUp

lbpre.BackColor = system.drawing.Color.Black '设置颜色

lbpre.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

Public Sub lbExit_MouseUp(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbExit.MouseUp

lbExit.BackColor = system.drawing.Color.Black '设置颜色

lbExit.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

Public Sub lbShow_MouseUp(ByVal sender As Object, ByVal e As System.WinForms.MouseEventArgs) Handles lbShow.MouseUp

lbshow.BackColor = system.drawing.Color.BLack '设置颜色

lbshow.ForeColor = system.Drawing.Color.AliceBlue '设置颜色

End Sub

'下面是鼠标离开_MouseLeave时发生的事件了

Public Sub lbShow_MouseLeave(ByVal sender As Object, ByVal e As System.EventArgs) Handles lbShow.MouseLeave

lbshow.BackColor = system.drawing.Color.BlanchedAlmond '设置颜色

lbshow.ForeColor = system.Drawing.Color.Black '设置颜色

End Sub

Public Sub lbExit_MouseLeave(ByVal sender As Object, ByVal e As System.EventArgs) Handles lbExit.MouseLeave

lbExit.BackColor = system.drawing.Color.BlanchedAlmond '设置颜色

lbExit.ForeColor = system.Drawing.Color.Black '设置颜色

End Sub

Public Sub lbpre_MouseLeave(ByVal sender As Object, ByVal e As System.EventArgs) Handles lbpre.MouseLeave

lbpre.BackColor = system.drawing.Color.BlanchedAlmond '设置颜色

lbpre.ForeColor = system.Drawing.Color.Black '设置颜色

End Sub

End Class

'##############################################################

'!!!0001!!!04!!!26!!!!!!

'建议不要修改此模块 以免产生不必要的错误(此代码已相当完美) 如欲修改请先备份 _______VB.Net中文站 hejianzhong

'此模块可真接粘贴到您的程序中使用。

'不要删除此信息,我免费为您提供此代码,想得到的回报就是最起码的尊重,虽然最终用户并不能看到,我仍感到欣慰

'!!!0001!!!04!!!26!!!!!!

Public Module SKin

Public Rect1 As New Rectangle(0, 0, 0, 0)

Public Region1 As New System.Drawing.Region(Rect1)

Public Sub SkinRegion(ByVal SKform As Form, Optional ByVal skinNaSKform As String = Nothing)

Dim X, Y, transPix, opaciPix, BgWidth, BgHeight As Integer

Dim rect2 As New Rectangle()

Dim FirARGB As Integer = getpixel(SKform, 1, 1)

Dim Region1 As New System.Drawing.Region(Rect1)

Rect1 = Nothing

'SKform.Visible = False

If skinnaSKform <> Nothing Then SKform.BackgroundImage = SKform.BackgroundImage.FromFile(System.WinForms.Application.StartUpPath & "\" & skinNaSKform & ".gif")

BgWidth = SKform.BackgroundImage.Width

BgHeight = SKform.BackgroundImage.Height

SKform.Height = BgHeight

SKform.Width = BgWidth

For Y = 1 To BgHeight - 1 '这里参考了VB6中的扫描方法,请参考相关资料

X = 0

Do

X = X + 1

While (getpixel(SKform, X, Y) = FirARGB) And (X < BgWidth)

X = X + 1

End While

transPix = X

While (getpixel(SKform, X, Y) <> FirARGB) And (X < BgWidth)

X = X + 1

End While

opaciPix = X - 1

If transPix <= opaciPix Then

rect2 = rect2.FromLTRB(transPix - 1, Y - 1, opaciPix, Y)

Region1.Union(rect2)

rect2 = Nothing

End If

Loop Until X >= BgWidth

Next Y

SKform.Region = Region1

SKform.Refresh()

'SKform.Visible = True

End Sub

Public Function Getpixel(ByVal SKform As Form, ByVal x As Integer, ByVal y As Integer) As Integer

Dim pm As Bitmap = SKform.BackgroundImage

Try

Return pm.GetPixel(x, y).ToARGB

Catch

Exit Function

End Try

End Function

End Module

'#################################################

本文地址:http://com.8s8s.com/it/it46263.htm