溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在C# 中利用WPF 建立一個(gè)無邊框的登錄窗口

發(fā)布時(shí)間:2020-12-15 14:45:58 來源:億速云 閱讀:306 作者:Leah 欄目:開發(fā)技術(shù)

今天就跟大家聊聊有關(guān)如何在C# 中利用WPF 建立一個(gè)無邊框的登錄窗口,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

 實(shí)現(xiàn)方法

WPF做這樣的窗口非常簡單,只有需在窗口設(shè)計(jì)中設(shè)置兩個(gè)屬性,一個(gè)是AllowsTransparency, 設(shè)置為 Ture;  一個(gè)是 WindowStyle, 設(shè)置為 None。

如何在C# 中利用WPF 建立一個(gè)無邊框的登錄窗口

注:是Window的屬性,不要選中其他的控件。

另外,如果AllowsTransparency="True",那么 WindowStyle只能為 None, VS2015 已經(jīng)做到連動(dòng)設(shè)置,只要勾選AllowsTransparency,后一個(gè)也跟著變了。但 VS2008 還是需要用戶分別設(shè)置,不然會(huì)報(bào)錯(cuò)。

還有一個(gè)問題不得不提,AllowsTransparency="True" 之后就無法使用 WindowsFormsHost控件了,因?yàn)榫退阌昧?,WFH里的任何控件也是透明無法顯示出來的,比如ReportViewer!

窗口任意空白地方實(shí)現(xiàn)鼠標(biāo)拖拽

標(biāo)題欄上有最大化最小化和關(guān)閉的按鈕,其中在登錄窗口我們一般是不會(huì)使用最大化按鈕的??墒遣坏貌徽f,標(biāo)題欄還有一個(gè)很實(shí)用的作用,就是可以拖拽整個(gè)窗口,用戶只要單擊標(biāo)題欄不放,就可以拖到桌面的任何地方。如今把標(biāo)題欄隱藏之后,該如何彌補(bǔ)呢?

為窗口添加一個(gè) MouseLeftButtonDown 的事件,代碼如下:

private void Window_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
    {
      try
      {
        this.DragMove();
      }
      catch { }
    }

這樣就OK了!

注:網(wǎng)上有些示例里,沒有用 try{}catch{},而只有一行代碼

this.DragMove();

如果在登錄窗口,只有那么幾個(gè)控件和事件的話,應(yīng)該也是無大礙的。

在這里筆者有個(gè)小小的經(jīng)驗(yàn)必須分享一下:

由于在主界面里也使用了這種無標(biāo)題欄的窗口,鼠標(biāo)在Gridview上操作時(shí),經(jīng)常會(huì)引發(fā)異常崩潰。

所以筆者認(rèn)為最好加 try...catch... 避免異常,哪怕是登錄窗口也不例外。

 輸入密碼后按回車登錄

很多網(wǎng)站會(huì)注意這種情況,輸入密碼后回車,系統(tǒng)就可以登錄,這就是良好的用戶體驗(yàn)。(當(dāng)然,也有些網(wǎng)站不注意用戶體驗(yàn),用戶必須用鼠標(biāo)去點(diǎn)擊登錄的)

其實(shí)在密碼框添加一個(gè) KeyDown 事件就可以

private void txt_Pwd_KeyDown(object sender, KeyEventArgs e)
    {
      switch (e.Key)
      {
        case Key.Enter:
          btn_login_Click(btn_login, null);
          break;

        default:
          break;
      }
    }

So easy !

按Enter(回車)跳到下一控件

提到回車登錄,順便提一下,有些人不喜歡輸入用戶名后,又要用鼠標(biāo)移到密碼框,又鍵盤又鼠標(biāo),比如筆者。

事實(shí)上 Tab鍵 可以讓用戶在比較簡單的界面擺脫鼠標(biāo),不過要注意在窗口設(shè)計(jì)時(shí)調(diào)好控件的 TabIndex 順序。

當(dāng)然在此基礎(chǔ)上也可以加一個(gè) Enter 設(shè)置的功能,只要在后臺(tái)代碼重寫窗口的 OnKeyDown 事件,如下:

//按下回車后跳入下一個(gè)控件
    protected override void OnKeyDown(KeyEventArgs e)
    {
      if (e.Key == Key.Enter)
      {
        // MoveFocus takes a TraveralReqest as its argument.
        TraversalRequest request = new TraversalRequest(FocusNavigationDirection.Next);

        // Gets the element with keyboard focus.
        UIElement elementWithFocus = Keyboard.FocusedElement as UIElement;

        // Change keyboard focus.
        if (elementWithFocus != null)
        {
          elementWithFocus.MoveFocus(request);
        }
        e.Handled = true;
      }
      base.OnKeyDown(e);
    }

運(yùn)行時(shí)打開登錄窗口

登錄窗口畢竟不是主窗口,登錄后要關(guān)閉的,所以Startup的路徑不是登錄窗口,但登錄的時(shí)候是不能打開主窗口的,如果用戶關(guān)閉登錄窗口,退出程序。

實(shí)現(xiàn)方法:

項(xiàng)目下有一個(gè)App.xaml文件,Startup 指向主窗口的路徑,然后打開后臺(tái)代碼 App.xaml.cs,重寫OnStartup事件,判斷一下登錄窗口的 DialogResult 如果返回ture,就正常打開主窗口,如果為 false,則關(guān)閉整個(gè)程序。代碼:

//打開登錄窗口,成功后進(jìn)入主窗口
    protected override void OnStartup(StartupEventArgs e)
    {
      try
      {
        OneInstanceOnly();//僅運(yùn)行一個(gè)實(shí)例
//#if !DEBUG
        // 運(yùn)行登錄窗口
        Application.Current.ShutdownMode = System.Windows.ShutdownMode.OnExplicitShutdown;
        LoginWindow window = new LoginWindow();
        bool? dialogResult = window.ShowDialog();
        if (Utils.IsTrue(dialogResult))
        {
          base.OnStartup(e);
          Application.Current.ShutdownMode = ShutdownMode.OnMainWindowClose;
        }
        else
        {
          this.Shutdown();
        }
//#endif
      }
      catch (Exception ex)
      {
        UIUtils.ShowException(ex);
      }
    }

看完上述內(nèi)容,你們對(duì)如何在C# 中利用WPF 建立一個(gè)無邊框的登錄窗口有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

wpf
AI