移動端中的陀螺儀

来源:https://www.cnblogs.com/xiaohuochai/archive/2018/03/06/8511935.html
-Advertisement-
Play Games

前面的話 本文將詳細介紹移動端中的陀螺儀的概念及相關實現 橫豎屏 window下的orientation屬性來表示移動端的橫豎屏狀態,chrome模擬器不支持該屬性,只能在真機上測試 按照上右下左的順序,該屬性的結果分別是0、90、180、-90 [註意]手機頭朝下的切換沒有實現 window下的o ...


前面的話

  本文將詳細介紹移動端中的陀螺儀的概念及相關實現

 

橫豎屏

  window下的orientation屬性來表示移動端的橫豎屏狀態,chrome模擬器不支持該屬性,只能在真機上測試

window.orientation

  按照上右下左的順序,該屬性的結果分別是0、90、180、-90

  [註意]手機頭朝下的切換沒有實現

  window下的orientationchange事件來監測移動端的橫豎屏狀態

  [註意]橫豎屏切換也會觸發resize事件

    window.addEventListener('orientationchange',()=>{
      alert(window.orientation)
    })

  測試代碼如下

<style>
#box{
  width: 100px;
 height: 100px; line
-height: 100px; background: pink; margin: 30px auto 0; text-align: center; } </style> <div id="box"></div> <script> let oBox = document.getElementById('box') window.addEventListener('orientationchange',()=>{ oBox.innerHTML = window.orientation }) </script>

  查看效果

 

設備方向

  deviceorientation事件用來監聽設備的方向

  設備在三維空間中是靠x、y和z軸來定位的。當設備靜止放在水平錶面上時,這三個值都是0

  x軸方向是從左往右,y軸方向是從下往上,z軸方向是從後往前

  觸發deviceorientation事件時,事件對象中包含著每個軸相對於設備靜止狀態下發生變化的信息,事件對象包含以下5個屬性

alpha:在圍繞z軸旋轉時(即左右旋轉時),y軸的度數差;是一個介於0到360之間的浮點數
beta:在圍繞x軸旋轉時(即前後旋轉時),z軸的度數差;是一個介於-180到180之間的浮點數
gamma:在圍繞y軸旋轉時(即扭轉設備時),z軸的度數差;是一個介於-90到90之間的浮點數
absolute:布爾值,表示設備是否返回—個絕對值
compassCalibrated:布爾值,表示設備的指南針是否校準過

  手機放置在水平桌面上,android的alpha、beta、gamma值為90、0、0;IOS的alpha、beta、gamma值為0、0、0

  測試代碼如下

<style>
#box{
  width: 100px;
  line-height: 100px;
  height: 100px;
  background: pink;
  margin: 30px auto 0;
  text-align: center;
}  
</style>
<div id="box"></div>
<script>
let oBox = document.getElementById('box');
window.addEventListener('deviceorientation',(e)=>{
  oBox.innerHTML = Math.round(e.beta)
  oBox.style.transform = `rotate(${e.beta}deg)`
})
</script>

  查看效果

 

設備移動

  window.devicemotion事件告訴開發人員設備什麼時候移動,而不僅僅是設備方向如何改變

  觸發devicemotion事件時,事件對象包含以下屬性

acceleration:一個包含X、y和z屬性的對象,在不考慮重力的情況下,告訴你在每個方向上的加速度
accelerationIncludingGravity: 一個包含x、y和z屬性的對象,在考慮z軸自然重力加速度的情況下,告訴你在每個方向上的加速度
interval:以毫秒錶示的時間值,必須在另一個devicemotion事件觸發前傳入。這個值在每個事件中應該是一個常量
rotationRate: —個包含表示方向的alpha、beta和gamma屬性的對象

  手機在不同方向下,android和IOS的acceleration和accelerationlncludingGravity這兩個屬性的x、y、z的值表示不同

  1、放置在水平桌面上

android x:0 y:0 z:10
IOS x:0 y:0 z:-10

  2、屏幕朝右

android x:-10 y:0 z:0
IOS x:10 y:0 z:0

  3、屏幕正對人

android x:0 y:10 z:0
IOS x:0 y:-10 z:0

  所以,android和IOS下重力加速度的取值相反

【元素跟隨手機移動】

  下麵利用accelerationlncludingGravity屬性實現元素跟隨手機移動的效果

  測試代碼如下

<style>
#box{
  width: 100px;
  height: 100px;
  background: pink;
  margin: 30px auto 0;
  text-align: center;
}  
</style>
<div id="box"></div>
<script>
let oBox = document.getElementById('box');
let lastX=0,lastY=0,lastZ=0;
window.addEventListener('devicemotion',(e)=>{
  requestAnimationFrame(()=>{
    let {x,y,z} = e.accelerationIncludingGravity
    x = 6*x
    y = 6*y
    z = 6*z
    oBox.style.transform = `translate3d(${x+lastX}px,${y+lastY}px,${z+lastZ}px)`
    lastX = x
    lastY = y
    lastZ = z    
  })
})
</script>

  查看效果

【搖一搖】

  搖一搖的原理非常簡單,檢測到手機的重力加速忽然有比較大的變化幅度即可。搖一搖時,元素顏色發生變化

  測試代碼如下

<style>
#box{
  width: 100px;
  height: 100px;
  background: pink;
  margin: 30px auto 0;
  text-align: center;
  transition: 1s;
}  
</style>
<div id="box"></div>
<script>
let oBox = document.getElementById('box');
let colorArr = ['orange','lightblue','lightgreen','pink','lightyellow']
let lastX,lastY,lastZ
let index = 0
window.addEventListener('devicemotion',(e)=>{
  requestAnimationFrame(()=>{
    let {x,y,z} = e.accelerationIncludingGravity
    let nowRange = Math.abs(lastX -x) + Math.abs(lastY - y) + Math.abs(lastZ - z) 
    if(nowRange > 80){
      index = (index+1)%colorArr.length
      oBox.style.background = colorArr[index]
    }
    lastX = x 
    lastY = y
    lastZ = z 
  })
})
</script>

  查看效果

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 早在2007年發佈iPhone的時候 ,蘋果並沒有一同發佈本地化SDK,蘋果公司聲稱不需要本地SDK,鼓勵大家使用JavaScript,CSS和HTML開發Web應用。但接下來劇情並沒有按照蘋果設計的那樣發展,也許是蘋果的思想太超前,大多數開發者不並不吃這一套,他們希望自己開發的應用和iOS系統內置 ...
  • 1,標簽接收到的data屬性綁定的如果是一個對象,則可以在對象前加三個點時對象裡面的的鍵值對平鋪出來。如: 2,template是占位符,在編譯完成後就會消失,所以不能給template標簽綁定事件; 3,自定義屬性在自己起的屬性名前面添加 data- 即可; 4,微信小程式的緩存,如果用戶不主動清 ...
  • No1: Volley源碼分析: Volley.newRequestQueue-> RequestQueue.start()-> CacheDispatcher.start()->CacheDispatcher.run()-> NetworkDispatcher.start()->NetworkDi ...
  • Cordova/Ionic開發的Android APP,需要啟用WebView的調試模式,才可以在Chrome瀏覽器中輸入chrome://Inspect,然後使用大家熟悉的開發者工具進行調試。不啟用的話,就看不到App中的WebView頁面,也沒有Inspect鏈接。 如果Chrome Inspe ...
  • iOS~runtime理解 Runtime是想要做好iOS開發,或者說是真正的深刻的掌握OC這門語言所必需理解的東西。最近在學習Runtime,有自己的一些心得,整理如下,一為 查閱方便二為 或許能給他人一些啟發,三為 希望得到大家對這篇整理不足之處的一些指點。 什麼是Runtime 我們寫的代碼在 ...
  • 安卓智能電視或者安卓盒子的控制應用,可跨屏遠程輸入、遠程遙控(代替遙控器)盒子、盒子應用及文件管理、HTTP/RTMP/MMS網路視頻直播、ED2K/種子文件的視頻文件邊下邊播 ...
  • 1動畫效果如圖所示,簡單地說就是一個可以伸縮摺疊的Toolbar 2用到的控制項,一個一個說,CoordinatorLayout是最外層的佈局,AppBarLayout是綠色+紅色部分,CollapsingToolbarLayout是綠色部分,Toolbar是返回鍵那一行,至於下麵來回切換的頁面,就是 ...
  • 對象的概念 JavaScript 中,萬物皆對象!但對象也是有區別的。分為普通對象和函數對象,Object 、Function 是 JS 自帶的函數對象。下麵舉例說明 在上面的例子中 o1 o2 o3 為普通對象,f1 f2 f3 為函數對象。怎麼區分,其實很簡單,凡是通過 new Function ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...