pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

Javascript 高級手勢使用介紹_html5教程技巧

Javascript 高級手勢使用介紹_html5教程技巧HTML5中文學(xué)習(xí)網(wǎng),是中國最大的HTML5中文門戶,為廣大HTML5愛好者提供各種HTML5資料,包括HTML5網(wǎng)站、HTML5資訊、HTML5應(yīng)用、HTML5游戲、HTML5教程、HT
點評:在IE10中新加入的對高級用戶輸入的識別支持,舉例說明:注冊一個點擊操作,通過一句addEventListener 就能夠知道當(dāng)前用戶的點擊是哪種設(shè)備,是手指的點擊,是鼠標(biāo)的單擊還是觸控筆的點擊(平板設(shè)備都會帶有觸控筆)

  在IE10中新加入的對高級用戶輸入的識別支持,舉例說明:注冊一個點擊操作,通過一句addEventListener 就能夠知道當(dāng)前用戶的點擊是哪種設(shè)備,是手指的點擊,是鼠標(biāo)的單擊還是觸控筆的點擊(平板設(shè)備都會帶有觸控筆)。

 <canvas id="MyCanvas"></canvas>
    <script>
        MyCanvas.addEventListener(
"MSPointerDown", MyBack, false);
        
function MyBack(e) {
            alert(e.pointerType.toString());
        }
    
</script>

 以上這段代碼就是能夠識別出當(dāng)前用戶的點擊是哪種設(shè)備,通過回調(diào)的方法中 e.pointerType 還進行判斷。鼠標(biāo)是4,觸控筆是3,手指是2。至于值為1是何種設(shè)備還有待研究。

還有需要注意的就是 想在javascript中添加對輸入設(shè)備的識別,注冊的方法事件也是有點點區(qū)別。

addEventListener 添加的事件為 MSPointerDown

而在IE10中對于這樣的多種設(shè)備識別中優(yōu)先處理的手指的點擊,前提是不影響功能正常單擊的情況下。然而IE10不僅僅能識別用戶的輸入設(shè)備還支持非常多的高級手勢

以下為IE10高級手勢支持的演示

 

創(chuàng)建手勢對象

在您的網(wǎng)站中處理手勢的第一步是實例化手勢對象。

var myGesture = new MSGesture();

接下來,為該手勢提供一個目標(biāo)元素。瀏覽器將對該元素觸發(fā)手勢事件。同時,該元素還可以確定事件的坐標(biāo)空間。

elm = document.getElementById("someElement");

myGesture.target = elm;

elm.addEventListener("MSGestureChange", handleGesture);

最后,告知手勢對象在手勢識別期間處理哪些指針。

elm.addEventListener("MSPointerDown", function (evt) {

// adds the current mouse, pen, or touch contact for gesture recognition

myGesture.addPointer(evt.pointerId);

});

注意:請不要忘記您需要使用 –ms-touch-action 來配置元素以防止其執(zhí)行默認觸摸操作(例如,平移和縮放),并為輸入提供指針事件。

處理手勢事件

一旦手勢對象具有有效目標(biāo)并至少添加了一個指針,則其將開始觸發(fā)手勢事件。手勢事件可分為兩種:靜態(tài)手勢(例如,點擊或保持)和動態(tài)手勢(例如,收縮、旋轉(zhuǎn)和輕掃)。

點擊

最基本的手勢識別是點擊。當(dāng)檢測到點擊時,將會在手勢對象的目標(biāo)元素觸發(fā) MSGestureTap 事件。不同于單擊事件,點擊手勢只能在用戶觸摸、按鼠標(biāo)按鈕或使用手寫筆觸控而不移動時觸發(fā)。如果您要區(qū)分用戶點擊元素和拖動元素的操作,這一點通常會顯得十分有用。

長按

長按手勢是指用戶使用一個手指觸摸屏幕,并保持片刻并抬起而不移動的操作。在長按交互期間,MSGestureHold 事件會針對手勢的各種狀態(tài)而多次觸發(fā):

復(fù)制代碼
代碼如下:

element.addEventListener("MSGestureHold", handleHold);
function handleHold(evt) {
if (evt.detail & evt.MSGESTURE_FLAG_BEGIN) {
// Begin signals the start of a gesture. For the Hold gesture, this means the user has been holding long enough in place that the gesture will become a complete press & hold if the finger is lifted.
}
if (evt.detail & evt.MSGESTURE_FLAG_END) {
// End signals the end of the gesture.
}
if (evt.detail & evt.MSGESTURE_FLAG_CANCEL) {
// Cancel signals the user started the gesture but cancelled it. For hold, this occurs when the user drags away before lifting. This flag is sent together with the End flag, signaling the gesture recognition is complete.
}
}

動態(tài)手勢(收縮、旋轉(zhuǎn)、輕掃和拖動)

動態(tài)手勢(例如,收縮或旋轉(zhuǎn))將以轉(zhuǎn)換的形式報告,這與 CSS 2D 轉(zhuǎn)換頗為類似。動態(tài)手勢可觸發(fā)三種事件:MSGestureStartMSGestureChange(隨著手勢的持續(xù)而重復(fù)觸發(fā))和 MSGestureEnd。每個事件都包含縮放(收縮)、旋轉(zhuǎn)、轉(zhuǎn)換和速度等相關(guān)信息。

由于動態(tài)手勢以轉(zhuǎn)換的形式報告,因此使用包含 CSS 2D 轉(zhuǎn)換的 MSGesture 來操作諸如照片或拼圖等元素將變得十分輕松。例如,您可以通過下列方式啟用縮放、旋轉(zhuǎn)和拖動元素的操作:

復(fù)制代碼
代碼如下:

targetElement.addEventListener("MSGestureChange", manipulateElement);
function manipulateElement(e) {
// Uncomment the following code if you want to disable the built-in inertia provided by dynamic gesture recognition
// if (e.detail == e.MSGESTURE_FLAG_INERTIA)
// return;
var m = new MSCSSMatrix(e.target.style.transform); // Get the latest CSS transform on the element
e.target.style.transform = m
.translate(e.offsetX, e.offsetY) // Move the transform origin under the center of the gesture
.rotate(e.rotation * 180 / Math.PI) // Apply Rotation
.scale(e.scale) // Apply Scale
.translate(e.translationX, e.translationY) // Apply Translation
.translate(-e.offsetX, -e.offsetY); // Move the transform origin back
}


縮放和旋轉(zhuǎn)等動態(tài)手勢可支持鼠標(biāo)操作,具體可通過在旋轉(zhuǎn)鼠標(biāo)滾輪的同時分別使用 CTRL 或 SHIFT 修飾鍵來實現(xiàn)。


【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

作為一名前端工程師,寫組件的能力至關(guān)重要。雖然javascript經(jīng)常被人嘲笑是個小玩具,但是在一代代大牛的前仆后繼的努力下,漸漸的也摸索了一套組件的編寫方式。下面我們來談?wù)劊?/div>
call和apply都是改變上下文中的this并立即執(zhí)行這個函數(shù),bind方法可以讓對應(yīng)的函數(shù)想什么時候調(diào)就什么時候調(diào)用,并且可以將參數(shù)在執(zhí)行的時候添加,這是它們的區(qū)別,根據(jù)自己的實際情
JavaScript對象是一種復(fù)合值:它是屬性和已命名值的集合。通過quot;.quot;符號來引用屬性值。當(dāng)屬性值是一個函數(shù)時,稱為方法。,HTML5中國,中國最大的HTML5中文門戶。
JavaScript 只有 function 級的定義域,而無其他很多編程語言中的塊定義域,所以使得你在某一 function 內(nèi)的某語句和循環(huán)體中定義了一個變量,此變量可作用于整個 function 內(nèi),而不僅僅是在
如何寫JavaScript才能逼格更高呢?怎樣才能組織JavaScript才能讓別人一眼看出你不簡單呢?是否很期待別人在看完你的代碼之后感嘆一句“原來還可以這樣寫”呢?下面列出一些在JavaScri
您只要按照這七個步驟操作就會大大提高您的JavaScript項目的質(zhì)量。使用這個工作流程,錯誤將會減少并且將很多處理優(yōu)化,讓用戶擁有一個愉悅的上網(wǎng)瀏覽體驗。 ...,HTML5中國,中國最
主站蜘蛛池模板: 洗石机-移动滚筒式,振动,螺旋,洗矿机-青州冠诚重工机械有限公司 | 润东方环保空调,冷风机,厂房车间降温设备-20年深圳环保空调生产厂家 | 单柱拉力机-橡胶冲片机-哑铃裁刀-江都轩宇试验机械厂 | 帽子厂家_帽子工厂_帽子定做_义乌帽厂_帽厂_制帽厂_帽子厂_浙江高普制帽厂 | 猪I型/II型胶原-五克隆合剂-细胞冻存培养基-北京博蕾德科技发展有限公司 | 寮步纸箱厂_东莞纸箱厂 _东莞纸箱加工厂-东莞市寮步恒辉纸制品厂 | 全自动在线分板机_铣刀式在线分板机_曲线分板机_PCB分板机-东莞市亿协自动化设备有限公司 | 恒压供水控制柜|无负压|一体化泵站控制柜|PLC远程调试|MCGS触摸屏|自动控制方案-联致自控设备 | 广州小程序开发_APP开发公司_分销商城系统定制_小跑科技 | 蓝莓施肥机,智能施肥机,自动施肥机,水肥一体化项目,水肥一体机厂家,小型施肥机,圣大节水,滴灌施工方案,山东圣大节水科技有限公司官网17864474793 | 短信营销平台_短信群发平台_106短信发送平台-河南路尚 | 青岛成人高考_山东成考报名网| 多功能真空滤油机_润滑油全自动滤油机_高效真空滤油机价格-重庆润华通驰 | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | 氧化锆陶瓷_氧化锆陶瓷加工_氧化锆陶瓷生产厂家-康柏工业陶瓷有限公司 | 青岛侦探调查_青岛侦探事务所_青岛调查事务所_青岛婚外情取证-青岛狄仁杰国际侦探公司 | 螺旋叶片_螺旋叶片成型机_绞龙叶片_莱州源泽机械制造有限公司 | 企典软件一站式企业管理平台,可私有、本地化部署!在线CRM客户关系管理系统|移动办公OA管理系统|HR人事管理系统|人力 | 选宝石船-陆地水上开采「精选」色选机械设备-青州冠诚重工机械有限公司 | 山东钢衬塑罐_管道_反应釜厂家-淄博富邦滚塑防腐设备科技有限公司 | 台式低速离心机-脱泡离心机-菌种摇床-常州市万丰仪器制造有限公司 | 短信通106短信接口验证码接口群发平台_国际短信接口验证码接口群发平台-速度网络有限公司 | 流量卡中心-流量卡套餐查询系统_移动电信联通流量卡套餐大全 | WF2户外三防照明配电箱-BXD8050防爆防腐配电箱-浙江沃川防爆电气有限公司 | 安徽净化板_合肥岩棉板厂家_玻镁板厂家_安徽科艺美洁净科技有限公司 | 铝扣板-铝方通-铝格栅-铝条扣板-铝单板幕墙-佳得利吊顶天花厂家 elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 北京翻译公司-专业合同翻译-医学标书翻译收费标准-慕迪灵 | 上海办公室设计_办公楼,写字楼装修_办公室装修公司-匠御设计 | 净化工程_无尘车间_无尘车间装修-广州科凌净化工程有限公司 | 济南货架定做_仓储货架生产厂_重型货架厂_仓库货架批发_济南启力仓储设备有限公司 | 北京征地律师,征地拆迁律师,专业拆迁律师,北京拆迁律师,征地纠纷律师,征地诉讼律师,征地拆迁补偿,拆迁律师 - 北京凯诺律师事务所 | 湖州织里童装_女童男童中大童装_款式多尺码全_织里儿童网【官网】-嘉兴嘉乐网络科技有限公司 | 矿用履带式平板车|探水钻机|气动架柱式钻机|架柱式液压回转钻机|履带式钻机-启睿探水钻机厂家 | 厂房出售_厂房仓库出租_写字楼招租_土地出售-中苣招商网-中苣招商网 | 铝镁锰板_铝镁锰合金板_铝镁锰板厂家_铝镁锰金属屋面板_安徽建科 | 自恢复保险丝_贴片保险丝_力特保险丝_Littelfuse_可恢复保险丝供应商-秦晋电子 | 卫浴散热器,卫浴暖气片,卫生间背篓暖气片,华圣格浴室暖气片 | 创客匠人-让IP变现不走弯路 | 耐高温风管_耐高温软管_食品级软管_吸尘管_钢丝软管_卫生级软管_塑料波纹管-东莞市鑫翔宇软管有限公司 | 换网器_自动换网器_液压换网器--郑州海科熔体泵有限公司 | DNA亲子鉴定_DNA基因检测中心官方预约平台-严选好基因网 |