Windows Phone 7 立體旋轉動畫的實現

來源:互聯網
上載者:User

     Storyboard.TargetProperty表示擷取或設定應進行動畫處理的屬性的名稱。通過對Storyboard.TargetProperty屬性的設定可以很簡單地實現X軸、Y軸、Z軸的立體旋轉效果。

Storyboard.TargetProperty="RotationX"表示沿X軸旋轉

Storyboard.TargetProperty="RotationY"表示沿Y軸旋轉

Storyboard.TargetProperty="RotationZ"表示沿Z軸旋轉

下面是一個立體旋轉的執行個體:

<phone:PhoneApplicationPage 
x:Class="PerspectiveRotation.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d" d:DesignWidth="480" d:DesignHeight="768"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}"
Foreground="{StaticResource PhoneForegroundBrush}"
SupportedOrientations="PortraitOrLandscape" Orientation="Portrait"
shell:SystemTray.IsVisible="True">

<phone:PhoneApplicationPage.Resources>
<Storyboard x:Name="rotateX"><!--沿X軸方向旋轉的面板-->
<DoubleAnimation Storyboard.TargetName="planeProjection"
Storyboard.TargetProperty="RotationX"
From="0" To="360" Duration="0:0:5" />
</Storyboard>
<Storyboard x:Name="rotateY"><!--沿Y軸方向旋轉的面板-->
<DoubleAnimation Storyboard.TargetName="planeProjection"
Storyboard.TargetProperty="RotationY"
From="0" To="360" Duration="0:0:5" />
</Storyboard>
<Storyboard x:Name="rotateZ"><!--沿Z軸方向旋轉的面板-->
<DoubleAnimation Storyboard.TargetName="planeProjection"
Storyboard.TargetProperty="RotationZ"
From="0" To="360" Duration="0:0:5" />
</Storyboard>
</phone:PhoneApplicationPage.Resources>

<!--LayoutRoot is the root grid where all page content is placed-->
<Grid x:Name="LayoutRoot" Background="Transparent">
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>

<!--TitlePanel contains the name of the application and page title-->
<StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28">
<TextBlock x:Name="ApplicationTitle" Text="立體旋轉" Style="{StaticResource PhoneTextNormalStyle}"/>
</StackPanel>

<!--ContentPanel - place additional content here-->
<Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
<Grid.RowDefinitions>
<RowDefinition Height="*" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>

<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>

<TextBlock Name="txtblk"
Grid.Row="0" Grid.Column="0" Grid.ColumnSpan="3"
Text="Oh,My God"
FontSize="70"
Foreground="{StaticResource PhoneAccentBrush}"
HorizontalAlignment="Center"
VerticalAlignment="Center">
<TextBlock.Projection>
<PlaneProjection x:Name="planeProjection" />
</TextBlock.Projection>
</TextBlock>

<Button Grid.Row="1" Grid.Column="0"
Content="旋轉-X軸"
Click="RotateXClick" />

<Button Grid.Row="1" Grid.Column="1"
Content="旋轉-Y軸"
Click="RotateYClick" />

<Button Grid.Row="1" Grid.Column="2"
Content="旋轉-Z軸"
Click="RotateZClick" />
</Grid>
</Grid>

</phone:PhoneApplicationPage>
using System;
using System.Windows;
using Microsoft.Phone.Controls;

namespace PerspectiveRotation
{
public partial class MainPage : PhoneApplicationPage
{
public MainPage()
{
InitializeComponent();
}
//沿X軸旋轉
void RotateXClick(object sender, RoutedEventArgs args)
{
rotateX.Begin();
}
//沿Y軸旋轉
void RotateYClick(object sender, RoutedEventArgs args)
{
rotateY.Begin();
}
//沿Z軸旋轉
void RotateZClick(object sender, RoutedEventArgs args)
{
rotateZ.Begin();
}
}
}
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.