data:image/s3,"s3://crabby-images/133f8/133f8fa0942ac6748920f71649fc92f5d3b995ab" alt="releases" data:image/s3,"s3://crabby-images/99caa/99caac01d1a8ce820b0cf8e1da08b3c3c3ba250a" alt="issues" data:image/s3,"s3://crabby-images/a0c26/a0c26834dbe23577c4927ea5b94803194ed3a60d" alt="license" data:image/s3,"s3://crabby-images/91bf8/91bf8e066a79f4313761c18ebf772d87c0baf52d" alt="built" [data:image/s3,"s3://crabby-images/90d79/90d79fd8924a38b68f3eb13b371cdc992e904cdc" alt="GitHub forks"]() [data:image/s3,"s3://crabby-images/cf951/cf95194cfe86f8a78e1e6ebef1c378a02a18ca57" alt="GitHub stars"]() [data:image/s3,"s3://crabby-images/39023/39023be87f08ba9db59ca1fd55a9a3cc97f2a1e2" alt="GitHub watchers"]() *** WinToast =================== WinToast is a lightly library written in C++ which brings a complete integration of the modern **toast notifications** of **Windows 8** & **Windows 10**. Toast notifications allows your app to inform the users about relevant information and timely events that they should see and take action upon inside your app, such as a new instant message, a new friend request, breaking news, or a calendar event. 1. [Toast Templates](#id1) 2. [Event Handler](#id3) 3. [Expiration Time](#id4) 4. [Additional features available on Windows 10](#id5) 5. [Error Handling](#id2) 6. [Example of usage](#id6) 7. [Toast configuration on Windows 10](#id7) 8. [Projects using WinToast](#id8)
## Toast Templates WinToast integrates all standard templates available in the [ToastTemplateType enumeration](https://msdn.microsoft.com/en-us/library/windows/apps/br208660.aspx). | Template | Description | Example | | :------- | ----: | :---: | | `ImageAndText01` | A large image and a single string wrapped across three lines of text. | data:image/s3,"s3://crabby-images/f4094/f4094945b9f98108ff69ab3ba627cc23f58ee59a" alt="enter image description here" | | `ImageAndText02` | A large image, one string of bold text on the first line, one string of regular text wrapped across the second and third lines. | data:image/s3,"s3://crabby-images/779cd/779cdac01dd755afe4fe4a0a6192cfe81fc65b7d" alt="12" | | `ImageAndText03` | A large image, one string of bold text wrapped across the first two lines, one string of regular text on the third line. | data:image/s3,"s3://crabby-images/483da/483da4958d0e805663b9455718a34c99c21ef69c" alt="enter image description here" | | `ImageAndText04` | A large image, one string of bold text on the first line, one string of regular text on the second line, one string of regular text on the third line. | data:image/s3,"s3://crabby-images/5eab4/5eab455e9ac6e6e1a89df88947cd60dc849d612c" alt="enter image description here" | | `Text01` | Single string wrapped across three lines of text. | data:image/s3,"s3://crabby-images/96fe6/96fe64f9af5456912efa843dca8f3e1a053b24fd" alt="enter image description here"| | `Text02` | One string of bold text on the first line, one string of regular text wrapped across the second and third lines. | data:image/s3,"s3://crabby-images/3ccbb/3ccbba9457af14598ae337be971e4b2654662eb8" alt="enter image description here" | | `Text03` | One string of bold text wrapped across the first two lines, one string of regular text on the third line. | data:image/s3,"s3://crabby-images/0377b/0377b53b92cd64159c27a1661052f611e3d73667" alt="enter image description here"| | `Text04` | One string of bold text on the first line, one string of regular text on the second line, one string of regular text on the third line. | data:image/s3,"s3://crabby-images/d15d2/d15d21378362e1358f6d39539bdbe55c3031a1a0" alt="enter image description here" | Example of a `ImageAndText02` template: ```cpp WinToastTemplate templ = WinToastTemplate(WinToastTemplate::ImageAndText02); templ.setTextField(L"title", WinToastTemplate::FirstLine); templ.setTextField(L"subtitle", WinToastTemplate::SecondLine); templ.setImagePath(L"C:/example.png"); ``` **Note:** The user can use the default system sound or specify a sound to play when a toast notification is displayed. Same behavior for the toast notification image, by default Windows try to use the app icon.* ## Event Handler WinToast handle different events: - **Activated**: Occurs when user activates a toast notification through a click or touch. Apps that are running subscribe to this event - **Dismissed**: Occurs when a toast notification leaves the screen, either by expiring or being explicitly dismissed by the user. * Application Hidden: The application hid the toast using ToastNotifier.hide. * User Canceled: The user dismissed the toast. * Timed Out: The toast has expired - **Failed**: Occurs when an error is caused when Windows attempts to raise a toast notification. Create your custom handler to interact with the user actions by subclassing the interface `IWinToastHandler`: ```cpp class WinToastHandlerExample : public IWinToastHandler { public: WinToastHandlerExample(); // Public interfaces void toastActivated() const override; void toastDismissed(WinToastDismissalReason state) const override; void toastFailed() const override; }; ``` ## Expiration Time Set the time after which a toast notification is no longer considered current or valid and should not be displayed. Windows attempts to raise toast notifications immediately after you call Show, so this property is rarely used. > For Windows 8.x app, this property also causes the toast notification to be removed from the > Action Center once the specified data and time is reached. **Note:** Default Windows behavior is to hide notification automatically after time set in Windows Ease of Access Settings. If you need to preserve notification in Windows Action Center for longer period of time, you have to call `WinToastTemplate::setExpiration` method. ## Additional features available on Windows 10 If your system supports the new modern features (Version > Windows 8.1) available in Windows 10, you can add some interesting fields as: - **Actions**: you can add your own actions, this fact allow you to interact with user in a different way: ```cpp WinToastTemplate templ = WinToastTemplate(WinToastTemplate::Text02); templ.setTextField(L"Do you think this feature is cool?", WinToastTemplate::FirstLine); templ.setTextField(L"Ofc,it is!", WinToastTemplate::SecondLine); std::vector