• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 55  文章 - 15  trackbacks - 0
            <2013年1月>
            303112345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            參考文獻:
            1. 31Days of Windows 8 -- Toast Notification:http://www.jeffblankenburg.com/2012/11/10/31-days-of-windows-8-day-10-toast-notifications/
            2. MSDN Toast Notification OverView:http://msdn.microsoft.com/en-us/library/windows/apps/hh779727.aspx
            3. Windows Store apps[9]通知概述(Toast,Tile和Badge)by 破船: http://blog.csdn.net/beyondvincent/article/details/7854641

            一。 為什么叫Toast?
                  因為很想吐司機,當面包烤好之后,就會彈出到你面前。當有Voip Call或者一條聊天信息到來的時候,就會彈出到你的屏幕上。
                  Toast可以顯示在Desktop上,Windows 8 界面上,或者其他程序中。下圖是一個顯示在Desktop上的Toast。

            二。 一個屏幕上最多顯示3個Toast,Toast沒有類似Tile的隊列,他們的位置是見空插針式的。
            三。 Toast類似于Tile,都可以用于啟動應用程序。如果點擊Toast,應用程序之前是關閉著的,那么將調用OnLaunched方法,如果程序之前是開啟著的,將不調用該方法。另外,可以設置Toast 的 XML Dom對象中的launch屬性,可以傳遞參數給OnLaunched方法。等下有講。
            四。 Toast是主動顯示在屏幕上的,Tile是被動的。
            五。 要在Manifest里面設置Toast Capability為True。


            類似于Tile,有三種方法可以實現Local Toast:使用Dom API, 使用String, 使用微軟提供的NotificationExtassion庫。事實證明,最后一種方便些。下面是這三種方法的具體實現步驟,都有注釋,可以簡單了解一下流程。

            第一種:使用API函數:

             1void MainPage::toastByUsingAPIs()
             2{
             3    //使用ToastImageAndText02模板,類似于Tile 包含一個圖片和兩段文字
             4    ToastTemplateType toastType = ToastTemplateType::ToastImageAndText02;
             5    //通過ToastNotificationManager獲得DOM對象
             6    XmlDocument^ toastXML = ToastNotificationManager::GetTemplateContent(toastType);
             7    //設置text和image屬性
             8    XmlNodeList^ toastText = toastXML->GetElementsByTagName("text");
             9    XmlNodeList^ toastImage = toastXML->GetElementsByTagName("image");
            10    toastText->Item(0)->InnerText = "Funny cat";
            11    toastText->Item(1)->InnerText = "This cat is looks like kitty";
            12    safe_cast<XmlElement^>(toastImage->Item(0))->SetAttribute("src","cat.png");
            13    safe_cast<XmlElement^>(toastImage->Item(0))->SetAttribute("alt","My Cat");
            14    //option code 因為要使用循環的聲音,所以要在Toast屬性中加入duration屬性,并設置為long,
            15    //如果注釋掉該屬性的話,那么將會使用默認的聲音,時間也很短
            16
            17    //這里使用"toast"和"/toast"效果一樣
            18    IXmlNode^ toastNode = toastXML->SelectSingleNode("toast");
            19
            20    //safe_cast<XmlElement^>(toastNode)->SetAttribute("duration","111"); 如果這么用,不會出來Toast,也不會出現運行時錯誤。
            21    //safe_cast<XmlElement^>(toastNode)->SetAttribute("duration","short");使用默認的聲音,時間很短
            22
            23    //所以,我們還是乖乖地使用long吧
            24    safe_cast<XmlElement^>(toastNode)->SetAttribute("duration","long");//循環時的聲音用
            25    //插入audio節點
            26    XmlElement^ audioNode = toastXML->CreateElement("audio");
            27    //設置audio屬性
            28    audioNode->SetAttribute("src""ms-winsoundevent:Notification.Looping.Alarm");
            29    //這里一樣,如果是loop的聲音,必須要設置loop屬性,并且賦值為true
            30    audioNode->SetAttribute("loop","true");
            31    //插入子節點
            32    toastNode->AppendChild(audioNode);
            33    //這里就是點擊Toast時,傳入的參數了
            34    safe_cast<XmlElement^>(toastNode)->SetAttribute("launch","Toast");
            35    
            36    ToastNotification^ toast = ref new ToastNotification(toastXML);
            37    _toast = toast;
            38    //有3種方法可以使Toast消失,用戶取消(點擊Toast上的關閉按鈕),超時,使用ToastNotifier->Hide(toast)方法
            39    _toast->Dismissed += ref new Windows::Foundation::TypedEventHandler<ToastNotification^,ToastDismissedEventArgs^>(this,&MainPage::toastDismissed);
            40    //如果因為什么原因Toast失敗的話會觸發該事件
            41    _toast->Failed += ref new Windows::Foundation::TypedEventHandler<ToastNotification^,ToastFailedEventArgs^>(this,&MainPage::toastFalied);
            42    //Show it!
            43    ToastNotificationManager::CreateToastNotifier()->Show(toast);
            44}

             
            可以看到,這種方法我們要耗費大量的時間來設置Xml文件的屬性,太麻煩了。


            下面是我們的Dismissed方法:

             1void Toast::MainPage::toastDismissed(ToastNotification^ sender, ToastDismissedEventArgs^ args)
             2{
             3    String^ output = "";
             4    switch(args->Reason)
             5    {
             6    case ToastDismissalReason::ApplicationHidden:
             7        output = "The app hide the toast using ToastNotifier->Hide(toast)";
             8        break;
             9    case ToastDismissalReason::TimedOut:
            10        output = "The toast has time out";
            11        break;
            12    case ToastDismissalReason::UserCanceled:
            13        output = "User Canceled toast";
            14        break;
            15    }

            16    // 這里使用Dispatcher將其調度到UI線程,不是很理解,難道當Dismiss事件被觸發的時候,使用了異步操作?
            17    // 我的感覺是這個方法還是在UI線程之中,但是只使用outputText->Text = output是沒有結果的。
            18    // 想想看應該是異步的,當你的Toast消失的時候,會花很大時間來處理
            19    // 好吧,暫時得出這種結論,這種回掉函數都默認為異步的。
            20    Dispatcher->RunAsync(Windows::UI::Core::CoreDispatcherPriority::Normal,ref new Windows::UI::Core::DispatchedHandler([this,output](){
            21        outputText->Text = output;
            22    }
            ,CallbackContext::Any));
            23}


            第二種:程序內使用Xml string:

             1void MainPage::toastByUsingString()
             2{
             3    String^ toastXmlString = "";
             4    //我承認,用String也不方便,因為,你可能多寫了一個空格,或者多打了一個單引號,就會導致你的Toast不能出來
             5    toastXmlString = L"<toast duration='long' launch='Toast'>"
             6        + "<visual version ='1'>"
             7        + "<binding template='ToastImageAndText02'>"
             8        + "<text id='1'>Funny Cat</text>"
             9        + "<text id='2'>This cat is looks like kitty</text>"
            10        + "<image id='1' src='cat.png' alt='My Cat'/>"
            11        + "</binding>"
            12        + "</visual>"
            13        + "<audio src='ms-winsoundevent:Notification.Looping.Alarm' loop='true'/>"
            14        + "</toast>";
            15
            16    XmlDocument^ toastDom = ref new Windows::Data::Xml::Dom::XmlDocument();
            17    try
            18    {
            19        toastDom->LoadXml(toastXmlString);
            20        outputText->Text = toastDom->GetXml();
            21        auto toast = ref new ToastNotification(toastDom);
            22        ToastNotificationManager::CreateToastNotifier()->Show(toast);
            23    }
            catch(Exception^ e)
            24    {
            25        outputText->Text = e->Message;
            26    }

            27}

            這種方法的優點是,一目了然,可以直接看出Xml結構,缺點是,簡單的輸入錯誤就會導致Toast不出現。
             
            第三種:使用微軟的NotificationsExtasions庫 還是比較方便的,各種屬性直接設置就好了。但是我自己還沒試過。。。

             1    IToastText02^ toastContent = ToastContentFactory::CreateToastText02();
             2    toastContent->TextHeading->Text = "Sound:";
             3    toastContent->TextBodyWrap->Text = audioSrc;
             4
             5    toastContent->Audio->Content = audioContent;
             6
             7    OutputText(toastContent->GetContent());
             8
             9    // Create a toast, then create a ToastNotifier object to show
            10    // the toast
            11    auto toast = toastContent->CreateNotification();
            12
            13    // If you have other applications in your package, you can specify the AppId of
            14    // the app to create a ToastNotifier for that application
            15    ToastNotificationManager::CreateToastNotifier()->Show(toast);


            最后一點,我們的App.Xaml.Cpp中的OnLuanched方法:

             1void App::OnLaunched(Windows::ApplicationModel::Activation::LaunchActivatedEventArgs^ args)
             2{
             3    
             4
             5    auto rootFrame = dynamic_cast<Frame^>(Window::Current->Content);
             6    if(args->Arguments == "Toast")
             7    {
             8        if(!rootFrame->Navigate(TypeName(FromToast::typeid),args->Arguments))
             9        {
            10            throw ref new FailureException("Failed to create fromToast page");
            11        }

            12    }


            點擊的結果就是:



            有什么問題大家可以盡情的提哈,我也是新手,共同提高。

            posted on 2013-01-04 16:11 Dino-Tech 閱讀(2852) 評論(0)  編輯 收藏 引用
            欧美午夜A∨大片久久 | 99久久国产亚洲综合精品| 天天综合久久一二三区| 亚洲av日韩精品久久久久久a| 久久久久久亚洲AV无码专区| 狠狠人妻久久久久久综合蜜桃| 亚洲国产一成久久精品国产成人综合| 国产亚洲精久久久久久无码77777| 久久精品中文闷骚内射| 久久激情五月丁香伊人| 久久国产精品无码一区二区三区| 国产成人香蕉久久久久| 久久精品无码午夜福利理论片| 91麻精品国产91久久久久| 久久精品国产清自在天天线 | 亚洲国产精品综合久久一线| 久久亚洲精精品中文字幕| 九九久久精品国产| 国产精品久久亚洲不卡动漫| 国产亚洲精久久久久久无码77777| 国产日韩欧美久久| 久久天堂电影网| 久久久久亚洲AV成人片| 久久午夜无码鲁丝片秋霞| 久久久WWW成人免费毛片| 久久中文字幕一区二区| 久久精品国产亚洲AV无码偷窥| 久久精品桃花综合| 无码国内精品久久人妻麻豆按摩| 国产一级持黄大片99久久| 久久久久AV综合网成人| 亚洲午夜久久久影院伊人| 久久久久久久91精品免费观看| 久久精品国产清自在天天线| 国产精品久久久久久久午夜片 | 久久综合视频网站| 久久国产乱子伦精品免费午夜| 青青草国产精品久久| 99久久无码一区人妻| 久久精品成人| 久久久久久国产a免费观看黄色大片|