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

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

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

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

  首先,我们来一个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. Linux中内存查看命令free详解(转)

    add by zhj:说了那么多,其实看第一行就足够了,free项就是未使用的内存.其实,我是感觉压根就没必要 使用free命令,用top代替就行了 原文:http://liustb.blog.163 ...

  2. 游戏模块分析总结(2)之UI、操作篇

    转自:http://www.gameres.com/309812.html 游戏模块分析总结(2)之UI.操作篇 发布者: wuye | 发布时间: 2014-12-12 15:03| 评论数: 0 ...

  3. DataTable的新建、查询、添加和修改

    详细讲解了C#开发中数据类型DataTable的使用,包括新建DataTable,查询DataTable,在DataTable里添加记录,添加 列,修改列的属性以及修改某行某列的值的方法.同时说明了将 ...

  4. java线性表学习笔记(二)

    链表中的每一个元素都包含一个称为节点的结构,每向链表中增加一个元素,就会产生一个与之相关的节点,每个节点与它相邻的节点相连接(这是基础吧,不过在看c的时候没认真看,呼). 定义节点类如下(使用了泛型, ...

  5. OSPF虚链路配置.示例1

      在OSPF 网络中,区域0为骨干区域,其它的为非骨干区域,非骨干区域必须与骨干区域直接相连. 根据拓扑图可看到区域1与骨干区域0直接相连而区域2与骨干区域没有直接相连,这种情况下我们可以创建一条虚 ...

  6. django admin site配置(二)

    1. ModelAdmin.inlines 将有外键的子类包含进视图 ,实例: class Author(models.Model): name = models.CharField(max_leng ...

  7. windows server 2008 支持 .net framework 4.0

    windows server 2008平台下需要安装sp1,或打KB958854补丁,IIS7.0才能支持.net framework 4.0. 否则,IIS7.0中的应用程序虽然被配置为.net 4 ...

  8. socket编写简单回显server

    socket在公司代码中应用比较广,比如接口调用的IPCRPC机制,经常看到这样的代码,但是一直也没有动手写过. 在某个比较大的进程中创建一个子进程,由于父子进程复制会浪费内存,可以将创建进程的命令通 ...

  9. 【转载】Fragment 全解析(1):那些年踩过的坑

    http://www.jianshu.com/p/d9143a92ad94 Fragment系列文章:1.Fragment全解析系列(一):那些年踩过的坑2.Fragment全解析系列(二):正确的使 ...

  10. 编程异常——假设你报createSQLQuery is not valid without active transaction,...

    非常多时候我们使用hibernate的session时,都是让session在某一执行环境中保持其唯一. 比如在同一线程内用同一个session.在同一方法内用同一session,这样我们就能够用se ...