Windows Surface for 多点触摸 简介

news/2024/11/17 18:35:38/

最近研究了一下Windows  Surface , 很 cool 很炫 ,我想这是微软对抗苹果的好东西,这个东西是一个桌面程序,使用Windows7 操作系统就可以(我才知道Win7 系统本身是支持多点触摸操作~~~汗)

Surface 是基于WPF 技术来进行给用户展现的,可以想想我们以后的茶机,电视墙,洗脸镜,防盗门上都会是这些可以触碰操作的屏幕,那会是多么向往的生活。接下来我们看看几个Surface 的一些视频

http://www.tudou.com/programs/view/09jtf6d0kUs/


更多视频大家可以去搜索一下


其实更多的技术介绍我这里就不啰嗦了,网上会有很多,我喜欢用ScatterView 这个控件。可以随意拖动,放大,旋转 桌面照片,视频,以及文档内容。官方的Surface 2.0 SDK里面有Code Simple ,会介绍各种控件以及使用场景。

想尝试的朋友们,你们只要机器是Win7的 ,有VS2010 那么剩下的就是下载一个Surface SDK,Surface Runtime 就可以


-------------------以下内容是转载博客园中 Gnie 的内容,更多介绍大家可以去看看他的博客,不过目前学习资料太少,建议大家最好是了解,如果要做项目千万慎重考虑-----------------

以前的博文我曾向大家介绍过利用WPF 4 开发具有多点触屏功能的应用程序,可参考《Multi-Touch 开发资源汇总》。在那些文章中无论是简单的拖拽,还是复杂的旋转、缩放效果(下文简称Manipulating)都需要开发者逐字逐句的编写出来。Surface 2.0 SDK 的发布可以使这些工作更加简单,我们甚至不需要对这些效果写任何代码。

     本篇将为大家介绍如何使用ScatterView 控件实现上述功能。由于触屏技术只在Windows 7 操作系统中支持,所以XP 的用户必须要升级到Windows 7 系统。首先,需要在Windows 7 中安装Surface 2.0 SDK 和Runtime,可到官方页面下载安装程序。安装完成后打开VS2010 新建一个Surface 2.0 项目。在模板中选择Surface Appliction(WPF)。

CreateProject

     我们可以在当前的XAML 代码中添加一个Label 控件。F5 运行后Label 控件是无法进行Manipulating 操作的。

<s:SurfaceWindow x:Class="ScatterView.SurfaceWindow1"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:s="http://schemas.microsoft.com/surface/2008"Title="ScatterView"
><Grid><Label Content="Surface 2.0" Foreground="Fuchsia" FontWeight="Bold"/></Grid>
</s:SurfaceWindow>
Label

     接下来在Grid 中添加一个ScatterView 控件。我们可以将ScatterView 认为是一个容器能够包含其他控件,并且这些控件均可以实现Manipulating 效果。例如,我们在ScatterView 中加入Rectangle、Label、SurfaceTextBox 三个控件。有些朋友可能会问Rectangle 为什么要放在ScatterViewItem 里?其实,所有在ScatterView 里的控件默认都会自动加入到ScatterViewItem,所以如果不需要特别设置可以将ScatterViewItem 控件省略。本例中我为了调整Rectangle 的减速数值就需要手动写出ScatterViewItem 控件,并调整Deceleration 参数。

<Grid><s:ScatterView x:Name="mainScatterView"><s:ScatterViewItem Deceleration="50"><Rectangle Fill="Green" Width="200" Height="100"/></s:ScatterViewItem><Label Content="Surface 2.0" Foreground="Fuchsia" FontWeight="Bold"/><s:SurfaceTextBox Width="500" Height="20" FontSize="20"/></s:ScatterView>
</Grid>

完成上面代码后,F5 再运行一次。感觉如何?Manipulating 效果是不是变得很简单了... ...

ItRun

如果有需要可以自动加载控件到ScatterView,下面代码将自动加入一张本机图片到程序中。

private void AddDemoPic()
{string targetPic = @"C:\Users\Public\Pictures\Sample Pictures\Koala.jpg";ScatterViewItem item = new ScatterViewItem();mainScatterView.Items.Add(item);MediaElement pic = new MediaElement();item.Content = pic;item.Background = Brushes.Transparent;if (System.IO.File.Exists(targetPic)){pic.Source = new Uri(targetPic);}else{item.Content = "Picture not found";}
}

NicePicture

至此,本篇关于ScatterView 的介绍就到这里,欢迎大家相互交流。



http://www.ppmy.cn/news/484989.html

相关文章

android---多点触控

1.多点触控的基本概念 /** * ①即便是多个手指触控&#xff0c;仍然只有一个move事件。 * 当第一个手指点击的时候index就为0&#xff0c;当第二个手指点击的时候index就为1 * 当第一个手指抬起的时候&#xff0c;第二个手指的点的index就变成了0 * 这个是和pointerId是不同的&…

H5多点触控原理以及对多点触控的追踪

文章目录 接触点类Touch触摸事件接触点的生命周期类多点触控的追踪器抛砖引玉 对于PC端&#xff0c;我们的点击事件比较简单&#xff0c;因为鼠标指针只有一个。 但是对于移动端来说&#xff0c;存在多个接触点同时操作的情况&#xff0c;这种情况就是我们今天要研究的主题 – …

多点触摸操作

1.要处理Manipulation事件&#xff0c;首先必须设置UIElement的IsManipulationEnabled为true 2.ManipulationInertiaStartingEvent事件包含一个ManipulationStartingEventArgs参数&#xff0c;通过该参数可以设置&#xff1a;   UIElement的ManipulationContainer —— 设置…

开启多点触摸

一.ios上的多点触摸 现在很多游戏都有多点触摸&#xff0c;它能让玩家有更好的体验。 要开启多点触摸&#xff0c;必须在工程的ios目录下的AppController&#xff08;AppDelegate&#xff09;文件中添加代码。 在didFinishLaunchingWithOptions函数中添加 [__glView s…

实现单点和多点触屏操作

1、当把unity游戏运行到IOS或者Android设备上时候&#xff0c;桌面系统中的鼠标左键操作可以自动变为手机屏幕上的触屏操作&#xff0c;但鼠标操作无法实现一些特有的触屏操作&#xff0c;比如多点触屏等&#xff0c;在unity的input类中&#xff0c;除了包括桌面系统的各种输入…

多点触摸:MultiPointTouchArea

MultiPointTouchArea minimumTouchPoints: 多点触摸数量的最小值 maximumTouchPoints: 最大值 touchPoints:数组,存储自定义ID,每个ID将会是一个触摸点,外部使用ID访问此触摸的状态:按下抬起、XY等等属性 代码:每次触摸触发对应的粒子特效,粒子发射坐标为触摸点的坐标 Multi…

windows 7多点触摸开发

win7 触摸屏系统应用广泛&#xff0c;软件操作方便&#xff0c;功能强大&#xff0c;现以被许多硬件厂商应用。 我曾用一台装有win7 的汉王平板电脑进行了多点触摸软件的开发。 开发环境及条件&#xff1a; 1. 平板电脑 win7触摸系统 2. 编译平台 win7vs2010 。&#xff08;我…

什么是多点触摸?

传统的触控屏幕一次只能判断一个触控点&#xff0c;若同时有两个以上的点被触碰&#xff0c;就不能做出正确反应&#xff0c;或者说反应混乱了。多重触控的任务可以分解为两个方面的工作&#xff0c;一是同时采集多点信号&#xff0c;二是对每路信号的意义进行判断&#xff0c;…