用VisualC#编写仿MSNMessager的滚动提示窗口

visual

目录
引言
实现方法
作者简介

--------------------------------------------------------------------------------

引言
大家一定都用过MSN Messager了吧?每当有新邮件或者是新消息到来的时候,MSN Messager便会从右下角升起一个小窗口提醒您,然后又降下去。当你在聚精会神的在电脑上做一件事的时候,一定不会喜欢突然被"咚"一下出现在屏幕中心的对话框打扰,它的这种设计不但非常体贴用户,而且效果还很酷。如果您写了一个程序驻留在后台并要求在需要的时候会提醒用户,并且希望也能实现这种效果,那么请跟我一步一步来做下图所示的这个仿MSN Messager的滚动提示窗口。

--------------------------------------------------------------------------------

实现方法
效果示例图

第一步,建立一个Windows Application,然后在主form中放置一个Button,如下图所示:

第二步,给这个Application添加一个窗体(Form2),把窗体的FormBorderStyle属性设置为None(无边框模式),然后把TopMost属性(总在最上方)属性设置为True,把ShowInTaskbar属性(是否在 Windows 任务栏中显示窗体)设置为False,并在窗体上加上你打算要显示的文字(实际应用中一般是在程序中动态加载),将窗体的背景设置为你想要的图片和合适的大小。最后再放上三个Timer控件,其中,timer1控制窗体滚出的动画,timer2控制窗体停留时间,timer3控制窗体的滚入动画,将它们的Interval属性设置为10。参见下图

第四步,编写代码,在Form2中添加两个属性用来设置窗体的显示大小:
private int heightMax, widthMax;

public int HeightMax

{

 set

 {

  heightMax = value; 

 }

 get

 {

  return heightMax;

 }

}

public int WidthMax

{

 set

 {

  widthMax = value;

 }

 get

 {

  return widthMax;

 }

}

添加一个ScrollShow的公共方法:
public void ScrollShow()

{

 this.Width = widthMax;

 this.Height = 0;

 this.Show();

 this.timer1.Enabled = true;

}

添加一个StayTime属性设置窗体停留时间(默认为5秒):
public int StayTime = 5000;

添加ScrollUp和ScrollDown方法来编写窗体如何滚出和滚入:
private void ScrollUp()

{

 if(Height < heightMax)

 {

  this.Height += 3;

  this.Location = new Point(this.Location.X, this.Location.Y - 3);

 }

 else

 {

  this.timer1.Enabled = false;

  this.timer2.Enabled = true;

 }

}

private void ScrollDown()

{

 if(Height > 3)

 {

  this.Height -= 3;

  this.Location = new Point(this.Location.X, this.Location.Y + 3);

 }

 else

 {

  this.timer3.Enabled = false;

  this.Close();

 }

}

在三个Timer的Tick方法中分别写入:
private void timer1_Tick(object sender, System.EventArgs e)

{

 ScrollUp();

}

private void timer2_Tick(object sender, System.EventArgs e)

{

 timer2.Enabled = false;

 timer3.Enabled = true;

private void timer3_Tick(object sender, System.EventArgs e)

{

 ScrollDown();

}

在Form2的Load事件中初始化窗体变量:
private void Form2_Load(object sender, System.EventArgs e)

{

 Screen[] screens = Screen.AllScreens;

 Screen screen = screens[0];//获取屏幕变量

 this.Location = new Point(screen.WorkingArea.Width - widthMax - 20, screen.WorkingArea.Height - 34);//WorkingArea为Windows桌面的工作区

 this.timer2.Interval = StayTime;

}

好了,滚动窗体的代码编写到这里就完成了,当然,它本身只实现了一个比较简单的窗体滚动滚出效果,具体如何去应用还应该配合你的程序来完成。当然,你还可以为它添加更多的功能,比如从窗体的任意位置显示(这里只是从右下角显示),淡入淡出效果,加上声音等等。最常用的就是写一个托盘程序,然后采用这种提醒效果。如何用C#编写托盘程序请参见:用Visual C#做托盘程序http://www.yesky.com/20020110/213425.shtml
最后,我们再回到Form1,在Button的Click事件中写如下代码来测试一下效果:
private void button1_Click(object sender, System.EventArgs e)

{

 Form2 form = new Form2();

 form.HeightMax = 120;//窗体滚动的高度

 form.WidthMax = 148;//窗体滚动的宽度

 form.ScrollShow();

}

编译并运行程序,点击按纽,怎么样?是不是跟MSN Messager的效果一样,很酷吧?:)

--------------------------------------------------------------------------------

作者简介
作者:卢彦
Passport: nluyan@msn.com

时间: 2024-08-31 12:12:38

用VisualC#编写仿MSNMessager的滚动提示窗口的相关文章

源代码编写-最近在用java编写仿QQ聊天系统,编的不是很好,谁以前做过,参考一下。

问题描述 最近在用java编写仿QQ聊天系统,编的不是很好,谁以前做过,参考一下. 最近在用java编写仿QQ聊天系统,编的不是很好,谁以前做过,参考一下.

Android实现仿gallery垂直滚动的效果

Android实现仿gallery垂直滚动的效果  效果图:  附件里是整个工程,如果喜欢可以下载看下.我感觉挺复杂的,如果需要的时候可以研究下,哈哈 实现垂直滚动的gallery.rar

用JavaScript编写程序实现文本滚动

javascript|程序 在一些网页上,们经常看到一些滚动文本,很酷的,如何做呢? 下面我们就以徐志摩的一首<再别康桥>为例,用JavaScript编写一段程序,来实现文本的滚动. 1.运行Dreamweaver应用程序,单击工具栏中的"显示代码视图和设计视图"按钮, 在打开的代码窗口中,把下面这一段代码,插入到< head>区域中. < SCRIPT LANGUAGE="JavaScript"> < !-- Begin

基于编写jQuery的无缝滚动插件_jquery

首先来看下html骨架,如下: <div class="box"> <ul> <li>111</li> <li>222</li> <li>333</li> </ul> </div> 结构简单明了,没什么说的. 讲下实现原理: div box是最外层盒子,给它指定的宽高,记得给box添加一个 overflow:hidden (超出的内容隐藏)样式,因为滚动肯定是会超出b

Javascript 仿歌词智能滚动代码_文字特效

青花瓷(周杰伦) 一生有你(水木年华) 神话(孙楠.韩红)

js仿土豆视频滚动菜单_导航菜单

<< >>

仿微博内容滚动效果代码

曾虑多情损梵行 入山又恐别倾城 世间安得双全法 不负如来不负卿 第一最好不相见,如此便可不相恋. 第二最好不相知,如此便可不相思. 第三最好不相伴,如此便可不相欠. 第四最好不相惜,如此便可不相忆. 第五最好不相爱,如此便可不相弃. 第六最好不相对,如此便可不相会. 第七最好不相误,如此便可不相负. 第八最好不相许,如此便可不相续. 第九最好不相依,如此便可不相偎. 第十最好不相遇,如此便可不相聚. 但曾相见便相知,相见何如不见时. 安得与君相诀绝,免教生死作相思. 那一天 闭目在经殿香雾中 蓦

Android高仿京东垂直循环滚动新闻栏_Android

实现思路其实很简单,就是一个自定义的LinearLayout,并且textView能够循环垂直滚动,而且条目可以点击,显示区域最多显示2个条目,并且还有交替的属性垂直移动的动画效果,通过线程来控制滚动的实现. 不多说看效果: 代码实现 我们先来为控件设置自定义属性: <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="JDAdv

jQuery Scroll插件响应式单页全屏滚动介绍

One Page Scroll是一个响应式单页全屏滚动的jQuery插件,效果有点类是于fullpage.js,不过这个插件却是另外一个,它可以轻松的建立一个动感的响应式的滚动效果页面,比较适用于单页面的专题站,如:Apple's iPhone 5S 这样的网站,能大大的提升用户的体验,也提升自身的品牌形象.当然One Page Scroll是基于jquery的,且需要1.9.0以上版本,支持现代浏览器和IE8以上版本. One Page Scroll响应式单页全屏滚动jQuery插件 插件要求