WPF中窗體最大化問題的解決方法
前言
在創(chuàng)建WPF應用的時候,你第一個看到的就是窗體類。它作為窗體的基礎,提供標準的邊框、工具條、最大化、最小化和關閉按鈕。WPF窗體是XAML文件和后臺代碼文件的混合體。
本文將詳細介紹關于WPF窗體最大化問題的相關內容,下面話不多說了,來一起看看詳細的介紹吧
遇到的問題信息
問題:當WindowStyle=None時,窗口最大化,不顯示任務欄 —— 即窗體是全屏效果。
解決中遇到的問題列表【主要涉及到任務欄發(fā)生改變后的一些問題處理】:
- 最大化時,任務欄被遮蓋;
 - 最大化后,拖動任務欄,無法自適應窗體;
 - 最大化后,拖動任務欄,窗體還原,還原數(shù)據(jù)丟失,始終顯示最大;
 - 最大化后,拖動任務欄,窗體還原,設置之前保存的窗體位置數(shù)據(jù),再次設置,由于和之前一樣,窗體位置信息不生效;
 
解決方案
思路:窗體最大化時,將窗體透明化,設置內部元素Grid的Margin屬性,從而顯示出任務欄
步驟:
1、 設置窗體相關屬性:WindowStyle="None" AllowsTransparency="True" Background="Transparent" ResizeMode="CanMinimize"
窗體需要支持透明,并將窗體設置為透明;設置ResizeMode,否則最大化時,邊框會有影響。
2、 添加窗體最大化/還原代碼如下:
double normaltop;
double normalleft;
double normalwidth;
double normalheight;
/// <summary>
/// 最大化/還原處理
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Btn_maximize_Click(object sender, RoutedEventArgs e)
{
 //wpf最大化 全屏顯示任務欄處理
 if (this.WindowState == WindowState.Normal)
 {
 normaltop = this.Top;
 normalleft = this.Left;
 normalwidth = this.Width;
 normalheight = this.Height;
 double top = SystemParameters.WorkArea.Top;
 double left = SystemParameters.WorkArea.Left;
 double right = SystemParameters.PrimaryScreenWidth - SystemParameters.WorkArea.Right;
 double bottom = SystemParameters.PrimaryScreenHeight - SystemParameters.WorkArea.Bottom;
 gd_main.Margin = new Thickness(left, top, right, bottom);
 this.WindowState = WindowState.Maximized; 
 }
 else
 {
 this.WindowState = WindowState.Normal;
 //必須先設置為0,在重新設值,若前后值一樣,會失效 --拖動任務欄后,還原-始終顯示在屏幕最左上方
 this.Top = 0;
 this.Left = 0;
 this.Width = 0;
 this.Height = 0;
 this.Top = normaltop;
 this.Left = normalleft;
 this.Width = normalwidth;
 this.Height = normalheight;
 gd_main.Margin = new Thickness(0);
 }
}
3、添加任務欄變化處理
注意:此節(jié)實現(xiàn)僅適用于.Net Framework 4.5及以上。因為4.0及以前的版本中不包含StaticPropertyChanged事件。
不過可以通過WndProc來自己實現(xiàn),其中會有一個問題:利用WndProc來監(jiān)聽,結果是比較實時的,而SystemParameters中的值,實時性可能會跟不上,從而獲取到的值仍然是舊的。
對此有兩種解決方案:
* 1、添加一個Timer 或者 直接Sleep,等待一下在SystemParameters的值【此法相對簡單,但無法完全保證有效,畢竟SystemParameters中值更新的時間,還是要看.Net Framework】;
* 2、利用Windows API讀取系統(tǒng)值,用方法SystemParametersInfo獲取SPI_GETWORKAREA【微軟官方其實就是用這個獲取的,這樣比我下面的運行效率還要高些】
另外:下面的方法可能會有系統(tǒng)兼容性問題,我在Windows 10上是通過的,但在Windows 8.1上,邊界存在問題【不確定是不是Framework在系統(tǒng)上有bug】
注冊事件:SystemParameters.StaticPropertyChanged += SystemParameters_StaticPropertyChanged;
添加如下代碼:
private void SystemParameters_StaticPropertyChanged(object sender, System.ComponentModel.PropertyChangedEventArgs e)
{
 if (e.PropertyName == "WorkArea")
 {
 if (this.WindowState == WindowState.Maximized)
 {
  double top = SystemParameters.WorkArea.Top;
  double left = SystemParameters.WorkArea.Left;
  double right = SystemParameters.PrimaryScreenWidth - SystemParameters.WorkArea.Right;
  double bottom = SystemParameters.PrimaryScreenHeight - SystemParameters.WorkArea.Bottom;
  gd_main.Margin = new Thickness(left, top, right, bottom);
 }
 }
}
相關下載
點擊查看完整源代碼
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對我們的支持。
您可能感興趣的文章
- 01-10C#通過反射獲取當前工程中所有窗體并打開的方法
 - 01-10WinForm限制窗體不能移到屏幕外的方法
 - 01-10C#實現(xiàn)Winform中打開網頁頁面的方法
 - 01-10winform實現(xiàn)創(chuàng)建最前端窗體的方法
 - 01-10C#實現(xiàn)由四周向中心縮小的窗體退出特效
 - 01-10Extjs4如何處理后臺json數(shù)據(jù)中日期和時間
 - 01-10C#實現(xiàn)主窗體最小化后出現(xiàn)懸浮框及雙擊懸浮框恢復原窗體的方
 - 01-10C#實現(xiàn)更改MDI窗體背景顏色的方法
 - 01-10C#實現(xiàn)打開畫圖的同時載入圖片、最大化顯示畫圖窗體的方法
 - 01-10C#實現(xiàn)將窗體固定在顯示器的左上角且不能移動的方法
 


閱讀排行
本欄相關
- 01-10C#通過反射獲取當前工程中所有窗體并
 - 01-10關于ASP網頁無法打開的解決方案
 - 01-10WinForm限制窗體不能移到屏幕外的方法
 - 01-10WinForm繪制圓角的方法
 - 01-10C#實現(xiàn)txt定位指定行完整實例
 - 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
 - 01-10C#停止線程的方法
 - 01-10C#實現(xiàn)清空回收站的方法
 - 01-10C#通過重寫Panel改變邊框顏色與寬度的
 - 01-10C#實現(xiàn)讀取注冊表監(jiān)控當前操作系統(tǒng)已
 
隨機閱讀
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
 - 08-05織夢dedecms什么時候用欄目交叉功能?
 - 01-10使用C語言求解撲克牌的順子及n個骰子
 - 01-11ajax實現(xiàn)頁面的局部加載
 - 08-05DEDE織夢data目錄下的sessions文件夾有什
 - 04-02jquery與jsp,用jquery
 - 01-10delphi制作wav文件的方法
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 - 01-10C#中split用法實例總結
 - 01-10SublimeText編譯C開發(fā)環(huán)境設置
 


