上一篇我們為應用程式設定了自訂的縮圖,本篇我們將繼續在縮圖中進行開發,為其添加工具列(Toolbar)。在使用Windows Media Player(WMP)的時候,將滑鼠放置在WMP 表徵圖上方時會出現縮圖工具列,其中包括“播放”、“下一首”和“前一首”三個功能鍵,即使WMP 不是當前使用中視窗我們也可以通過該工具列選擇歌曲。下面我們就來製作一個具有切換圖片功能的工具列。
ThumbnailButton.ThumbnailToolbarButton 方法
在製作工具列前先通過ThumbnailToolbarButton(Icon icon, string tooltip) 方法建立四個功能按鈕:“Next Image”,“Previous Image”,“Last Image”,“First Image” 並為它們增加各自的Click 事件(例如,buttonFirst_Click)用來完成圖片切換功能,然後再將這些按鈕放到工具列中。
ThumbnailToolbarButton buttonFirst = new ThumbnailToolbarButton(
Win7TaskbarDemo.Properties.Resources.First, "First Image");buttonFirst.Enabled = true;buttonFirst.Click += buttonFirst_Click;ThumbnailToolbarButton buttonPrevious = new ThumbnailToolbarButton(
Win7TaskbarDemo.Properties.Resources.Previous, "Previous Image");buttonPrevious.Enabled = true;buttonPrevious.Click += buttonPrevious_Click;ThumbnailToolbarButton buttonNext = new ThumbnailToolbarButton(
Win7TaskbarDemo.Properties.Resources.Next, "Next Image");buttonPrevious.Enabled = true;buttonNext.Click += buttonNext_Click;ThumbnailToolbarButton buttonLast = new ThumbnailToolbarButton(
Win7TaskbarDemo.Properties.Resources.Last, "Last Image");buttonPrevious.Enabled = true;buttonLast.Click += buttonLast_Click;
ThumbnailToolbarManager.AddButtons 方法
AddButtons 方法參考:
public void AddButtons(IntPtr windowHandle, params ThumbnailToolbarButton[] buttons);public void AddButtons(UIElement control, params ThumbnailToolbarButton[] buttons);
將四個按鈕放入工具列中,注意按鈕的前後順序:
TaskbarManager.Instance.ThumbnailToolbars.AddButtons( new WindowInteropHelper(Application.Current.MainWindow).Handle, buttonFirst, buttonPrevious, buttonNext, buttonLast);
效果示範
如所示,應用程式本身的功能是:“選擇ListBox 中的圖片後,同步更新ListBox 上方的放大圖片。” 如果將滑鼠置於工作列表徵圖上方,便可看到我們剛剛製作的縮圖工具列,可通過裡面的四個功能按鈕切換ListBox 中的圖片以達到與程式一樣的功能效果。
相關參考資料
1. Windows API Code Pack for .NET Framework
http://code.msdn.microsoft.com/WindowsAPICodePack
2. Thumbnail Toolbars
http://msdn.microsoft.com/en-us/library/dd378460(VS.85).aspx#thumbbars
3. Windows 7 工作列開發 之 縮圖預覽(Thumbnail)
http://www.cnblogs.com/gnielee/archive/2010/03/08/windows7-taskbar-thumbnail-preview.html
原始碼下載
包含之前所有執行個體: