WPF3D图片轮播效果-程序员宅基地

原文: WPF3D图片轮播效果

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/m0_37591671/article/details/68059169

1.   效果图:

(1)初始化:


(2)当点击该图片时,该图片放大


(3)当点击其他图片时,被点击图片移动到屏幕中央,再次点击放大。


2.   实现思路


3.具体实现

(1)第一步:获得图片路径

    String  myPath=” Pic”;声明文件夹的相对路径;


DirectoryInfodirectoryinfo = new DirectoryInfo(myPath);

FileInfo[] files =directoryinfo.GetFiles();//得到文件夹中图片目录

    private List <string > GetUserImages()
        {
            List<string> images = new List<string>();
            if (Directory.Exists(myPath) == false)
            {
                MessageBox.Show("图片路径"+myPath +"不存在");
                return images;
            }
            DirectoryInfo directoryinfo = new DirectoryInfo(myPath);//new 一个DirectoryInfo实例
            FileInfo[] files = directoryinfo.GetFiles();//得到文件夹中图片目录
            if (files != null)
            {
                foreach ( FileInfo file in files)
                {
                    images.Add(file.FullName);//返回完整路径


                }
            }
            return images;


        }

(2)第二步:根据图片路径和索引值,创建InteractiveVisual3D对象

  private void LoadImageToViewport3D(  List <string > images)
        {
           
            if (images ==null)
            {
                return ;
            }
            for (int i = 0; i <images.Count;i++ )
            {
                string image = images[i];
                InteractiveVisual3D visual3D = CreateInteractiveVisual3D(image,i);
                this.viewport3D.Children.Add(visual3D);
            }
            this.ReLayoutInteractiveVisual3D();
        }

创建3D对象包含几何图形、变换和内容

 private InteractiveVisual3D CreateInteractiveVisual3D(string imagefile,int index)
        {
            InteractiveVisual3D visual3D = new InteractiveVisual3D();
            visual3D.Visual = this.CreatVisual3D(imagefile ,index);
            visual3D.Geometry = this.CreateGeometry();
            visual3D.Transform = this.CreateTransform();
            return visual3D;
        }

①3D对象内容:

实例Border对象,里面添加Image和TextBlock两个对象,分别显示图片和图片名称。

bitmapimage =newBitmapImage (new Uri(imagefile,UriKind.Relative));

获得图片的路径。

String  imageName= imagefile.Substring(imagefile.LastIndexOf('\\')+1, imagefile.LastIndexOf('.')-imagefile.LastIndexOf('\\')-1);根据正则表达式截取图片名称

②根据图片像素进行等比缩放,返回一个图像宽度和高度,用来构建几何形状

  BitmapImage bitmapimage=null;
            try
            {
                bitmapimage =new BitmapImage (new Uri(imagefile,UriKind.Relative));
                _3DiamgeWidth = ConvertImageScale(bitmapimage.PixelWidth,bitmapimage.PixelHeight,0.7,0.7)[0];
                _3DimageHeight = ConvertImageScale(bitmapimage.PixelWidth,bitmapimage.PixelHeight,0.7,0.7)[1];

            }
            catch{}

MeshGeometry3D geometry = new MeshGeometry3D();//实例MeshGeometry3D对象,根据返回值确定空间四个坐标,本例在z平面,所以z坐标为0.

Point3DpLeftTop = new Point3D(-1, _3DimageHeight, 0); pLeftTop.Offset((1.0 -_3DiamgeWidth) / 2.0, (1.0 - _3DimageHeight) / 2.0, 0);

geometry.Positions.Add(pLeftTop);//

……

geometry.TriangleIndices = new Int32Collection();//定义三角形

geometry.TriangleIndices.Add(0);

geometry.TriangleIndices.Add(1);

……

geometry.TextureCoordinates = new PointCollection();//对朝向摄像机的立方体面进行映射

geometry.TextureCoordinates.Add(new Point(0, 0));

……

③变换,本例运用两种变换 RotateTransform3D、TranslateTransform3D

   private Transform3DGroup CreateTransform() 
        {
            Transform3DGroup transform3DGroup = new Transform3DGroup();
            transform3DGroup.Children.Add(new  RotateTransform3D(new  AxisAngleRotation3D(new Vector3D (0,1,0),0)));
            transform3DGroup.Children.Add(new TranslateTransform3D(new Vector3D()));
            return transform3DGroup;
        }

(3)布局

初始化:根据索引和当前CurrentMiddleIndex布局,初始CurrentMiddleIndex值为0.

disToMiddleIndex = index - currentmiddleindex;

当小于0时,角度为15,Offsetx值向左移动,Offsetz向z轴负方向移动;当大于0时,角度为-15,Offsetx值向右移动,Offsetz向z轴负方向移动;

鼠标点击事件:当鼠标点击后,this.CurrentMiddleIndex = index;将当前索引值赋值给CurrentMiddleIndex,如果CurrentMiddleIndex值改变,调用CurrentMiddleIndexChangedCallBack()函数进行重新布局。

  private static void CurrentMiddleIndexChangedCallBack(DependencyObject sender, DependencyPropertyChangedEventArgs arg)
    {
        MainWindow mainWindow = sender as MainWindow;
        if (mainWindow!=null)
    {
        mainWindow.ReLayoutInteractiveVisual3D();
    }
    }

鼠标点击后图片放大事件:

鼠标第一次点击时,当前Offsetz值为0;

  if(((TranslateTransform3D)(((Transform3DGroup)visual3D.Transform).Children[1])).OffsetZ>0)
                        {
                            offsetZ = 0;
                        }
                        else {
                            offsetZ = 1;
                        }


当为0时,将Offsetz值改为1,拉近与Camera距离,产生图片放大效果,当再次点击Offsetz值为1,Offsetz值将还原为0,图片还原。


3.   源代码

http://download.csdn.net/detail/m0_37591671/9797092
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_33972649/article/details/86017190

智能推荐

while循环&CPU占用率高问题深入分析与解决方案_main函数使用while(1)循环cpu占用99-程序员宅基地

文章浏览阅读3.8k次,点赞9次,收藏28次。直接上一个工作中碰到的问题,另外一个系统开启多线程调用我这边的接口,然后我这边会开启多线程批量查询第三方接口并且返回给调用方。使用的是两三年前别人遗留下来的方法,放到线上后发现确实是可以正常取到结果,但是一旦调用,CPU占用就直接100%(部署环境是win server服务器)。因此查看了下相关的老代码并使用JProfiler查看发现是在某个while循环的时候有问题。具体项目代码就不贴了,类似于下面这段代码。​​​​​​while(flag) {//your code;}这里的flag._main函数使用while(1)循环cpu占用99

【无标题】jetbrains idea shift f6不生效_idea shift +f6快捷键不生效-程序员宅基地

文章浏览阅读347次。idea shift f6 快捷键无效_idea shift +f6快捷键不生效

node.js学习笔记之Node中的核心模块_node模块中有很多核心模块,以下不属于核心模块,使用时需下载的是-程序员宅基地

文章浏览阅读135次。Ecmacript 中没有DOM 和 BOM核心模块Node为JavaScript提供了很多服务器级别,这些API绝大多数都被包装到了一个具名和核心模块中了,例如文件操作的 fs 核心模块 ,http服务构建的http 模块 path 路径操作模块 os 操作系统信息模块// 用来获取机器信息的var os = require('os')// 用来操作路径的var path = require('path')// 获取当前机器的 CPU 信息console.log(os.cpus._node模块中有很多核心模块,以下不属于核心模块,使用时需下载的是

数学建模【SPSS 下载-安装、方差分析与回归分析的SPSS实现(软件概述、方差分析、回归分析)】_化工数学模型数据回归软件-程序员宅基地

文章浏览阅读10w+次,点赞435次,收藏3.4k次。SPSS 22 下载安装过程7.6 方差分析与回归分析的SPSS实现7.6.1 SPSS软件概述1 SPSS版本与安装2 SPSS界面3 SPSS特点4 SPSS数据7.6.2 SPSS与方差分析1 单因素方差分析2 双因素方差分析7.6.3 SPSS与回归分析SPSS回归分析过程牙膏价格问题的回归分析_化工数学模型数据回归软件

利用hutool实现邮件发送功能_hutool发送邮件-程序员宅基地

文章浏览阅读7.5k次。如何利用hutool工具包实现邮件发送功能呢?1、首先引入hutool依赖<dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.7.19</version></dependency>2、编写邮件发送工具类package com.pc.c..._hutool发送邮件

docker安装elasticsearch,elasticsearch-head,kibana,ik分词器_docker安装kibana连接elasticsearch并且elasticsearch有密码-程序员宅基地

文章浏览阅读867次,点赞2次,收藏2次。docker安装elasticsearch,elasticsearch-head,kibana,ik分词器安装方式基本有两种,一种是pull的方式,一种是Dockerfile的方式,由于pull的方式pull下来后还需配置许多东西且不便于复用,个人比较喜欢使用Dockerfile的方式所有docker支持的镜像基本都在https://hub.docker.com/docker的官网上能找到合..._docker安装kibana连接elasticsearch并且elasticsearch有密码

随便推点

Python 攻克移动开发失败!_beeware-程序员宅基地

文章浏览阅读1.3w次,点赞57次,收藏92次。整理 | 郑丽媛出品 | CSDN(ID:CSDNnews)近年来,随着机器学习的兴起,有一门编程语言逐渐变得火热——Python。得益于其针对机器学习提供了大量开源框架和第三方模块,内置..._beeware

Swift4.0_Timer 的基本使用_swift timer 暂停-程序员宅基地

文章浏览阅读7.9k次。//// ViewController.swift// Day_10_Timer//// Created by dongqiangfei on 2018/10/15.// Copyright 2018年 飞飞. All rights reserved.//import UIKitclass ViewController: UIViewController { ..._swift timer 暂停

元素三大等待-程序员宅基地

文章浏览阅读986次,点赞2次,收藏2次。1.硬性等待让当前线程暂停执行,应用场景:代码执行速度太快了,但是UI元素没有立马加载出来,造成两者不同步,这时候就可以让代码等待一下,再去执行找元素的动作线程休眠,强制等待 Thread.sleep(long mills)package com.example.demo;import org.junit.jupiter.api.Test;import org.openqa.selenium.By;import org.openqa.selenium.firefox.Firefox.._元素三大等待

Java软件工程师职位分析_java岗位分析-程序员宅基地

文章浏览阅读3k次,点赞4次,收藏14次。Java软件工程师职位分析_java岗位分析

Java:Unreachable code的解决方法_java unreachable code-程序员宅基地

文章浏览阅读2k次。Java:Unreachable code的解决方法_java unreachable code

标签data-*自定义属性值和根据data属性值查找对应标签_如何根据data-*属性获取对应的标签对象-程序员宅基地

文章浏览阅读1w次。1、html中设置标签data-*的值 标题 11111 222222、点击获取当前标签的data-url的值$('dd').on('click', function() { var urlVal = $(this).data('ur_如何根据data-*属性获取对应的标签对象

推荐文章

热门文章

相关标签