欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

用WPF实现屏幕文字提示的实现方法

程序员文章站 2024-02-29 09:28:46
1. 新建一个wpf application。2. 将window的windowstyle属性设置为"none"去掉标题栏,将allowstransparency属性设置为...
1. 新建一个wpf application。
2. 将window的windowstyle属性设置为"none"去掉标题栏,将allowstransparency属性设置为"true"允许透明,topmost属性设置为"true"使提示文字显示在顶层,background属性设置为"#00000000"使窗口透明。
3. 设置grid的background属性。如显示黑色文字提示,可使用半透明白色背景。透明的效果如果由opacity属性产生会使该容器内的其他元素也有透明效果。比较简单的方法是通过background属性的前两位来设置透明度。
4. 给window的mouseleave、mousedown、mouseenter事件添加处理方法。添加mouseenter和mouseleave事件的处理方法是为了让鼠标划入提示区域时加深背景透明度,鼠标划出提示区域时减小背景透明度。mousedown事件的处理方法使鼠标点击提示区域后取消提示。
复制代码 代码如下:

代码
/// <summary>
/// 鼠标移入处理方法
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void window_mouseenter(object sender, mouseeventargs e)
{
    brush brush = new solidcolorbrush(color.fromargb(0x78,0xff,0xff,0xff));  // 创建一个纯色brush
    grid.background = brush;  // 应用于grid
}
/// <summary>
/// 鼠标移出处理方法
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void window_mouseleave(object sender, mouseeventargs e)
{
    brush brush = new solidcolorbrush(color.fromargb(0x52, 0xff, 0xff, 0xff));  // 创建一个纯色brush
    grid.background = brush;  // 应用于grid
}
/// <summary>
/// 鼠标按下处理方法
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void window_mousedown(object sender, mousebuttoneventargs e)
{
    mainwindow.close();  // 或者使用mainwindow.hide()隐藏窗口
}

本文适用于 .net framework 4