Click here to Skip to main content
15,993,913 members
Articles / Programming Languages / C#

Charm Notification Component

Rate me:
Please Sign up or sign in to vote.
4.90/5 (26 votes)
2 Aug 2016LGPL32 min read 16.3K   1.6K   29   5
Gorgeous notification component for creating advanced notifications

This GIF is lagging, for better viewing, I suggest you check the demo application.

Introduction

The CharmNotification is a component that allows you to create customized notifications that slide from the right to the left side of the bottom-right side of the screen.

Thanks to this component, you'll be able to customize the colors, icon, etc. of your notification or you can simply create new ones at Run-Time (as presented above).

Background

While coding or reading books, notifications like this (updates) appear in an attractive way with a cute tone, so I asked myself:

  • Why don't I create a free component that does the same thing?

Implementation

This component contains several properties, here I present them all and their functionalities:

  • BackColor1: The color of the left side of the notification
  • BackColor2: The color of the right side of the notification
  • Title: The title of the notification
  • Text: The text of the notification
  • TitleForeColor: The color of title of the notification
  • TextForeColor: The color of title of the notification
  • Icon: The icon the notification
  • Duration: The duration of the notification (1000 = 1 second)
  • PlayTone: The notification will play a tone if this bool will be set true

Layout

Using the Code

CharmNotification usage is made to be as easy as possible, however, you can manipulate it with codes or using the designer.

To fulfill the task and release your advanced notification, you can go through one of the two possible methodologies.

Easy Usage

  1. Drag and drop the component on the form.
  2. Edit the properties:

  3. Write this piece of code:
    C#
    notification1.ShowNotification();

Run-Time Usage

To create a customized notification, you can write this piece of code:

C#
Notification n = new Notification();
n.Title = "Windows update";
n.Text = "Windows started updating, please do not turn off you computer.";
n.Duration = 3000;
n.Icon = Properties.Resources.windows_32;
n.BackColor2 = Color.FromArgb(35,35,35);
n.BackColor1 = Color.FromArgb(28, 28, 28);
n.TitleForeColor = Color.WhiteSmoke;
n.TextForeColor = Color.WhiteSmoke;
n.ShowNotification();

Result:

That's all of it, folks!

Points of Interest

Sometimes, you must rely on the simplest stuff to create the most complicated things.

History

  • 8/2/2016: First release

License

This article, along with any associated source code and files, is licensed under The GNU Lesser General Public License (LGPLv3)


Written By
Student
France France
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions

 
GeneralAdd Click Pin
Andrew Alex6-Feb-20 7:41
Andrew Alex6-Feb-20 7:41 
QuestionSweet Pin
jediYL16-Aug-16 17:27
professionaljediYL16-Aug-16 17:27 
GeneralMy vote of 5 Pin
Franc Morales2-Aug-16 11:43
Franc Morales2-Aug-16 11:43 
SuggestionMulti-Monitor Configuration Pin
GAAlex1-Aug-16 20:47
GAAlex1-Aug-16 20:47 
GeneralRe: Multi-Monitor Configuration Pin
RadiatorTwo1-Aug-16 22:35
RadiatorTwo1-Aug-16 22:35 
You could get the correct screen to use by Screen.PrimaryScreen instead of just using Screen in the Styler_Tick in the NotificationHost Control.
Or the Calling Form gets the Screen it´s on right now with Screen.FromControl(...) and passes it to the NotificationHost.

But even if you´d set it to the correct monitor it wouldn´t be usable right now.
You´d see it moving from the right screen onto the left screen.

So you´d also need some logic to resize the Notification Host, so only the left part is seen as it moves to the left.

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.