WPF图标特殊效果实现方法

开发 开发工具
WPF图标实现的效果可以根据具体程序编程中不同的需求来进行改变。比如我们这里要向大家介绍的显示标签效果和模糊效果的方法等。

WPF开发工具的用途主要是体现在各种图形界面的显示方面。那么在使用的过程中,其中有很多技巧值得我们去深入研究。本篇将要实现图标的两个效果:1. 显示图标标签,2. 图标模糊效果。#t#

在上一篇中提到Image没有HTML < img>的Title属性(在MSDN中也没找到类似的属性),所以本篇将自行制作一个标签,它的功能是当鼠标移动到图标上方时会显示该图标的Tag说明,并且该WPF图标模糊显示。

1. 在Home < Image>中加入MouseEnter和MouseLeave事件。

 

  1. < Image Source="image/home.png" 
  2. Width="110" Height="110" 
  3. Tag="My Home"Canvas.Left="30"
    Canvas.Top="20" 
  4. Cursor="Hand"   
  5. MouseEnter="Image_BlurEffect_MouseEnter"   
  6. MouseLeave="Image_BlurEffect_MouseLeave"> 
  7. < /Image> 

 

2. 事件加好了,就要为添加内容了。先看Image_BlurEffect_MouseEnter事件:

 

  1. private void Image_BlurEffect_
    MouseEnter(object sender,
    MouseEventArgs e)   
  2. {   
  3. //将sender定义为Image对象   
  4. Image image = sender as Image;  
  5. //创建模糊BlurEffect对象   
  6. BlurEffect newBlurEffect = 
    new BlurEffect();  
  7. //设定模糊效果值Radius   
  8. newBlurEffect.Radius = 5;  
  9. //为Image添加Blur效果   
  10. image.Effect = newBlurEffect;  
  11. //将Image Tag内容传给imageTitle 
    Textblock   
  12. imageTitle.Text = " " + 
    image.Tag.ToString() +" ";  
  13. //将imageTitle的Border设置为可见   
  14. imageTitleBorder.Visibility = 
    Visibility.Visible;  
  15. //调整imageTitleBorder的Canvas位置,
    使其在图标下方显示   
  16. Canvas.SetLeft(imageTitleBorder, 
    Canvas.GetLeft(image)+ image.
    Width / 2 - 15);   
  17. Canvas.SetTop(imageTitleBorder, 125);   
  18. }  
  19. private void Image_BlurEffect_
    MouseLeave(object sender,
    MouseEventArgs e)   
  20. {   
  21. Image image = sender as Image;   
  22. BlurEffect newBlurEffect = 
    new BlurEffect();   
  23. newBlurEffect.Radius = 0;   
  24. image.Effect = newBlurEffect;   
  25. imageTitleBorder.Visibility = 
    Visibility.Collapsed;   

 

可以使用ToolTipService。经过测试使用ToolTip可以实现标签的功能(代码如下),而且也不用预设WPF图标显示效果,但是没法通过Canvas设定其位置,大家可以都学习一下。

 

  1. XAML:  
  2. < Image Source="image/home.png" 
    Width="110" Height="110"   
  3. Tag="My Home" Canvas.Left="30" 
    Canvas.Top="20"   
  4. MouseEnter="Image_BlurEffect_
    MouseEnter"
       
  5. MouseLeave="Image_BlurEffect_
    MouseLeave"
       
  6. Cursor="Hand">   
  7. < Image.ToolTip>   
  8. < TextBlock>My Home< /TextBlock>   
  9. < /Image.ToolTip>   
  10. < /Image> 

 

C#代码自然就简单多了:

 

  1. private void Image_BlurEffect_
    MouseEnter(object sender,
    MouseEventArgs e)   
  2. {   
  3. Image image = sender as Image;   
  4. BlurEffect newBlurEffect = 
    new BlurEffect();   
  5. newBlurEffect.Radius = 5;   
  6. image.Effect = newBlurEffect;   

上面这些方法介绍的就是WPF图标显示效果的实现。

责任编辑:曹凯 来源: ddvip.com
相关推荐

2009-12-29 14:26:04

WPF按钮

2010-09-10 09:57:27

DIV样式

2010-08-24 14:10:44

div style

2015-07-08 16:19:17

iOSUIVisualEff

2010-08-03 11:29:09

Flex全屏

2010-08-17 10:16:37

DIV样式

2013-07-05 10:26:40

Android

2017-01-22 17:25:55

Android放大镜效果源码分析

2013-06-25 11:21:35

Android开发幻灯片效果Gallery

2009-12-28 15:39:33

WPF滑动条

2011-08-10 14:40:23

iPhone动画

2009-08-17 17:15:48

C# 进度条效果

2017-02-14 17:29:42

Android毛玻璃虚化效果

2022-07-28 14:33:32

webviewweb页面

2009-12-29 11:01:46

WPF淡入效果

2024-04-24 11:09:12

Android图标

2009-12-28 17:33:19

WPF视频音频

2009-12-24 17:57:53

WPF页面跳转

2009-12-28 11:14:29

WPF显示文本

2009-12-24 13:31:25

WPF UI设计
点赞
收藏

51CTO技术栈公众号