背水一戰 Windows 10 (37) - 控制項(彈出類): MessageDialog, ContentDialog

来源:http://www.cnblogs.com/webabcd/archive/2016/09/28/5915058.html
-Advertisement-
Play Games

背水一戰 Windows 10 之 控制項(彈出類): MessageDialog, ContentDialog ...


[源碼下載]


背水一戰 Windows 10 (37) - 控制項(彈出類): MessageDialog, ContentDialog



作者:webabcd


介紹
背水一戰 Windows 10 之 控制項(彈出類)

  • MessageDialog
  • ContentDialog



示例
1、MessageDialog 的示例
Controls/FlyoutControl/MessageDialogDemo.xaml

<Page
    x:Class="Windows10.Controls.FlyoutControl.MessageDialogDemo"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Windows10.Controls.FlyoutControl"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <Grid Background="Transparent">
        <StackPanel Margin="10 0 10 10">

            <TextBlock Name="lblMsg" Margin="5" />

            <Button Name="btnShowMessageDialogSimple" Margin="5" Content="彈出一個簡單的 MessageDialog" Click="btnShowMessageDialogSimple_Click" />

            <Button Name="btnShowMessageDialogCustomCommand" Margin="5" Content="彈出一個自定義命令按鈕的 MessageDialog" Click="btnShowMessageDialogCustomCommand_Click" />

        </StackPanel>
    </Grid>
</Page>

Controls/FlyoutControl/MessageDialogDemo.xaml.cs

/*
 * MessageDialog - 信息對話框(未繼承任何類)
 *     Content - 內容
 *     Title - 標題
 *     Options - 選項(Windows.UI.Popups.MessageDialogOptions 枚舉)
 *         None - 正常,預設值
 *         AcceptUserInputAfterDelay - 為避免用戶誤操作,彈出對話框後短時間內禁止單擊命令按鈕
 *     Commands - 對話框的命令欄中的命令集合,返回 IList<IUICommand> 類型的數據
 *     DefaultCommandIndex - 按“enter”鍵後,激發此索引位置的命令
 *     CancelCommandIndex - 按“esc”鍵後,激發此索引位置的命令
 *     ShowAsync() - 顯示對話框,並返回用戶激發的命令
 *     
 * IUICommand - 命令
 *     Label - 顯示的文字
 *     Id - 參數
 */

using System;
using Windows.UI.Popups;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;

namespace Windows10.Controls.FlyoutControl
{
    public sealed partial class MessageDialogDemo : Page
    {
        public MessageDialogDemo()
        {
            this.InitializeComponent();
        }

        // 彈出一個簡單的 MessageDialog
        private async void btnShowMessageDialogSimple_Click(object sender, RoutedEventArgs e)
        {
            MessageDialog messageDialog = new MessageDialog("內容", "標題");

            await messageDialog.ShowAsync();
        }

        // 彈出一個自定義命令按鈕的 MessageDialog
        private async void btnShowMessageDialogCustomCommand_Click(object sender, RoutedEventArgs e)
        {
            MessageDialog messageDialog = new MessageDialog("內容", "標題");

            messageDialog.Commands.Add
            (
                new UICommand
                (
                    "自定義命令按鈕1",
                    (command) =>
                    {
                        lblMsg.Text = string.Format("command label:{0}, id:{1}", command.Label, command.Id);
                    },
                    "param1"
                )
            );

            messageDialog.Commands.Add
            (
                new UICommand
                (
                    "自定義命令按鈕2", 
                    (command) =>
                    {
                        lblMsg.Text = string.Format("command label:{0}, id:{1}", command.Label, command.Id);
                    }, 
                    "param2"
                )
            );

            messageDialog.Commands.Add
            (
                new UICommand
                (
                    "自定義命令按鈕3", 
                    (command) =>
                    {
                        lblMsg.Text = string.Format("command label:{0}, id:{1}", command.Label, command.Id);
                    }, 
                    "param3"
                )
            );

            messageDialog.DefaultCommandIndex = 0; // 按“enter”鍵後,激發第 1 個命令
            messageDialog.CancelCommandIndex = 2; // 按“esc”鍵後,激發第 3 個命令
            messageDialog.Options = MessageDialogOptions.AcceptUserInputAfterDelay; // 對話框彈出後,短時間內禁止用戶單擊命令按鈕,以防止用戶的誤操作

            // 顯示對話框,並返回用戶激發的命令
            IUICommand chosenCommand = await messageDialog.ShowAsync();

            lblMsg.Text += Environment.NewLine;
            lblMsg.Text += string.Format("result label:{0}, id:{1}", chosenCommand.Label, chosenCommand.Id);
        }
    }
}


2、ContentDialog 的示例
Controls/FlyoutControl/CustomContentDialog.xaml

<ContentDialog
    x:Class="Windows10.Controls.FlyoutControl.CustomContentDialog"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Windows10.Controls.FlyoutControl"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d"
    
    Title="custom dialog title"
    PrimaryButtonText="primary button"  
    SecondaryButtonText="secondary button"
    PrimaryButtonClick="ContentDialog_PrimaryButtonClick"
    SecondaryButtonClick="ContentDialog_SecondaryButtonClick">

    <!--以下為自定義對話框的標題-->
    <ContentDialog.TitleTemplate>
        <DataTemplate>
            <TextBlock Text="custom dialog title" Foreground="Red" />
        </DataTemplate>
    </ContentDialog.TitleTemplate>

    <!--以下為自定義對話框的內容-->
    <StackPanel VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
        <TextBox Name="email" Header="Email address"/>
        <PasswordBox  Name="password" Header="Password"/>
        <CheckBox Name="showPassword" Content="Show password"/>

        <TextBlock Name="body" TextWrapping="Wrap">
            <TextBlock.Text>
                content content content content content content content content content content content content content content
            </TextBlock.Text>
        </TextBlock>
    </StackPanel>
    
</ContentDialog>

Controls/FlyoutControl/CustomContentDialog.xaml.cs

/*
 * 自定義 ContentDialog
 */

using System.Threading.Tasks;
using Windows.UI.Xaml.Controls;

namespace Windows10.Controls.FlyoutControl
{
    public sealed partial class CustomContentDialog : ContentDialog
    {
        public CustomContentDialog()
        {
            this.InitializeComponent();
        }

        // 用戶點擊了第一個按鈕
        private async void ContentDialog_PrimaryButtonClick(ContentDialog sender, ContentDialogButtonClickEventArgs args)
        {
            // 通過 GetDeferral() 來等待長時任務,否則即使 await 了也不會等
            ContentDialogButtonClickDeferral deferral = args.GetDeferral();
            try
            {
                await Task.Delay(1);
            }
            finally
            {
                // 完成非同步操作
                deferral.Complete();
            }

            // 使此事件可以冒泡(當然 args.Cancel 預設就是 false)
            args.Cancel = false;
        }

        // 用戶點擊了第二個按鈕
        private async void ContentDialog_SecondaryButtonClick(ContentDialog sender, ContentDialogButtonClickEventArgs args)
        {
            // 通過 GetDeferral() 來等待長時任務,否則即使 await 了也不會等
            ContentDialogButtonClickDeferral deferral = args.GetDeferral();
            try
            {
                await Task.Delay(1);
            }
            finally
            {
                // 完成非同步操作
                deferral.Complete();
            }

            // 使此事件可以冒泡(當然 args.Cancel 預設就是 false)
            args.Cancel = false;
        }
    }
}

Controls/FlyoutControl/ContentDialogDemo.xaml

<Page
    x:Class="Windows10.Controls.FlyoutControl.ContentDialogDemo"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Windows10.Controls.FlyoutControl"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <Grid Background="Transparent">
        <StackPanel Margin="10 0 10 10">

            <Button Name="btnShowDialog" Margin="5" Content="彈出一個標準的對話框" Click="btnShowDialog_Click" />

            <Button Name="btnShowCustomDialog" Margin="5" Content="彈出一個自定義的對話框" Click="btnShowCustomDialog_Click" />

            <TextBlock Name="lblMsg" Margin="5" />

        </StackPanel>
    </Grid>
</Page>

Controls/FlyoutControl/ContentDialogDemo.xaml.cs

/*
 * ContentDialog - 內容對話框(繼承自 ContentControl, 請參見 /Controls/BaseControl/ContentControlDemo/)
 *     FullSizeDesired - 是否全屏彈出對話框
 *     Title, TitleTemplate - 對話框的標題(可以自定義樣式)
 *     Content, ContentTemplate - 對話框的內容(可以自定義樣式)
 *     PrimaryButtonText - 對話框第一個按鈕顯示的文本
 *     SecondaryButtonText - 對話框第二個按鈕顯示的文本
 *     PrimaryButtonCommand, PrimaryButtonCommandParameter, SecondaryButtonCommand, SecondaryButtonCommandParameter - 按鈕命令及命令參數
 *     
 *     PrimaryButtonClick - 第一個按鈕按下時觸發的事件
 *     SecondaryButtonClick - 第二個按鈕按下時觸發的事件
 *     Closed, Closing, Opened - 顧名思義的一些事件
 *     
 *     ShowAsync() - 彈出對話框
 *     Hide() - 隱藏對話框
 *     
 * 
 * 註意:自定義的內容對話框參見 CustomContentDialog.xaml
 */

using System;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;

namespace Windows10.Controls.FlyoutControl
{
    public sealed partial class ContentDialogDemo : Page
    {
        public ContentDialogDemo()
        {
            this.InitializeComponent();
        }

        private async void btnShowDialog_Click(object sender, RoutedEventArgs e)
        {
            ContentDialog dialog = new ContentDialog()
            {
                Title = "dialog title",
                Content = "dialog content, dialog content, dialog content, dialog content, dialog content, dialog content, dialog content",
                FullSizeDesired = true,
                PrimaryButtonText = "PrimaryButton",
                SecondaryButtonText = "SecondaryButton"
            };

            dialog.PrimaryButtonClick += dialog_PrimaryButtonClick;
            dialog.SecondaryButtonClick += dialog_SecondaryButtonClick;

            // 彈出對話框,返回值為用戶的選擇結果
            /*
             * ContentDialogResult.Primary - 用戶選擇了第一個按鈕
             * ContentDialogResult.Secondary - 用戶選擇了第二個按鈕
             * ContentDialogResult.None - 用戶沒有選擇(按了系統的“返回”按鈕)
             */
            ContentDialogResult result = await dialog.ShowAsync();
            if (result == ContentDialogResult.Primary)
            {
                lblMsg.Text += "選擇了第一個按鈕";
                lblMsg.Text += Environment.NewLine;
            }
            else if (result == ContentDialogResult.Secondary)
            {
                lblMsg.Text += "選擇了第二個按鈕";
                lblMsg.Text += Environment.NewLine;
            }
            else if (result == ContentDialogResult.None)
            {
                lblMsg.Text += "沒有選擇按鈕";
                lblMsg.Text += Environment.NewLine;
            }
        }

        void dialog_PrimaryButtonClick(ContentDialog sender, ContentDialogButtonClickEventArgs args)
        {
            lblMsg.Text += "點擊了第一個按鈕";
            lblMsg.Text += Environment.NewLine;
        }

        void dialog_SecondaryButtonClick(ContentDialog sender, ContentDialogButtonClickEventArgs args)
        {
            lblMsg.Text += "點擊了第二個按鈕";
            lblMsg.Text += Environment.NewLine;
        }


        // 彈出自定義對話框
        async private void btnShowCustomDialog_Click(object sender, RoutedEventArgs e)
        {
            // 實例化自定義對話框
            CustomContentDialog contentDialog = new CustomContentDialog();

            // 彈出對話框,返回值為用戶的選擇結果
            /*
             * ContentDialogResult.Primary - 用戶選擇了第一個按鈕
             * ContentDialogResult.Secondary - 用戶選擇了第二個按鈕
             * ContentDialogResult.None - 用戶沒有選擇(按了系統的“返回”按鈕)
             */
            ContentDialogResult result = await contentDialog.ShowAsync();
            if (result == ContentDialogResult.Primary)
            {
                lblMsg.Text += "選擇了第一個按鈕";
                lblMsg.Text += Environment.NewLine;
            }
            else if (result == ContentDialogResult.Secondary)
            {
                lblMsg.Text += "選擇了第二個按鈕";
                lblMsg.Text += Environment.NewLine;
            }
            else if (result == ContentDialogResult.None)
            {
                lblMsg.Text += "沒有選擇按鈕";
                lblMsg.Text += Environment.NewLine;
            }
        }
    }
}



OK
[源碼下載]


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • .NET Core 超強性能測試組件BenchmarkDotNet 支持Full .NET Framework, .NET Core (RTM), Mono。 BenchmarkDotNet支持 C#, F#, 和Visual Basic,可以跨平臺運行。 而且支持各種報表導出,相當的方便。 Git ...
  • 命名空間:(記得引入ASPJPEGLib.dll) usingAspose.Words; 1.創建word模版,使用MergeFeild綁定數據 新建一個Word文檔,命名為Template.doc 打開Template.doc必須在菜單的"插入→文檔部件→域”找到MergeField並輸入相應的域 ...
  • Aspose.Cells導出excel,處理Datatable,下載地址編碼(中文),虛擬路徑&物理路徑 ...
  • ColorConsole htmlagilitypack.1.4.9.5 經測試效率比 CsQueryLaster 高 csvhelper Extend Devlib系列一套 itextsharp litedb log4net microsoft.bcl一套,.net4 await 用 MySql. ...
  • ADO.NET:數據訪問技術 就是將C#和MSSQL連接起來的一個紐帶 可以通過ADO.NET將記憶體中的臨時數據寫入到資料庫中也可以將資料庫中的數據提取到記憶體中供程式調用 所有數據訪問技術的基礎 連接資料庫基本格式:需要兩個類1、資料庫連接類 SqlConnection2、資料庫操作類 SqlCom ...
  • 添加引用InTheHand.Net.Personal.dll 首先創建一個藍牙類 然後就是搜索設備 藍牙的配對 客戶端 伺服器端 基本上就是這些吧! ...
  • 只是想簡單說下特性 - Attribute 【博主】反骨仔 【原文地址】http://www.cnblogs.com/liqingwen/p/5911289.html 目錄 特性簡介 使用特性 特性的參數 特性的目標 特性的常見用途 創建自定義的特性 使用反射訪問特性 特性簡介 使用特性 特性的參數 ...
  • 前段時間在改Bug打開一個project時,發生了一件奇怪的事,好好的一直不能載入solution底下的這個project,錯誤如下圖所示:大致的意思就是這個project的web server被配置成了IIS Express,但是當前URL被配置成local IIS web server。要想打開 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...