WPF之鼠标滑动切换图片
在网上找了一会儿也没找到我想要的效果,还是自己动手,丰衣足食吧。
需求:当前面板中只显示一张图片,图片栏的下部有用来显示当前图片处于图片队列中的位置的圆球,并且点击下部栏内的圆球可以快速切换,附动画缓动效果。
比较简单,但是还是简单说一下开发的思路吧。
主要是要有一个容器放置很多张图片,然后让它们排列好,增加鼠标事件以达到左右滑动的效果,要关联外部控件控制图片的位置,那么就要有一个依赖属性来控制。
首先,我们来一个Canvas,然后要让里面的子项排列好,不然它们就堆在一起了。(艾玛,你说为啥不用StackPanel呢?)
#region 绘制窗口
//分配容器的大小
protected override Size MeasureOverride(Size constraint)
{
Size size = new Size(_width, _height);
foreach (UIElement e in InternalChildren)
{
e.Measure(new Size(_width, _height));
}
return size;
}
//分配子项的大小
protected override Size ArrangeOverride(Size arrangeSize)
{
for (int i = ; i < InternalChildren.Count; i++)
{
InternalChildren[i].Arrange(new Rect(i * _width, , _width, _height));
}
return arrangeSize;
}
#endregion
绘制窗口
然后为Canvas加上鼠标事件用来滑动,其实这个很简单的,就是鼠标摁下去的点和起来的点的一个距离判断,如果距离够了,就移动一个子项的距离,至于左右就要看你自己怎么设置了,这里也是为什么不用StackPanel的原因了,
因为这边Canvas我绘制的窗口之中,我会去设置子项的大小,然后根据子项的大小来实现滑动及统一,这样比较方便。
void CanvasWithPhoto_MouseUp(object sender, System.Windows.Input.MouseButtonEventArgs e)
{
_endPoint = e.GetPosition(App.Current.MainWindow); //X轴滑动的距离
double offsetX = _startPoint.X - _endPoint.X;
if (offsetX > && Index < _totalPage)
{
++Index;
}
else if (offsetX < - && Index > )
{
--Index;
} Move(Index);
} //X轴的移动动画
private void Move(int Index)
{
DoubleAnimation animation = new DoubleAnimation(-(Index - ) * _width, TimeSpan.FromMilliseconds());
animation.DecelerationRatio = 0.2;
animation.AccelerationRatio = 0.2;
_translate.BeginAnimation(TranslateTransform.XProperty, animation);
} void CanvasWithPhoto_MouseDown(object sender, System.Windows.Input.MouseButtonEventArgs e)
{
_startPoint = e.GetPosition(App.Current.MainWindow);
}
鼠标事件
艾玛,这里就有人说了那Index是什么啊,这里就是当前页面了,因为需求里面是想快速定位到图片的,第三张跳到第七张这个样子的,所以用了一个Index,这个就是依赖属性,而且添加了一个自定义的事件,留出一个接口方便以后使用,其实这个程序里面我也没有用上,纯粹就是习惯。
//当前页
public int Index
{
get { return (int)GetValue(IndexProperty); }
set { SetValue(IndexProperty, value); }
} public static readonly DependencyProperty IndexProperty =
DependencyProperty.Register("Index", typeof(int), typeof(CanvasWithPhoto), new FrameworkPropertyMetadata(, new PropertyChangedCallback(OniIndexChanged)));
public static void OniIndexChanged(DependencyObject sender,DependencyPropertyChangedEventArgs e)
{
CanvasWithPhoto c = (CanvasWithPhoto)sender;
int newValue = (int)e.NewValue;
int oldValue = (int)e.OldValue;
c.Index = (int)e.NewValue;
c.OnIndexChanged(oldValue, newValue);
}
private void OnIndexChanged(int oldValue, int newValue)
{
RoutedPropertyChangedEventArgs<int> args
= new RoutedPropertyChangedEventArgs<int>(oldValue, newValue);
args.RoutedEvent = IndexChangedEvent;
RaiseEvent(args);
Move(newValue);
}
public static RoutedEvent IndexChangedEvent =
EventManager.RegisterRoutedEvent("IndexChanged", RoutingStrategy.Bubble, typeof(RoutedPropertyChangedEventHandler<int>), typeof(CanvasWithPhoto));
public event RoutedPropertyChangedEventHandler<int> IndexChanged
{
add { AddHandler(IndexChangedEvent, value); }
remove { RemoveHandler(IndexChangedEvent, value); }
}
依赖属性
最后,自定义的CanvasWithImage是不会限制长度的,这样就会有一个图片会全部显示出来的问题,这里我是用一个StackPanel包裹住,这个StackPanel是有一个宽度限制的,ClipToBounds="True",设置这个属性,会讲超出部分的内容裁减隐藏。
简陋的效果图:

软件环境:VisualStudio2010 + Windows 7
http://download.csdn.net/detail/qq278709708/9150335
不足的地方大家多多指教
WPF之鼠标滑动切换图片的更多相关文章
- 原生JS—实现图片循环切换及监测鼠标滚动切换图片
今天我们主要讲讲如何使用原生JS实现图片的循环切换的方法以及如何检测鼠标滚动循环切换图片.多余的话我们就不多说了,我们一个一个开始讲吧. 1 原生JS实现图片循环切换 -- 方法一 在上栗子之前我们 ...
- H5+CSS3实现手指滑动切换图片
包含3个文件:html.slider-H5.js.jquery.js(自行下载).在html中可配置滑动参数.具体代码如下: HTML代码: <!DOCTYPE HTML> <htm ...
- Android:使用ViewPager实现左右滑动切换图片(图上有点点)
在以下实例的基础上加上点点 Android:使用ViewPager实现左右滑动切换图片 (简单版) 效果预览: 因为要把点点放图片上,所以修改布局为相对布局: <?xml version=&qu ...
- Android:使用ViewPager实现左右滑动切换图片 (简单版)
ViewPager,它是google SDk中自带的一个附加包的一个类, 可以使视图滑动. 步骤: 1.引入android-support-v4.jar包,在主布局里加入 <android.su ...
- 基于jQuery左右滑动切换图片代码
分享一款基于jQuery左右滑动切换图片代码.这是一款基于jQuery实现的左右滑动切换焦点图代码.效果图如下: 在线预览 源码下载 实现的代码: <div class="v_ou ...
- android 图片浏览器滑动切换图片
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...
- 【方法】jQuery无插件实现 鼠标拖动切换图片/内容 功能
前言 我就想随便叨逼叨几句,爱看就看几句,不爱看就直接跳过看正文就好啦~ 这个方法是仿写页面时我自己研究出来,可能有比我更简单的方法. 但我不管,因为我没查我不知道,我就觉得我的最好啦,耶耶耶~ 效果 ...
- Swiper 滑动切换图片(可用于PC端,移动端)
作为一名后端的普通程序猿, 你让我搞这种前端不是跟我玩命吗,所以用插件来搞,省事又简单,而且Swiper使用又简单是吧: 头皮发麻,不喜欢说废话,我更喜欢直接看到效果: 按Swiper官方文档来说, ...
- jQuery实现鼠标移入切换图片
初始效果: 鼠标移入效果: 首先添加jQuery库,我这边直接引用百度CDN地址 <script src="https://apps.bdimg.com/libs/jquery/2.1 ...
随机推荐
- 【131】如何讲好PPT
1 列提纲2 写稿子3 背稿子4 演练5遍,用自己的话说出来,最好和稿子一样,但不强求一样,关键要理解5 不一定要做,但是做好了会有很大提高,讲的时候也会很NB:有时间可以再演练几遍,录出来看看哪里需 ...
- KMP算法——Javascript实现
腾讯和阿里的笔试刚过去了,里面有很多题都很值得玩味的.之前Blog积累的很多东西,还要平时看的书,都有很大的帮助.这个深有体会啊! 例如,腾讯有一道算法题是吃香蕉(好邪恶的赶脚..),一次吃一根或者两 ...
- Chocolatey的安装与使用
@(编程) 前言 在 Linux 下,大家喜欢用 apt-get 来安装应用程序,如今在 windows 下,大家可以使用 Chocolatey 来快速下载搭建一个开发环境. Chocolatey 的 ...
- hdu 1260 Tickets
http://acm.hdu.edu.cn/showproblem.php?pid=1260 题目大意:n个人买票,每个人买票都花费时间,相邻的两个人可以一起买票以节约时间: 所以一个人可以自己买票也 ...
- [置顶] EASYUI+MVC4+VS2010通用权限管理系统开发
通用权限案例平台在经过几年的实际项目使用,并取得了不错的用户好评.在平台开发完成后,特抽空总结一下平台知识,请各位在以后的时间里,关注博客的更新. 1.EASYUI+MVC4通用权限管理平台--前言 ...
- HDU 5884 Sort (二分)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5884 nn个有序序列的归并排序.每次可以选择不超过kk个序列进行合并,合并代价为这些序列的长度和.总的 ...
- HDU1896Stones(优先队列)
地址http://acm.hdu.edu.cn/showproblem.php?pid=1896 题目大一比较简单,就是说在一条直线道路上有n个石头,往前走,遇到一个数一个,如果遇到的是第奇数个那就把 ...
- CCF 201312-1 出现次数最多的数 (水题)
问题描述 给定n个正整数,找出它们中出现次数最多的数.如果这样的数有多个,请输出其中最小的一个. 输入格式 输入的第一行只有一个正整数n(1 ≤ n ≤ 1000),表示数字的个数. 输入的第二行有n ...
- iOS获取文件和文件夹大小
//通常用于删除缓存的时,计算缓存大小 //单个文件的大小 - (long long) fileSizeAtPath:(NSString*) filePath{ NSFileManager* mana ...
- 用vagrant搭建一个自己的lnmp环境(一)
用vagrant搭建自己的lnmp环境 1.工具: a.vagrant b.virtual box c.linux服务器box(此处我使用centos 7.0) 2.安装完vagrant和virtua ...