DYLIKE

DSAPI WIN7风格

在Winform项目中,有时需要将UI变成适应Vista/Windows7/8/10的风格,通过"选用"以下代码来使你的UI支持系统主题渲染.

注:该功能不支持XP,建议使用DS控件库中的WIN7风格控件。

新建工程,添加相关控件,复制粘贴以下代码即可

Public Class Form1
 
    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        DSAPI.Win7特性.任务栏特效.设置任务栏进度(Me.Handle, 50, 100)
        '*******缩略图按钮标识ID至少应200以上,以避免系统冲突
        '------------------
        Dim Itm1 As New DSAPI.Win7特性.任务栏缩略图.缩略图控制按钮
        With Itm1
            .标记 = DSAPI.Win7特性.任务栏缩略图.缩略图按钮状态.启用
            .标识ID = 500
            .标志组合 = DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.提示 + DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.图标 + DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.标记
            .图标 = My.Resources.D__32_.GetHicon
            .提示 = "上一首"
        End With
        '------------------
        Dim Itm2 As New DSAPI.Win7特性.任务栏缩略图.缩略图控制按钮
        With Itm2
            .标记 = DSAPI.Win7特性.任务栏缩略图.缩略图按钮状态.启用
            .标识ID = 501
            .标志组合 = DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.提示 + DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.图标 + DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.标记
            .图标 = My.Resources.D__41_.GetHicon
            .提示 = "暂停"
        End With
        '------------------
        Dim Itm3 As New DSAPI.Win7特性.任务栏缩略图.缩略图控制按钮
        With Itm3
            .标记 = DSAPI.Win7特性.任务栏缩略图.缩略图按钮状态.启用
            .标识ID = 502
            .标志组合 = DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.提示 + DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.图标 + DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.标记
            .图标 = My.Resources.D__31_.GetHicon
            .提示 = "播放"
        End With
        '------------------
        Dim Itm4 As New DSAPI.Win7特性.任务栏缩略图.缩略图控制按钮
        With Itm4
            .标记 = DSAPI.Win7特性.任务栏缩略图.缩略图按钮状态.启用
            .标识ID = 503
            .标志组合 = DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.提示 + DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.图标 + DSAPI.Win7特性.任务栏缩略图.缩略图按钮标志.标记
            .图标 = Me.Icon.ToBitmap.GetHicon
            .提示 = "帮助"
        End With
        DSAPI.Win7特性.任务栏特效.添加缩略图控制按钮(Me.Handle, New DSAPI.Win7特性.任务栏缩略图.缩略图控制按钮() {Itm1, Itm2, Itm3, Itm4})
        AddHandler DSAPI.Win7特性.任务栏特效.缩略图按钮被点击, AddressOf ItmClick
    End Sub
 
    Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        DSAPI.Win7特性.任务栏特效.初始化(Me)
        DSAPI.控件相关.Form窗体.窗体支持鼠标拖动(Me, True)
        Me.ForeColor = Color.FromArgb(255, 2, 2, 2)
        For Each S As String In [Enum].GetNames(ListView1.View.GetType)
            ComboBox1.Items.Add(S)
        Next
        ComboBox1.SelectedIndex = 0
        For Each S As String In [Enum].GetNames(GetType(DSAPI.Win7特性.任务栏缩略图.任务栏进度条状态))
            ComboBox2.Items.Add(S)
        Next
        ComboBox2.SelectedIndex = 0
    End Sub
    Sub ItmClick(ID As Integer)
        Select Case ID
            Case 500
                MsgBox("点击了上一首")
            Case 501
                MsgBox("点击了暂停")
            Case 502
                MsgBox("点击了播放")
            Case 503
                MsgBox("点击了帮助")
        End Select
    End Sub
 
    Private Sub Form1_Shown(sender As Object, e As EventArgs) Handles Me.Shown
        TreeView1.ExpandAll()
    End Sub
 
    Private Sub ComboBox1_SelectedIndexChanged(sender As Object, e As EventArgs) Handles ComboBox1.SelectedIndexChanged
        ListView1.View = ComboBox1.SelectedIndex
    End Sub
 
    Private Sub LinkLabel1_LinkClicked(sender As Object, e As LinkLabelLinkClickedEventArgs) Handles LinkLabel1.LinkClicked
        Try
            Process.Start("SystemPropertiesAdvanced.exe")
        Catch 
        End Try
    End Sub
 
    Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click
        If Form2.Visible = True Then Exit Sub
        Form2.Show()
        DSAPI.Win7特性.在指定窗体指定区域显示源窗体缩略图(Form2.Handle, New Rectangle(0, 0, Me.Width, Me.Height), Me.Handle, False, 255)
    End Sub
 
    Private Sub TrackBar1_Scroll(sender As Object, e As EventArgs) Handles TrackBar1.Scroll
    End Sub
 
    Private Sub Button3_Click(sender As Object, e As EventArgs) Handles Button3.Click
        DSAPI.Win7特性.设置窗体为磨砂透明效果(Me)
    End Sub
 
    Private Sub Button4_Click(sender As Object, e As EventArgs) Handles Button4.Click
        DSAPI.Win7特性.使控件应用Win7资源管理器风格(Me)
    End Sub
 
    Private Sub TrackBar1_ValueChanged(sender As Object, e As EventArgs) Handles TrackBar1.ValueChanged
        DSAPI.Win7特性.任务栏特效.设置任务栏进度(Me.Handle, TrackBar1.Value, TrackBar1.Maximum)
 
    End Sub
 
    Private Sub ComboBox2_SelectedIndexChanged(sender As Object, e As EventArgs) Handles ComboBox2.SelectedIndexChanged
        DSAPI.Win7特性.任务栏特效.设置任务栏进度条状态(Me.Handle, GetV(ComboBox2.SelectedItem.ToString))
    End Sub
    Private Function GetV(S As String) As Integer
        Dim Ints() As Integer = [Enum].GetValues(GetType(DSAPI.Win7特性.任务栏缩略图.任务栏进度条状态))
        For Each T As Integer In Ints
            If [Enum].GetName(GetType(DSAPI.Win7特性.任务栏缩略图.任务栏进度条状态), T) = S Then
                Return T
            End If
        Next
        Return 0
    End Function
End Class

  

posted on 2019-03-24 09:44  『DYLIKE』  阅读(795)  评论(0编辑  收藏  举报

导航

Live2D