CSharp Tips:模拟MSN Message发送文字效果的实现
2007-06-15 12:00
253 查看
在MSN Message发送文字的原则是:单击Enter发送;没有输入任何文字是发送Enter无操作;单击Shift+ Enter,在输入框中添加一个回车,即换行显示;没有输入任何文字,单击Shift+Enter,也在输入框中添加一个回车,即显示一个空行;没有任何外文字,单价Shift+Enter,然后再单击Enter,发送一个空行。
具体实现的代吗非常简单,处理文本框的两个事件即可,不过需要两个窗口集的成员变量辅助。
private String m_sMsgContent = null; // 需要发送的文字
private Boolean m_fSendMsg = false; // 是否执行发送操作
// 控件初始化的代码省略
private void txtContent_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
...{
if (e.KeyCode == Keys.Enter && !e.Shift)
...{
m_sMsgContent = txtContent.Text;
m_fSendMsg = true;;
}
else
...{
m_fSendMsg = false;
}
}
private void txtContent_KeyPress(object sender, System.Windows.Forms.KeyPressEventArgs e)
...{
// 这行代码很重要,如果需要发送输入的文字,就不调用基类的处理代码,即不再文本框中添加Enter
e.Handled = m_fSendMsg;
if (m_fSendMsg)
...{
if (m_sMsgContent != null && m_sMsgContent != String.Empty)
OnSendMessage(); // 执行发送消息的代码
}
}
此外还需要强调一下,当我们在键盘上按一个键的时候,窗体或者控件触发事件的顺序是:KeyDown->KeyPress->KeyUp。一般有KeyPress事件必定有KeyUp事件,但是一定要在KeyPress事件中发送操作,而不要在KeyUp中执行。因为在中文输入法启动的情况下,当键入Enter进行选字操作时,会触发一个KeyUp事件(在此之前没有KeyDown和KeyPress),所以在KeyPress中处理能够减少一些额外的处理,使代码简洁一些。
具体实现的代吗非常简单,处理文本框的两个事件即可,不过需要两个窗口集的成员变量辅助。
private String m_sMsgContent = null; // 需要发送的文字
private Boolean m_fSendMsg = false; // 是否执行发送操作
// 控件初始化的代码省略
private void txtContent_KeyDown(object sender, System.Windows.Forms.KeyEventArgs e)
...{
if (e.KeyCode == Keys.Enter && !e.Shift)
...{
m_sMsgContent = txtContent.Text;
m_fSendMsg = true;;
}
else
...{
m_fSendMsg = false;
}
}
private void txtContent_KeyPress(object sender, System.Windows.Forms.KeyPressEventArgs e)
...{
// 这行代码很重要,如果需要发送输入的文字,就不调用基类的处理代码,即不再文本框中添加Enter
e.Handled = m_fSendMsg;
if (m_fSendMsg)
...{
if (m_sMsgContent != null && m_sMsgContent != String.Empty)
OnSendMessage(); // 执行发送消息的代码
}
}
此外还需要强调一下,当我们在键盘上按一个键的时候,窗体或者控件触发事件的顺序是:KeyDown->KeyPress->KeyUp。一般有KeyPress事件必定有KeyUp事件,但是一定要在KeyPress事件中发送操作,而不要在KeyUp中执行。因为在中文输入法启动的情况下,当键入Enter进行选字操作时,会触发一个KeyUp事件(在此之前没有KeyDown和KeyPress),所以在KeyPress中处理能够减少一些额外的处理,使代码简洁一些。
相关文章推荐
- jQuery实现的简单文字提示效果模拟title
- 【转】jQuery实现的简单文字提示效果模拟title
- jQuery实现的简单文字提示效果模拟title(转)
- OAF 中对文字实现html效果及对超级长文本实现默认换行,对只读的messageTextInput中的内容自动换行
- Java模拟web微x登录发送文字和图片消息简单实现爬虫
- PHP实现微信模拟登陆并给用户发送消息的方法【文字,图片,图文】
- Android用StaticLayout实现文字转化为图片效果(类似长微博发送)
- js实现模拟计算器退格键删除文字效果的方法
- js实现模拟计算器退格键删除文字效果的方法
- 使用StaticLayout实现文字转化为图片的效果(类似发送长微博)
- 用CSS+JavaScript实现文字闪烁效果
- Jquery插件--实现面板模拟效果
- 使用C#发送Http请求实现模拟登陆实例
- 【Android】边框旁的文字实现模糊效果
- jquery 实现 点击按钮后倒计时效果,多用于实现发送手机验证码、邮箱验证码
- 简单JS实现走马灯效果的文字(无需jQuery)
- css实现图片选中效果,选中后在图片上有内框和文字介绍
- 保存图片到本地,查看本地图片,递归实现scrollView的无限循环滚动,文字横向渐变效果,autoLayout
- JS实现密码框根据焦点的获取与失去控制文字的消失与显示效果
- Android开发之TextView文字水平滚动效果实现