原文:WPF动态加载3D 放大-旋转-平移

WavefrontObjLoader.cs

第二步:ModelVisual3DWithName.cs

public class ModelVisual3DWithName:ModelVisual3D

    {

       
public string Name { get; set; }

public object Tag { get; set; }

}

第三步:MainWindow.xmal

<Grid x:Name="lay">

   
 <Viewport3D x:Name="vp"
Margin="0">

   
  <Viewport3D.Camera>

<PerspectiveCamera
FieldOfView="45" FarPlaneDistance="100"
LookDirection="0,0,-3.4142135623731" NearPlaneDistance="0.1"
Position="0,0,3.4142135623731"
UpDirection="0,3,0"/>

   
  </Viewport3D.Camera>

</Viewport3D>

       
<Slider Height="23" HorizontalAlignment="Left"
Margin="220,288,0,0" Name="slider1" VerticalAlignment="Top"
Width="100" Maximum="2000" />

       
<Slider Height="23" HorizontalAlignment="Left"
Margin="49,288,0,0" Name="slider2" VerticalAlignment="Top"
Width="100" Maximum="1000" />

       
<Slider Height="23" HorizontalAlignment="Left"
Margin="367,288,0,0" Name="slider3" VerticalAlignment="Top"
Width="100" Minimum="200" Maximum="2000" />

       
<Slider Height="23" HorizontalAlignment="Left"
Margin="567,288,0,0" Name="slider4" VerticalAlignment="Top"
Width="100" Minimum="200" Maximum="2000" />

   
</Grid>

第四步:MainWindow.xmal

PerspectiveCamera myPCamera;

       
DirectionalLight myDirectionalLight;

       
Model3DGroup myModel3DGroup;

       
WavefrontObjLoader wfl;

       
ModelVisual3DWithName mv3dw;

       
public MainWindow()

       
{

           
InitializeComponent();

           
wfl = new
WavefrontObjLoader();           
slider1.ValueChanged += new
RoutedPropertyChangedEventHandler<double>(slider1_ValueChanged);

slider2.ValueChanged += new
RoutedPropertyChangedEventHandler<double>(slider2_ValueChanged);

slider3.ValueChanged += new
RoutedPropertyChangedEventHandler<double>(slider3_ValueChanged);

slider4.ValueChanged += new
RoutedPropertyChangedEventHandler<double>(slider4_ValueChanged);

createCamera();

           
createLight();

           
createModel3D();

           
create360();

           
//createAnimation();

       
}

       
#region //光源

       
private void createLight()

       
{

           
myDirectionalLight = new DirectionalLight();

           
myDirectionalLight.Color = Colors.White;

           
myDirectionalLight.Direction = new Vector3D(-0.61, -0.5,
-0.61);

       
}

       
#endregion

       
#region //摄像机

       
private void createCamera()

       
{

           
myPCamera = new PerspectiveCamera();

           
//myPCamera.Position = new Point3D(0,-1743,-4000);//看的方向

           
myPCamera.Position = new Point3D(0, 0, 1000);

           
myPCamera.LookDirection = new Vector3D(0,0,-1000);//摄影机看的方向

           
myPCamera.UpDirection = new Vector3D(0, 1, -0);

           
myPCamera.FieldOfView = 45;//法向量
摄影机上下颠倒,左转右转           
myPCamera.NearPlaneDistance = 0.1;

           
myPCamera.FarPlaneDistance = 11050;

vp.Camera = myPCamera;

       
}

       
#endregion

       
#region //模型

       
private void createModel3D()

       
{

           
myModel3DGroup = new Model3DGroup();

           
myModel3DGroup.Children.Add(myDirectionalLight);

var m =
wfl.LoadObjFile(@"C:/Users/Adminstrator/Desktop/3D动态加载/WpfApplication2/xx.obj");

m.Content = myModel3DGroup;

vp.Children.Add(m);

       
}

       
#endregion

       
#region //360旋转动作

       
RotateTransform3D rtf3D;

       
AxisAngleRotation3D aar;

       
private void create360()

       
{

           
rtf3D = new
RotateTransform3D();

aar = new AxisAngleRotation3D();

           
this.RegisterName("myAngleRotation", aar);

           
aar.Angle = 0;

           
aar.Axis = new Vector3D(0, 3, 0);

           
rtf3D.Rotation = aar;

           
myModel3DGroup.Transform = rtf3D;

           
myPCamera.Transform = rtf3D;

       
}

       
Storyboard sbd;

       
DoubleAnimation dan;

       
private void createAnimation()

       
{

           
sbd = new Storyboard();

           
dan = new DoubleAnimation(0,360,new
Duration(TimeSpan.FromSeconds(10)));

           
dan.RepeatBehavior = RepeatBehavior.Forever;

           
Storyboard.SetTargetName(dan,"myAngleRotation");

           
Storyboard.SetTargetProperty(dan, new
PropertyPath(AxisAngleRotation3D.AngleProperty));

           
sbd.Children.Add(dan);

           
sbd.BeginTime = TimeSpan.FromSeconds(5);//开始时间

           
sbd.Begin(this);

       
}

       
#endregion

       
void slider1_ValueChanged(object sender,
RoutedPropertyChangedEventArgs<double>
e)

       
{

           
myPCamera.Position = new Point3D(slider1.Value , slider2.Value,
slider3.Value);

       
}

       
void slider2_ValueChanged(object sender,
RoutedPropertyChangedEventArgs<double>
e)

       
{

           
myPCamera.Position = new Point3D(slider1.Value, slider2.Value,
slider3.Value);

       
}

       
void slider3_ValueChanged(object sender,
RoutedPropertyChangedEventArgs<double>
e)

       
{

           
myPCamera.Position = new Point3D(slider1.Value, slider2.Value,
slider3.Value);

       
}

       
void slider4_ValueChanged(object sender,
RoutedPropertyChangedEventArgs<double>
e)

       
{

           
aar.Angle = slider4.Value;

       
}

WPF动态加载3D 放大-旋转-平移的更多相关文章

  1. WPF动态加载3D 放大-旋转-平移

    第一步:新建WavefrontObjLoader.cs using System; using System.Collections.Generic; using System.Windows; us ...

  2. WPF 动态加载主题由zip

    经典主题的方式 主题战略 加载速度 本机支持 (不需要额外的代码) 支持代码为主题 (捆绑代码 & 资源成单独的文件) 支持资源层次结构中导航 动态加载 动态卸载 轻松地编辑和编译 (不需要安 ...

  3. WPF 3D动态加载模型文件

    原文:WPF 3D动态加载模型文件 这篇文章需要读者对WPF 3D有一个基本了解,至少看过官方的MSDN例子. 一般来说关于WPF使用3D的例子,都是下面的流程: 1.美工用3DMAX做好模型,生成一 ...

  4. [WPF学习笔记]动态加载XAML

    好久没写Blogs了,现在在看[WPF编程宝典],决定开始重新写博客,和大家一起分享技术. 在编程时我们常希望界面是动态的,可以随时变换而不需要重新编译自己的代码. 以下是动态加载XAML的一个事例代 ...

  5. mvvm模式下在WPF项目中动态加载项目的程序集和类

    在mvvm模式的wpf项目中有个需求需要去加载解决方案的程序集,并且根据程序集去动态加载当前程序集的类,做成下拉框形式. 效果: //全局定义 private ComboBox abList= nul ...

  6. WPF中动态加载XAML中的控件

    原文:WPF中动态加载XAML中的控件 using System; using System.Collections.Generic; using System.Linq; using System. ...

  7. WPF中Style文件的引用——使用xaml代码或者C#代码动态加载

    原文:WPF中Style文件的引用--使用xaml代码或者C#代码动态加载 WPF中控件拥有很多依赖属性(Dependency Property),我们可以通过编写自定义Style文件来控制控件的外观 ...

  8. Win8 Metro动态加载内容框架

    制作背景 为了参加ImagineCup 2013 世界公民类比赛,我们设计制作了一个可动态扩展的幼教类App.这个App需要能动态加载内容,内容包括带动画可交互的电子书,动画,视频,游戏. 技术支持 ...

  9. 携程Android App插件化和动态加载实践

    携程Android App的插件化和动态加载框架已上线半年,经历了初期的探索和持续的打磨优化,新框架和工程配置经受住了生产实践的考验.本文将详细介绍Android平台插件式开发和动态加载技术的原理和实 ...

随机推荐

  1. (2)入门指南——(7)添加jquery代码(Adding our jQuery code)

    Our custom code will go in the second, currently empty, JavaScript file which we included from the H ...

  2. CSS——inline-block属性

    Inline-block 是元素 display属性的一个值 .这个名字的由来是因为,可以简单的解释为inline+block :display设置这个值的元素,兼具行内元素( inline elem ...

  3. 【MySQL案例】HA: GTID_MODE配置不一致

    1.1.1. HA: GTID_MODE配置不一致 [环境描写叙述] msyql5.6.14 [报错信息] 初始状态Master和Slave都开启了enforce-gtid-consistency和g ...

  4. moodle中文API之表单API

    Form API 表单API 文件夹 1.概述 2.亮点 3.使用方法 4.表单元素 4.1 基本表单元素 4.2 定制表单元素 5.经常使用函数 5.1  add_action_buttons($c ...

  5. git/github初级运用自如 (转)

    三 . 设置用户信息 这一步不是很重要,貌似不设置也行,但github官方步骤中有,所以这里也提一下. 在git中设置用户名,邮箱 $ git config --global user.name &q ...

  6. cocos2D(四)---- CCSprite

    在介绍CCSprite之前,先要理解游戏开发中的一个核心概念:精灵.精灵也称为游戏对象,它能够用来表示游戏中的不论什么物体,比方敌人.子弹.甚至是一个背景图片.一段文字.CCSprite能够说是在co ...

  7. Wix打包系列(二)用户界面和本地化操作

    原文:Wix打包系列(二)用户界面和本地化操作 上一章节,我们已经大概知道如何对文件进行打包安装,不过我们也注意到,通过对Sample.wxs的编译链接,生成的msi安装包没有任何用户界面,只有一个安 ...

  8. OpenStack 中的neutron-server启动过程

    neutron-server是neutron的核心组件之中的一个.负责直接接收外部请求,然后调用后端对应plugin进行处理. 其核心启动过程代码主要在neutron.server包中. __init ...

  9. 采用CXF+spring+restful创建一个web接口项目

    这篇文章是http://blog.csdn.net/zxnlmj/article/details/28880303下面,加入的基础上的restful特征 1.参加restful必jar包裹 jsr31 ...

  10. Failed to load libGL.so问题解决

    Ubuntu 14.04下启动模拟设备Android 4.2.2的时候报错: failed to load libgl.so 先用locate 命令定位libGL库, 然后加入�一个链接就可以: de ...