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