一个Silverlight图片切换效果

首先来看这个效果:

 

下面一步步实现这个效果

 

l  打开Blend 4,新建一个 Silverlight 4.0 项目 SwitchImage

l  新建一个数据源,添加一个Image字段为Image类型,并且自动添加好了图片

image

l  新建两个ListBox控件,DocklayoutRoot

image

l  把数据源分别拖拽到两个ListBox上面,Blend会自动生成相应的ItemTemplate。我们在Resources面板里把两个ItemTemplate分别改名为:ThumbnailItemTemplatePickingItemTemplate

image

l  ThumbnailSelectedIndex双向绑定到PickingSelectedIndex

l  下一步就开始编辑两个ListBox的相应模板,首先对Picking进行编辑

n  新建一个ItemsPanelTemplate,把生成的StackPanel的布局进行如下修改

image

n  ItemTemplate Image替换成Ellipse。大小为15,填充颜色为蓝色

n复制一个新的PickingListBoxItemStyle,把其中的fillColorfillColor2FocusVisualElement删除,只留下一个contentPresenter

n  修改默认的VSM,把SelectionStatesSelected修改为ScaleX=1.5ScaleY=1.5

n  增加两个Transition

image

n  ItemTemplate增加一个States,其中MouseEnterellipse的填充颜色修改为红色

image

n  拖拽两个GoToStateActionellipse,分别设置好MouseEnterMouseLeave

image image

n  到这一步就完成了Picking的设计

l  下一步设计Thumbnail

n  和前面一样先修改ItemsPanelTemplate

n  这一步制作水面投影的效果,编辑ThumbnailItemTemplate

n  复制一个Image,依次编辑第二个ImageOpacityMaskFlip Y Effect,具体值如图所示

imageimageimageimage

nPicking一样,删除多余控件,修改默认VSM,把SelectionStatesSelected修改为ScaleX=2.5ScaleY=2.5ZIndex=65535

l  到这一步就完成了基本的设计,然后对样式做一些细节性调整即可

 

点击这里下载完整代码

posted @   Aimeast  阅读(5461)  评论(3编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
点击右上角即可分享
微信分享提示