好玩的WPF第四彈:用Viewport2DVisual3D實現3D旋轉效果
效果呢就是這麼個效果,但是大家要發揮想象力,比如做成一個可以旋轉的按鈕等等。
定義一個這樣的資源就好。
<Window.Resources>
<DiffuseMaterial x:Key="DiffuseMaterialStyle" Viewport2DVisual3D.IsVisualHostMaterial="True"
Brush="White"/>
</Window.Resources>
關鍵是在Grid裡放這麼一個東西:
<Viewport3D x:Name="view" ClipToBounds="True" RenderOptions.EdgeMode="Aliased">
<Viewport3D.Camera>
<PerspectiveCamera x:Name="perspectiveCam" FieldOfView="59" Position="0.5,0.5,2" LookDirection="0,0,-1">
<PerspectiveCamera.Transform>
<RotateTransform3D x:Name="rot" CenterY="0.5" CenterX="0.5" CenterZ="-0.5">
<RotateTransform3D.Rotation>
<AxisAngleRotation3D x:Name="AxisAngleRot" Axis="0,1,0" Angle="0"/>
</RotateTransform3D.Rotation>
</RotateTransform3D>
</PerspectiveCamera.Transform>
</PerspectiveCamera>
</Viewport3D.Camera>
<ModelVisual3D>
<ModelVisual3D.Content>
<AmbientLight Color="White" />
</ModelVisual3D.Content>
</ModelVisual3D>
</Viewport3D>
正面:
<Viewport2DVisual3D Material="{StaticResource DiffuseMaterialStyle }">
<Viewport2DVisual3D.Geometry>
<MeshGeometry3D Positions="0,1,0 0,0,0 1,0,0 1,1,0"
TextureCoordinates="0,0 0,1 1,1 1,0"
TriangleIndices="0 1 2 0 2 3"/>
</Viewport2DVisual3D.Geometry>
<Border BorderThickness="10" x:Name="FrontSide" BorderBrush="Blue" CornerRadius="1"
PreviewMouseDown="FrontSide_PreviewMouseDown" >
<TextBlock Text="歡迎訪問我的部落格" Foreground="Green" />
</Border>
</Viewport2DVisual3D>
右側:
<Viewport2DVisual3D Material="{StaticResource DiffuseMaterialStyle}">
<Viewport2DVisual3D.Geometry>
<MeshGeometry3D Positions="1,1,0 1,0,0 1,0,-1 1,1,-1"
TextureCoordinates="0,0 0,1 1,1 1,0"
TriangleIndices="0 1 2 0 2 3"/>
</Viewport2DVisual3D.Geometry>
<Border BorderThickness="1" x:Name="RightSide" BorderBrush="Lime" CornerRadius="4"
PreviewMouseDown="RightSide_PreviewMouseDown" >
<Border.Background>
<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
<GradientStop Color="White" />
</LinearGradientBrush>
</Border.Background>
<TextBlock Text="感謝您的支援" FontSize="20"/>
</Border>
</Viewport2DVisual3D>
大家對比上面這兩個就知道正面的鏤空是怎麼來的了……
左側:
<Viewport2DVisual3D Material="{StaticResource DiffuseMaterialStyle}">
<Viewport2DVisual3D.Geometry>
<MeshGeometry3D Positions="0,1,-1 0,0,-1 0,0,0 0,1,0"
TextureCoordinates="0,0 0,1 1,1 1,0"
TriangleIndices="0 1 3 0 2 3"/>
</Viewport2DVisual3D.Geometry>
<Border BorderThickness="40" x:Name="LeftSide" BorderBrush="White" CornerRadius="1"
PreviewMouseDown="LeftSide_PreviewMouseDown" >
<Border.Background>
<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
<GradientStop Color="Black" />
</LinearGradientBrush>
</Border.Background>
<TextBlock Text="有問題直接評論就好" Foreground="Lime"/>
</Border>
</Viewport2DVisual3D>
後方:
<Viewport2DVisual3D Material="{StaticResource DiffuseMaterialStyle}">
<Viewport2DVisual3D.Geometry>
<MeshGeometry3D Positions="1,1,-1 1,0,-1 0,0,-1 0,1,-1 0,0.5,-1"
TextureCoordinates="0,0 0,1 1,1 1,0"
TriangleIndices="0 1 2 0 2 4"/>
</Viewport2DVisual3D.Geometry>
<Border BorderThickness="1" x:Name="BackSide" BorderBrush="White" CornerRadius="4"
PreviewMouseDown="BackSide_PreviewMouseDown" >
<Border.Background>
<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
<GradientStop Color="White" />
</LinearGradientBrush>
</Border.Background>
<TextBlock Text="常來哦……" FontSize="20"/>
</Border>
</Viewport2DVisual3D>
大家先不管MeshGeometry3D這些東西是做什麼的,後面我儘量簡單快速的講解它們。
所以先來看看程式的內部。
public partial class MainWindow : Window
{
DispatcherTimer dispatTime = null;
double AxAngle = 90;
public MainWindow()
{
InitializeComponent();
if (dispatTime == null)
dispatTime = new DispatcherTimer();
dispatTime.Tick += new EventHandler(DT_Tick);
dispatTime.Interval = new TimeSpan(0, 0, 0, 0, 2);
}
private void DT_Tick(object sender, EventArgs e)
{
AxisAngleRot.Angle += 1;
if (AxisAngleRot.Angle >= AxAngle)
dispatTime.Stop();
}
private void FrontSide_PreviewMouseDown(object sender, MouseButtonEventArgs e)
{
AxisAngleRot.Angle = 0;
AxAngle = 90;
dispatTime.Start();
}
private void LeftSide_PreviewMouseDown(object sender, MouseButtonEventArgs e)
{
AxAngle = 360;
dispatTime.Start();
}
private void BackSide_PreviewMouseDown(object sender, MouseButtonEventArgs e)
{
AxAngle = 270;
dispatTime.Start();
}
private void RightSide_PreviewMouseDown(object sender, MouseButtonEventArgs e)
{
AxAngle = 180;
dispatTime.Start();
}
}
像這種程式肯定會涉及到計時器的,就是DT_Tick方法。我將它設定為每次都轉動1度,而下面這一行則是間隔的時間。
dispatTime.Interval = new TimeSpan(0, 0, 0, 0, 2);
其餘的每個方法都用於調節角度,可以看到在正面時會將角度重置一次。
所以接下來看看Positions是什麼意思。
原諒我把正方體畫歪了,圖中另外用箭頭指出了“正面”、“右側”等。
大家看看Positions中都是3個數字一組對吧,這就是一個點,我在圖中已經標識出來了。而TriangleIndices中也是3個數字一組,這3個數字指示了Positions中的組合索引(從0開始索引),然後3個數字組成三角形,如圖中箭頭所指向的。
而TextureCoordinates是WPF的3D紋理座標,這裡就不深究的,後面可以深入探討寫一篇部落格。
大家也可以拿原始碼回去慢慢弄著玩嘛……
所以這篇部落格就到此為止咯。掰掰……
相關文章
- CSS3實現的3D旋轉效果CSSS33D
- | / - 的旋轉效果實現(轉)
- three.js實現的地球3D旋轉效果JS3D
- css3實現的3D立體旋轉效果CSSS33D
- css3實現的立方體3D旋轉效果CSSS33D
- CSS 3D旋轉效果CSS3D
- SVG實現的圓環旋轉效果SVG
- three.js實現的3D球狀拖動旋轉效果JS3D
- iOS實現3D旋轉iOS3D
- 如何實現圖片的3D旋轉,而且是不停旋轉?3D
- javascript 3D旋轉滾動效果JavaScript3D
- canvas實現的旋轉太極圖效果Canvas
- css3實現的旋轉的陀螺效果CSSS3
- 滑鼠懸浮div實現旋轉效果
- 用Unity實現彈反效果Unity
- 簡單的css3頭像旋轉與3D旋轉效果CSSS33D
- 3D旋轉效果程式碼例項3D
- CSS3 3d旋轉魔方效果CSSS33D
- css3實現的立方體旋轉效果CSSS3
- 滑鼠懸浮實現環形旋轉效果
- HTML+CSS實現太極旋轉效果HTMLCSS
- css3實現環狀旋轉效果CSSS3
- css3實現的旋轉載入等待效果CSSS3
- WPF 實現陰影效果
- CSS3邊框旋轉動畫實現效果CSSS3動畫
- canvas實現太陽、地球和月亮旋轉效果Canvas
- jQuery和css3實現的摩天輪旋轉效果jQueryCSSS3
- CSS3實現的小球旋轉載入等待效果CSSS3
- javascript元素3D旋轉效果程式碼例項JavaScript3D
- CSS3立方體3D旋轉效果CSSS33D
- 不適用imrotate 的影像旋轉實現
- CSS3實現的3D旋轉程式碼例項CSSS33D
- css3實現的旋轉魔方效果程式碼例項CSSS3
- css3實現的loadding旋轉載入效果CSSS3
- canvas實現的旋轉的太極圖效果程式碼例項Canvas
- 如何用 Swift 實現一個好玩的彈性動畫Swift動畫
- 基於HT for Web向量實現3D葉輪旋轉Web3D
- css3實現旋轉loadding載入效果CSSS3