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图标显示效果的实现。

THE END