Windows 8.1 应用开发 – 触控操作
与WPF相同Windows 8.1应用中也具有高级触控操作(Manipulation),其中包含了三种常见的触屏手势:平移、缩放、旋转,通过以下四种事件可为控件实现各种触控操作:ManipulationStarting、ManipulationStarted、ManipulationDelta、ManipulationInertiaStarting、ManipulationCompleted。
打开Visual Studio 2013 Preview,新建Windows Store应用。在XAML代码中添加Image控件,将ManipulationMode设置为ALL(也可按需要选择不同模式),并为其添加ManipulationStarting、ManipulationDelta、ManipulationCompleted事件,以便后续实现相关手势操作内容。RenderTransform中的CompositeTransform是一个控件变形组合,可容纳多种变形属性,如平移、旋转、缩放。
<Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">
<Canvas> <Image x:Name="imageElement" Source="images/cliff.jpg" Height="460" Width="758" Canvas.Left="300" Canvas.Top="150" ManipulationMode="All" ManipulationStarting="image_ManipulationStarting" ManipulationDelta="image_ManipulationDelta" ManipulationCompleted="image_ManipulationCompleted"> <Image.RenderTransform> <CompositeTransform x:Name="imageCT"/> </Image.RenderTransform> </Image> </Canvas> </Grid>
接下来,编写每个事件的具体内容,如下代码:
private void image_ManipulationStarting(object sender, ManipulationStartingRoutedEventArgs e) { e.Handled = true; } private void image_ManipulationDelta(object sender, ManipulationDeltaRoutedEventArgs e) { FrameworkElement element = e.OriginalSource as FrameworkElement; element.Opacity = 0.5;
imageCT.TranslateX += e.Delta.Translation.X; imageCT.TranslateY += e.Delta.Translation.Y; imageCT.ScaleX *= e.Delta.Scale; imageCT.ScaleY *= e.Delta.Scale; imageCT.Rotation += e.Delta.Rotation; }
private void image_ManipulationCompleted(object sender, ManipulationCompletedRoutedEventArgs e) {
FrameworkElement element = e.OriginalSource as FrameworkElement; element.Opacity = 1; }
这些代码很好理解,当ManipulationDelta触发后,首先将控件透明度设置为0.5,然后捕捉触控操作并对TranslateX、TranslateY(平移);ScaleX、ScaleY(缩放)、Rotation(旋转)进行修改。最后ManipulationCompleted结束后将控件透明度恢复即可。按下F5键看看效果如何。
作者:李敬然(Gnie)
出处:{GnieTech} (http://www.cnblogs.com/gnielee/)
版权声明:本文的版权归作者与博客园共有。转载时须注明本文的详细链接,否则作者将保留追究其法律责任。
出处:{GnieTech} (http://www.cnblogs.com/gnielee/)
版权声明:本文的版权归作者与博客园共有。转载时须注明本文的详细链接,否则作者将保留追究其法律责任。
分类:
Windows 8
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?