在网上找了一会儿也没找到我想要的效果,还是自己动手,丰衣足食吧。

  需求:当前面板中只显示一张图片,图片栏的下部有用来显示当前图片处于图片队列中的位置的圆球,并且点击下部栏内的圆球可以快速切换,附动画缓动效果。

  比较简单,但是还是简单说一下开发的思路吧。

  主要是要有一个容器放置很多张图片,然后让它们排列好,增加鼠标事件以达到左右滑动的效果,要关联外部控件控制图片的位置,那么就要有一个依赖属性来控制。

  首先,我们来一个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之鼠标滑动切换图片的更多相关文章

  1. 原生JS—实现图片循环切换及监测鼠标滚动切换图片

    今天我们主要讲讲如何使用原生JS实现图片的循环切换的方法以及如何检测鼠标滚动循环切换图片.多余的话我们就不多说了,我们一个一个开始讲吧. 1  原生JS实现图片循环切换 -- 方法一 在上栗子之前我们 ...

  2. H5+CSS3实现手指滑动切换图片

    包含3个文件:html.slider-H5.js.jquery.js(自行下载).在html中可配置滑动参数.具体代码如下: HTML代码: <!DOCTYPE HTML> <htm ...

  3. Android:使用ViewPager实现左右滑动切换图片(图上有点点)

    在以下实例的基础上加上点点 Android:使用ViewPager实现左右滑动切换图片 (简单版) 效果预览: 因为要把点点放图片上,所以修改布局为相对布局: <?xml version=&qu ...

  4. Android:使用ViewPager实现左右滑动切换图片 (简单版)

    ViewPager,它是google SDk中自带的一个附加包的一个类, 可以使视图滑动. 步骤: 1.引入android-support-v4.jar包,在主布局里加入 <android.su ...

  5. 基于jQuery左右滑动切换图片代码

    分享一款基于jQuery左右滑动切换图片代码.这是一款基于jQuery实现的左右滑动切换焦点图代码.效果图如下: 在线预览   源码下载 实现的代码: <div class="v_ou ...

  6. android 图片浏览器滑动切换图片

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...

  7. 【方法】jQuery无插件实现 鼠标拖动切换图片/内容 功能

    前言 我就想随便叨逼叨几句,爱看就看几句,不爱看就直接跳过看正文就好啦~ 这个方法是仿写页面时我自己研究出来,可能有比我更简单的方法. 但我不管,因为我没查我不知道,我就觉得我的最好啦,耶耶耶~ 效果 ...

  8. Swiper 滑动切换图片(可用于PC端,移动端)

    作为一名后端的普通程序猿, 你让我搞这种前端不是跟我玩命吗,所以用插件来搞,省事又简单,而且Swiper使用又简单是吧: 头皮发麻,不喜欢说废话,我更喜欢直接看到效果: 按Swiper官方文档来说, ...

  9. jQuery实现鼠标移入切换图片

    初始效果: 鼠标移入效果: 首先添加jQuery库,我这边直接引用百度CDN地址 <script src="https://apps.bdimg.com/libs/jquery/2.1 ...

随机推荐

  1. 60分钟内从零起步驾驭Hive实战学习笔记

    本博文的主要内容是: 1. Hive本质解析 2. Hive安装实战 3. 使用Hive操作搜索引擎数据实战 SparkSQL前身是Shark,Shark强烈依赖于Hive.Spark原来没有做SQL ...

  2. C++11空指针

    [C++11空指针] 早在 1972 年,C语言诞生的初期,常数 0 带有常数及空指针的双重身分. C 使用 preprocessor macro NULL 表示空指针, 让 NULL 及 0 分别代 ...

  3. C# 多线程参数的使用

    一个参数: Thread.Start方法可以带一个参数: public static void Main() { Thread t = new Thread(new ParameterizedThre ...

  4. [iOS微博项目 - 3.4] - 获取用户信息

    github: https://github.com/hellovoidworld/HVWWeibo   A.获取用户信息 1.需求 获取用户信息并储存 把用户昵称显示在“首页”界面导航栏的标题上   ...

  5. class dict

    class dict(object): """ dict() -> new empty dictionary dict(mapping) -> new dic ...

  6. 使用UIGestureRecognizer监听屏幕事件

    转载自  http://blog.csdn.net/samguoyi/article/details/7911499 如果只是想获取屏幕点击事件有一个最简单的办法,就是写一个透明的uibutton覆盖 ...

  7. Codeforces 711 D. Directed Roads (DFS判环)

    题目链接:http://codeforces.com/problemset/problem/711/D 给你一个n个节点n条边的有向图,可以把一条边反向,现在问有多少种方式可以使这个图没有环. 每个连 ...

  8. jquery ajax 序列化表单传参提交实体对象到后台action

    ========action后台我这里使用的是SpringMVC如果用ssh用法一致=============== @Controller@RequestMapping("PubjobCon ...

  9. IP报文解析及基于IP 数据包的洪水攻击

    版本(4bit) 报头长度(4bit) 优先级和服务类型(8bit) 总长度(16bit) 标识(16bit) 标志(3bit) 分段偏移(13bit) 存活期(8bit) 协议(8bit) 报头校验 ...

  10. OC:习题来自平时搜索

    == 第一部分 ==  类变量的@protected ,@private,@public,@package,声明各有什么含义?写一个标准宏MIN,这个宏输入两个参数并返回较小的一个?面向对象的三大特征 ...