2019-11-29-浅谈-Windows-桌面端触摸架构演进

原文:2019-11-29-浅谈-Windows-桌面端触摸架构演进

title author date CreateTime categories

浅谈 Windows 桌面端触摸架构演进

lindexi

2019-11-29 10:20:37 +0800

2019-11-12 08:41:21 +0800

我在和小伙伴水触摸相关的坑,说到了上古的触摸,很难和小伙伴统一知识,于是就写了本文用于告诉大家,桌面端的触摸架构是如何一步步演进的

所有触摸架构都建立在系统之上,和系统版本相关。所以可以通过系统划分。虽然说是触摸架构,但是我能知道的也就是应用层面的接口和编程方法,如果是小伙伴被标题吸引过来的,想看触摸架构,那么请左转官方的 文档

在 XP 之前的系统,在开发行业,触摸屏只有少数游戏才能使用,此时触摸屏不是标准设备,各个应用需要通过端口访问硬件设备。也就是软件没有通过系统,直接和硬件通讯做到触摸。因为没有约定好触摸屏标准,可能有些触摸屏用的是PIN输入,有些用蓝牙输入,在上古的开发者都是非常厉害的,所以实现起来十分诡异。在这里是无法说明架构的,每个公司都可以使用自己的方式开发。请看 Windows for Pen Computing

在 XP 的时候,此时触摸屏成为 HID 设备,也就是有了标准。可以在系统上支持触摸屏,我记得在缺少补丁和驱动将会只支持单点触摸,如果需要支持多点触摸,需要额外的补丁或驱动。这部分我没有去查文档,如有错误,请告诉我。在 XP 的触摸存在很多坑,如果要在 XP 上开发支持多点触摸的应用,需要用一些有趣的技术,如TUIO等。此时的触摸屏还是作为 Mouse 用,此时我将这一代的触摸架构称为上古的触摸

在 Vista 和 Win7 才算支持多点触摸,此时的应用默认可以收到了 Gestures 消息,如果注册了 RegisterTouchWindow 的窗口将会接收到 Touch 消息,此时通过 Touch 消息就能做到多指触摸,请看 Detecting and Tracking Multiple Touch Points

在 Win7 的触摸是通过硬件设备作为 HID 设备,通过 HAL 层收集到信息,通过系统驱动进行转发消息。此时的硬件将不是直接连接到软件,中间会经过很多层,此时系统将会处理很多触摸的细节,开发的难度降低。但是这也存在一个坑就是系统的稳定性,如果系统没有正确处理触摸消息和触摸消息的转发,那么将会让应用或系统触摸失效

但是微软发现在书写时,如果走 Touch 消息,此时因为需要经过 Windows 消息,速度没有之前从硬件获取的快,于是提出了 Windows Inking Service Platform 请看 WPF 触摸到事件

在 Win7 的这个触摸架构就是古代的触摸

很多开发者都会反馈在 Win7 开发的触摸失效问题,如 WPF 客户端开发需要知道的触摸失效问题 和需要区分 Touch 和 Stylus 和鼠标事件,这样的开发成本比较高

在 Windows 8 提出了现代的触摸方法,通过 Pointer 表示,无论是鼠标还是触摸还是笔都是使用相同的 Pointer 消息,这个触摸架构将会对触摸有很好的支持。默认在 UWP 应用使用这个触摸架构,而 WPF 程序可以通过 这个方法 开启,对于 win32 应用需要使用 EnableMouseInPointer 方法在进程内开启

在上古的系统,因为触摸屏没有大量使用,也没有标准,只能各个应用读写硬件设备自己做触摸。在 XP 的时候,开始引入触摸屏 HID 设备标准(不确定win98又没引入,毕竟我不是学历史的) 此时触摸刚起步,存在很多不合理的设计,多点触摸还没有完善,需要依赖额外的驱动和补丁。在 Win7 将触摸作为 Windows 消息,支持了多点的触摸,同时兼容 XP 和上古的和硬件设备读写的软件,但是 Win7 系统消息的转发受补丁和驱动的影响,也会存在一些触摸失效,同时因为 Touch 消息和鼠标消息分开,降低了开发效率。在 Win8 提出了 Pointer 消息,可以将触摸等合并为相同的消息

本文主要的是下面文档,更多细节请看文档

Introduction to WPF 4 Multitouch – Jaime Rodriguez

c# - WPF supports touch or multi-touch screen? - Stack Overflow

MultiTouch driver for Windows XP Tablet PC Edition 2005 - ThinkPad X60 Tablet, X61 Tablet, X200 Tablet - PL

Getting Started with Windows Touch Messages

Getting Started with Windows Touch Gestures

TranslateZoomRotateBehavior

Pointer Input Messages and Notifications

win10 支持默认把触摸提升 Pointer 消息

WPF 触摸到事件

WPF 客户端开发需要知道的触摸失效问题

原文地址:https://www.cnblogs.com/lonelyxmas/p/12075834.html

时间: 2024-11-13 06:58:03

2019-11-29-浅谈-Windows-桌面端触摸架构演进的相关文章

浅谈Windows平台下C++调用静态链接库的方式

浅谈Windows平台下C++调用静态链接库的方式 1. 什么是静态链接库?为什么要用静态链接库? 维基百科上关于静态库的解释是这样的:在计算机科学里,静态库(英语:Static library, Statically-linked library),或称静态库,是一个外部函数与变量的集合体.静态库的文件内容,通常包含一堆程序员自定的变量与函数,其内容不像动态链接库那么复杂,在编译期间由编译器与连接器将它集成至应用程序内,并制作成目标文件以及可以独立运作的可执行文件. 由上面的解释可以很清楚的看

浅谈Windows Server APPFABRIC

    hi,everyone !真的是好久好久没有update blog了,因为最近忙着备考,没有时间对<数据结构与算法>进行研究学习了.所以,blog一直未更新.today is Friday,心里比较轻松,(哈哈,上班族懂我的感受),有时间写篇技术文章了.正好,最近研究了一些新技术,这篇文章权当对技术的梳理归纳吧.子曰:"温故而知新,可以为师也."对于knowledge,我们一定要时常复习.thought.归纳.practice.只有这样,我们才能真正的掌握它.Ein

浅谈Windows API编程

WinSDK是编程中的传统难点,个人写的WinAPI程序也不少了,其实之所以难就难在每个调用的API都包含着Windows这个操作系统的潜规则或者是windows内部的运行机制…… WinSDK是编程中的传统难点,曾经听有一个技术不是很好的朋友乱说什么给你API谁都会用,其实并非那么简单,个人写的WinAPI程序也不少了,其实之所以难就难在每个调用的API都包含着Windows这个操作系统的潜规则或者是windows内部的运行机制. 首先来谈谈句柄,初学习WinSDK的朋友刚看到这个词头大了吧?

浅谈前端移动端页面开发(布局篇)

前言的一些碎碎念:最近一直在写移动端的页面,不过一直是用的别人造好的轮子,很多时候并没有想那是为什么,那是怎么样要那么写,就跟着别人的文档去了.本以为自己对移动端的那一丢丢理解,结果很多东西都特么有问题,所以,今天停下了手中的一些东西,来谈下移动端的布局方案吧 内容有些长,这也是我第一次写博客,不足之处还请严厉指出 一. viewport 什么是viewport 简单来讲,viewport就是浏览器上,用来显示网页的那一部分区域了,也就是说,浏览器的实际宽度,是和我们手机的宽度不一样的,无论你的

浅谈iOS中MVVM的架构设计与团队协作【转载】

今天写这篇文章是想达到抛砖引玉的作用,想与大家交流一下思想,相互学习,博文中有不足之处还望大家批评指正.本篇文章的内容沿袭以往博客的风格,也是以干货为主,偶尔扯扯咸蛋(哈哈~不好好工作又开始发表博客啦~). 由于本人项目经验有限,关于架构设计方面的东西理解有限,我个人对MVVM的理解主要是借鉴于之前的用过的MVC的Web框架~在学校的时候用过ThinkPHP框架,和SSH框架,都是MVC的架构模式,今天MVVM与传统的MVC可谓是极为相似,也可以说是兄弟关系,也就是一家人了. 说到架构设计和团队

IOS中 浅谈iOS中MVVM的架构设计与团队协作

今天写这篇文章是想达到抛砖引玉的作用,想与大家交流一下思想,相互学习,博文中有不足之处还望大家批评指正.本篇文章的内容沿袭以往博客的风格,也是以干货为主,偶尔扯扯咸蛋(哈哈~不好好工作又开始发表博客啦~). 每日更新关注:http://weibo.com/hanjunqiang  新浪微博 由于本人项目经验有限,关于架构设计方面的东西理解有限,我个人对MVVM的理解主要是借鉴于之前的用过的MVC的Web框架~在学校的时候用过ThinkPHP框架,和SSH框架,都是MVC的架构模式,今天MVVM与

浅谈h5移动端页面的适配问题

一.前言 昨天唠叨了哈没用的,今天说点有用的把.先说一下响应式布局吧,我一直认为响应式布局的分项目,一下布局简单得项目做响应式还是可以可以得.例如博客.后台管理系统等.但是有些会认为响应式很牛逼,尤其是在不懂前端的人眼中,一味的追求响应式布局,我觉得复杂的布局项目做响应式还不如做二套样式,因为响应式的样式混在一起真的维护起来是恨费劲的.可能我说的不对,但是发表 一点点自己的看法.说道这里就想说一下移动端的布局,有很多人就是想把手机端得程序兼容ipad,我就觉得这个很不可思议为什么要这么做得,命名

浅谈Linux桌面(发行版及桌面环境)

Part I: 前言 笔者2018年接触Linux(当时还是学校机房的Ubuntu 14.04 LTS),至今已经有2个年头了. 折腾了至少十几个Linux发行版,包括但不限于: ubuntu.Debian.Red Hat.CentOS.Fedora.Manjaro.deepin.Arch Linux.Gentoo(没装成功).Linux Mint.MX Linux.Elemantary OS.KDE neon...... (好像忘记openSUSE了) 折腾了这么久,从一名连命令行都不知为何物

浅谈windows消息驱动的基本原理(.NET平台)

最近的课设涉及到调用系统API函数和窗体消息的发送,重载接收等.因此发表一篇浅文,希望能和大家共同探讨,学习. 首先,windows是一个基于视窗的消息驱动系统.这句话非常的有意思.重点是"视窗"和"消息驱动"这两个词,这两个词包含了windows界面的处理原理.下面解释下什么是消息驱动.所谓"消息",即"事件".接触过C#.NET的朋友都知道,你拖一个控件,双击,添加代码,这一段即可称为"事件".严肃点来