Lesson9 some interesting things in C#
1、关键帧动画
1)xml 界面
<Page
x:Class="Test.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Test"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
Background="{ThemeResource ApplicationPageBackgroundThemeBrush}"> <Page.Resources>
<Storyboard x:Name="Bounce">
<DoubleAnimationUsingKeyFrames BeginTime="00:00:00" Storyboard.TargetName="ball" Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(TranslateTransform.X)">
<SplineDoubleKeyFrame KeyTime="00:00:00" Value=""/>
<SplineDoubleKeyFrame KeyTime="00:00:04" Value=""/>
<SplineDoubleKeyFrame KeyTime="00:00:06" Value=""/>
</DoubleAnimationUsingKeyFrames>
<DoubleAnimationUsingKeyFrames BeginTime="00:00:00" Storyboard.TargetName="ball" Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(TranslateTransform.Y)">
<SplineDoubleKeyFrame KeyTime="00:00:00" Value=""/>
<SplineDoubleKeyFrame KeyTime="00:00:02" Value="-206">
<SplineDoubleKeyFrame.KeySpline>
<KeySpline ControlPoint1="0,1" ControlPoint2="1,1"/>
</SplineDoubleKeyFrame.KeySpline>
</SplineDoubleKeyFrame>
<SplineDoubleKeyFrame KeyTime="00:00:04" Value="">
<SplineDoubleKeyFrame.KeySpline>
<KeySpline ControlPoint1="1,0" ControlPoint2="1,1"/>
</SplineDoubleKeyFrame.KeySpline>
</SplineDoubleKeyFrame>
<SplineDoubleKeyFrame KeyTime="00:00:05" Value="-20">
<SplineDoubleKeyFrame.KeySpline>
<KeySpline ControlPoint1="0,1" ControlPoint2="1,1"/>
</SplineDoubleKeyFrame.KeySpline>
</SplineDoubleKeyFrame>
<SplineDoubleKeyFrame KeyTime="00:00:06" Value="">
<SplineDoubleKeyFrame.KeySpline>
<KeySpline ControlPoint1="1,0" ControlPoint2="1,1"/>
</SplineDoubleKeyFrame.KeySpline>
</SplineDoubleKeyFrame>
</DoubleAnimationUsingKeyFrames>
</Storyboard>
</Page.Resources>
<Grid Background="#FFF0F1FF">
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions> <StackPanel x:Name="TitlePanel" Grid.Row="" Margin="12,35,0,28">
<TextBlock Foreground="CornflowerBlue" Text="Naughty Egg" FontSize="" HorizontalAlignment="Center"/>
</StackPanel>
<!--
<Grid Background="AliceBlue" x:Name="ContentPanel" Grid.Row="" Margin="12,0,12,0">
<Path Margin ="50,-200,0,0" Height="" Width="" Stretch="Uniform"
HorizontalAlignment="Left" >
<Path.Fill >
<ImageBrush Stretch="UniformToFill" ImageSource="Assets/Pic1.png" />
</Path.Fill>
<Path.Data >
<GeometryGroup FillRule="EvenOdd" >
<EllipseGeometry Center="50,50" RadiusX="" RadiusY=""
x:Name="ball">
</EllipseGeometry>
</GeometryGroup>
</Path.Data>
</Path>
</Grid>
-->
<Grid x:Name="ContentPanel" Grid.Row="" Margin="12,0,12,0">
<Path Margin ="60,-250,0,0" Height="" Width="" Stretch="Uniform"
HorizontalAlignment="Left">
<Path.Fill >
<ImageBrush Stretch="UniformToFill" ImageSource="Assets/Pic1.png" />
</Path.Fill>
<Path.Data>
<GeometryGroup FillRule="EvenOdd" >
<EllipseGeometry RadiusX="" RadiusY=""
Center="100,100">
</EllipseGeometry>
</GeometryGroup>
</Path.Data>
</Path>
<Ellipse Height="" HorizontalAlignment="Left" Margin="5,0,0,151" VerticalAlignment="Bottom" Width="" Fill="#FFF40B0B" Stroke="#FF000000" x:Name="ball" RenderTransformOrigin="0.5,0.5" Opacity="0.5">
<Ellipse.RenderTransform>
<TransformGroup>
<TranslateTransform/>
</TransformGroup>
</Ellipse.RenderTransform>
</Ellipse>
<StackPanel Margin="0,300,0,100" >
<ProgressRing Background="#FFF0F1FF" x:Name="prgRing" Width="" Height="" Foreground="LightSeaGreen"
IsActive ="True" /> </StackPanel> </Grid> </Grid> </Page>
2) .cs 中控制播放:
public MainPage()
{
this.InitializeComponent();
//开始运行Storyboard
Bounce.Begin();
Bounce.Completed += ToNewPage; timer.Tick += dispatcherTimer_Tick;
timer.Interval = TimeSpan.FromSeconds(1.1); //设置刷新的间隔时间
timer.Start();
}
void dispatcherTimer_Tick(object sender, object e)
{
//function to execute
count++;
if (count == )
{
this.prgRing.IsActive = false;
} }
private void ToNewPage(object sender, object e)
{
Frame rootFrame = this.Parent as Frame;
if (rootFrame == null)
{
return;
} rootFrame.Navigate(typeof(Choice));
}
3)效果:
2、C#中的触控
xml:
<Grid x:Name="gamegrid" RenderTransformOrigin="0.335,0.445" Margin="0,0,0,49"
Background="White" Opacity="0.9">
<Canvas Name="canvas" Margin="5,4,5,3" >
<Ellipse Name="circle"
Width=""
Height=""
Canvas.Left=""
ManipulationDelta="OnManipulationDelta" ManipulationStarting="OnManipulationStarting"
ManipulationCompleted="OnManipulationCompleted" PointerPressed="finger_PointerPressed"
PointerMoved="finger_PointerMoved" PointerReleased="finger_PointerReleased"
Canvas.Top="" RenderTransformOrigin="3.56,3.875">
<Ellipse.DataContext>
<Button Content=" " ></Button>
<!--<Image Name="img1" Source="Assets/Pic2.png" Margin="" Width="" Height="" />-->
</Ellipse.DataContext>
</Ellipse> <TextBlock Foreground="CornflowerBlue" Canvas.Left="" TextWrapping="Wrap" Text="Grades" Canvas.Top="" FontSize="" Height="" Width=""
/>
<TextBlock Height="" Canvas.Left="" TextWrapping="Wrap"
Name="test" Foreground="CornflowerBlue"
Text="{Binding Path=HP}" Canvas.Top="" Width="" FontSize="" FontFamily="Buxton Sketch"
/>
<TextBlock HorizontalAlignment="Center" Name="lev" Foreground="CornflowerBlue" FontSize="" Canvas.Left="" TextWrapping="Wrap" Text="level1" Canvas.Top="" Height="" Width=""/>
</Canvas> </Grid> </Grid>
</Page>
.cs控制:
//控制触摸移动的开始
private void OnManipulationStarting(object sender, ManipulationStartingRoutedEventArgs e)
{
mapMode = e.Mode;
}
//移动中触发
private void OnManipulationDelta(object sender, ManipulationDeltaRoutedEventArgs e)
{
if (ManipulationModes.TranslateX == (mapMode & ManipulationModes.TranslateX))
{
cpTransform.TranslateX += e.Delta.Translation.X;
x = cpTransform.TranslateX;
}
if (ManipulationModes.TranslateY == (mapMode & ManipulationModes.TranslateY))
{
cpTransform.TranslateY += e.Delta.Translation.Y;
y = (double)cpTransform.TranslateY;
} }
// 移动停止时触发
private void OnManipulationCompleted(object sender,ManipulationCompletedRoutedEventArgs e)
{ } // 按下时触发
Boolean pushDown = false;
private void finger_PointerPressed(object sender, PointerRoutedEventArgs e)
{
pushDown = true;
// rect1.Fill = new SolidColorBrush(Colors.Black); }
// 指针或手松开时触发
private void finger_PointerReleased(object sender, PointerRoutedEventArgs e)
{
pushDown = false;
//rect1.Fill = new SolidColorBrush(Colors.Orange);
if (p.HP <= && p.HP >= )
{
XmlDocument toastXml = ToastNotificationManager.GetTemplateContent(ToastTemplateType.ToastText01);
XmlNodeList elements = toastXml.GetElementsByTagName("text");
elements[].AppendChild(toastXml.CreateTextNode("恭喜你成为人生赢家!"));
ToastNotification toast = new ToastNotification(toastXml);
ToastNotificationManager.CreateToastNotifier().Show(toast);
}
}
// 按下手或指针移动过程中触发
private void finger_PointerMoved(object sender, PointerRoutedEventArgs e)
{
Point p = e.GetCurrentPoint(circle).Position;
Point p2 = e.GetCurrentPoint(rect1).Position;
mousepoint = e.GetCurrentPoint(circle).Position;
if (pushDown) {
if (tag == )
{
rect1.Fill = new SolidColorBrush(Colors.Red); //矩形的填充颜色为红色!
changecolor(p2);
}
else
{
changecolor2(p2);
rect1.Fill = new SolidColorBrush(Colors.Green); //矩形的填充颜色为绿色!
}
}
}
效果:
3、画刷
前端xml界面:
<Grid x:Name="ContentPanel" Grid.Row="" Margin="12,0,12,0">
<Path Margin ="60,-250,0,0" Height="" Width="" Stretch="Uniform"
HorizontalAlignment="Left">
<Path.Fill >
<ImageBrush Stretch="UniformToFill" ImageSource="Assets/Pic1.png" />
</Path.Fill>
<Path.Data>
<GeometryGroup FillRule="EvenOdd" >
<EllipseGeometry RadiusX="" RadiusY=""
Center="100,100">
</EllipseGeometry>
</GeometryGroup>
</Path.Data>
</Path>
<Ellipse Height="" HorizontalAlignment="Left" Margin="5,0,0,151" VerticalAlignment="Bottom" Width="" Fill="#FFF40B0B" Stroke="#FF000000" x:Name="ball" RenderTransformOrigin="0.5,0.5" Opacity="0.5">
<Ellipse.RenderTransform>
<TransformGroup>
<TranslateTransform/>
</TransformGroup>
</Ellipse.RenderTransform>
</Ellipse>
<StackPanel Margin="0,300,0,100" >
<ProgressRing Background="#FFF0F1FF" x:Name="prgRing" Width="" Height="" Foreground="LightSeaGreen"
IsActive ="True" /> </StackPanel> </Grid>
效果:
见上图中透出的椭圆形图片效果
Lesson9 some interesting things in C#的更多相关文章
- An interesting experiment on China’s censorship
This paper presented a very interesting topic. Censorship in China has always drawn people's attenti ...
- 2015年辽宁省赛Interesting Tree
题目描述 Recently, Miss Huang want to receive a Tree as her birthday gift! (What a interesting person!) ...
- HDU5785 Interesting(Manacher + 延迟标记)
题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5785 Description Alice get a string S. She think ...
- ural 2070. Interesting Numbers
2070. Interesting Numbers Time limit: 2.0 secondMemory limit: 64 MB Nikolay and Asya investigate int ...
- 多校赛3- Solve this interesting problem 分类: 比赛 2015-07-29 21:01 8人阅读 评论(0) 收藏
H - Solve this interesting problem Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I ...
- hdu Interesting Fibonacci
Interesting Fibonacci Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- CF #365 (Div. 2) D - Mishka and Interesting sum 离线树状数组
题目链接:CF #365 (Div. 2) D - Mishka and Interesting sum 题意:给出n个数和m个询问,(1 ≤ n, m ≤ 1 000 000) ,问在每个区间里所有 ...
- CF #365 (Div. 2) D - Mishka and Interesting sum 离线树状数组(转)
转载自:http://www.cnblogs.com/icode-girl/p/5744409.html 题目链接:CF #365 (Div. 2) D - Mishka and Interestin ...
- Calculations are rather interesting
Calculations are rather interesting, especially when some thoughts are involved therein.
随机推荐
- java实现 zip解压缩
程序实现了ZIP压缩.共分为2部分 : 压缩(compression)与解压(decompression) 大致功能包括用了多态,递归等JAVA核心技术,可以对单个文件和任意级联文件夹进行压缩和解压. ...
- linux下,把屏幕竖起来
xrandr -o left 向左旋转90度 xrandr -o right 向右旋转90度 xrandr -o inverted 上下翻转 xrandr -o normal 回到正常角度
- mysql8.0 忘记root密码
先打开一个cmd:net stop mysql //关闭mysql服务mysqld --shared-memory --skip-grant-tables//跳过登录密码在不关闭第一个CMD的情况下打 ...
- java线程安全总结 - 2 (转载)
原文地址:http://www.jameswxx.com/java/%E7%BA%BF%E7%A8%8B%E5%AE%89%E5%85%A8%E6%80%BB%E7%BB%93%EF%BC%88%E4 ...
- Diycode开源项目 如何解决InputMethodManager造成的内存泄漏问题
1.内存泄漏的状况及原因 1.1.利用LeakCanary查看内存泄漏的状况 1.2.内存泄漏怎么产生的呢? InputMethodManager.mServicedView持有一个最后聚焦View的 ...
- Tomcat详解及SNS系统的部署实现
Tomcat详解及SNS系统的部署实现 http://jungege.blog.51cto.com/4102814/1409290
- JavaScript - 问题集 - 含function的json对象与json字符串之间相互转换
基本的转换为:JSON.parse与JSON.stringify. 但是json数据中含function,则转换后,function会丢失,如: var json={ test:'test', log ...
- Java的接口和抽象类深入理解
对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者确实有很多相似的地方,看了一整天别人怎么说,大致总结如下: 一.抽象类 在了解抽象类 ...
- 对setTimeout函数的理解
之前去面试一家公司时,面试官出了一道关于js的setTimeout函数的题目: /* *面试官给的原题目如下: *执行mytest()后,控制台输出内容是_____ *function mytest( ...
- 剑指Offer - 九度1518 - 反转链表
剑指Offer - 九度1518 - 反转链表2013-11-30 03:09 题目描述: 输入一个链表,反转链表后,输出链表的所有元素.(hint : 请务必使用链表) 输入: 输入可能包含多个测试 ...