重力感應(yīng)控制方向

設(shè)計(jì)目的

重力感應(yīng)控制方向的設(shè)計(jì)目的是:
利用手機(jī)的重力感應(yīng)器來(lái)控制頁(yè)面上元素的移動(dòng)方向,進(jìn)而實(shí)現(xiàn)頁(yè)面上的某種動(dòng)畫(huà)效果。

原理闡釋

HTML5 DeviceOrientation 接口應(yīng)用一文中介紹了DeviceOrientation的一個(gè)用例,就是判斷手機(jī)的左右搖擺方向杠园。

var gamma_html = "";
if( gamma > 0 ){
    gamma_html = "向右傾斜";
}else{
    gamma_html = "向左傾斜";
}

這個(gè)是假設(shè)我們用手拿手機(jī)時(shí)的狀態(tài)為:面對(duì)手機(jī)屏幕,手機(jī)頭部朝斜上方。此時(shí)野蝇,beta值在0-90之間。對(duì)于大多數(shù)人來(lái)說(shuō)括儒,要讓他向左旋轉(zhuǎn)手機(jī)绕沈,他可能會(huì)做兩種不同的動(dòng)作:把手機(jī)繞y軸向左翻轉(zhuǎn);或者把手機(jī)繞z軸逆時(shí)針旋轉(zhuǎn)(面對(duì)z軸正向)同時(shí)向左整體移動(dòng)手機(jī)帮寻。

第一種動(dòng)作中乍狐,手機(jī)只繞y軸發(fā)生了旋轉(zhuǎn),也就是說(shuō)只有g(shù)amma值發(fā)生了變化固逗。我們只要判斷gamma值的正負(fù)即可判斷手機(jī)的旋轉(zhuǎn)方向浅蚪。

第二種動(dòng)作比較復(fù)雜,手機(jī)在繞z軸旋轉(zhuǎn)的同時(shí)烫罩,其他兩個(gè)軸的角度也發(fā)生了變化惜傲。實(shí)際上,這個(gè)動(dòng)作發(fā)生的過(guò)程中贝攒,手機(jī)的歐拉角發(fā)生了變化盗誊。

雖然通過(guò)alpha,beta和gamma值計(jì)算出歐拉角,然后確定手機(jī)在三維空間中旋轉(zhuǎn)方向會(huì)比較精確,但對(duì)于只需要簡(jiǎn)單判斷方向的Web應(yīng)用場(chǎng)景來(lái)說(shuō)有點(diǎn)小題大作了哈踱。

通過(guò)觀察發(fā)現(xiàn)荒适,在發(fā)生第二種動(dòng)作時(shí),beta值的變化并沒(méi)有那么大开镣,不超過(guò)10吻贿。alpha的變化范圍在-50到50之間,但它跟手機(jī)頭部與地磁N極相關(guān)哑子,與局部空間內(nèi)手機(jī)的選擇關(guān)系不大舅列。而gamma值的變化非常明顯,在-30到30之間卧蜓。因此我們?nèi)匀豢梢酝ㄟ^(guò)gamma值的變化來(lái)確定手機(jī)的搖動(dòng)方向帐要。

代碼實(shí)現(xiàn)和類(lèi)型設(shè)計(jì)

通過(guò)原理分析和實(shí)踐觀察,我們得出可以利用gamma值的變化粗略判斷手機(jī)旋轉(zhuǎn)的方向弥奸。其核心代碼依然不變榨惠,即根據(jù)gamma值的正負(fù)來(lái)判斷朝左還是朝右,根據(jù)其大小來(lái)判斷旋轉(zhuǎn)的程度(或角度)盛霎。

把核心的代碼放進(jìn)程序中就能實(shí)現(xiàn)判斷手機(jī)旋轉(zhuǎn)赠橙,當(dāng)然也可以封裝出一個(gè)組件,在任何地方重復(fù)調(diào)用愤炸。

GravityController類(lèi)設(shè)計(jì)

功能描述

GravityContoller設(shè)計(jì)為系統(tǒng)級(jí)對(duì)象期揪,其自身通過(guò)window對(duì)象來(lái)監(jiān)聽(tīng)手機(jī)的旋轉(zhuǎn)朝向,并獲得各個(gè)軸方向的角度规个。通過(guò)給它綁定onScrollLeftonScrollRight方法來(lái)執(zhí)行相應(yīng)代碼凤薛。

對(duì)象設(shè)計(jì)
access type name description
private float alpha alpha角度
private float beta beta角度
private float gamma gamma角度
public function onScrollLeft 向左旋轉(zhuǎn)時(shí)執(zhí)行的函數(shù)
public function onScrollRight 向右旋轉(zhuǎn)時(shí)執(zhí)行的函數(shù)

alpha,beta,gammaGravityController類(lèi)私有屬性,值來(lái)自于windowdeviceorientationevent對(duì)象诞仓。當(dāng)deviceorientation事件發(fā)生時(shí)缤苫,根據(jù)gamma值的變化調(diào)用onScrollLeftonScrollRight函數(shù),并傳入gamma墅拭。

接口使用示例

首先編寫(xiě)onScrollLeftonScrollRight函數(shù):

var scrollLeftHandler = function(angle){
    console.log( "Cellphone Turn Left:" + Math.abs(angle).toFixed(2) );
};
var scrollRightHandler = function(angle){
    console.log( "Cellphone Turn Right:" + Math.abs(angle).toFixed(2) );
};

然后聲明GravityController對(duì)象活玲,并傳入onScrollLeftonScrollRight函數(shù):

var gc = new GravityController({
    onScrollLeft : scrollLeftHandler,
    onScrollRight : scrollRightHandler
});
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市谍婉,隨后出現(xiàn)的幾起案子舒憾,更是在濱河造成了極大的恐慌,老刑警劉巖屡萤,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件珍剑,死亡現(xiàn)場(chǎng)離奇詭異掸宛,居然都是意外死亡死陆,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)措译,“玉大人别凤,你說(shuō)我怎么就攤上這事×旌纾” “怎么了规哪?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)塌衰。 經(jīng)常有香客問(wèn)我诉稍,道長(zhǎng),這世上最難降的妖魔是什么最疆? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任杯巨,我火速辦了婚禮,結(jié)果婚禮上努酸,老公的妹妹穿的比我還像新娘服爷。我一直安慰自己,他們只是感情好获诈,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布仍源。 她就那樣靜靜地躺著,像睡著了一般舔涎。 火紅的嫁衣襯著肌膚如雪笼踩。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,521評(píng)論 1 304
  • 那天亡嫌,我揣著相機(jī)與錄音戳表,去河邊找鬼。 笑死昼伴,一個(gè)胖子當(dāng)著我的面吹牛匾旭,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播圃郊,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼价涝,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了持舆?” 一聲冷哼從身側(cè)響起色瘩,我...
    開(kāi)封第一講書(shū)人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎逸寓,沒(méi)想到半個(gè)月后居兆,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡竹伸,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年泥栖,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了簇宽。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡吧享,死狀恐怖魏割,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情钢颂,我是刑警寧澤钞它,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站殊鞭,受9級(jí)特大地震影響遭垛,放射性物質(zhì)發(fā)生泄漏垦江。R本人自食惡果不足惜段誊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望疯淫。 院中可真熱鬧牲尺,春花似錦卵酪、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至蜒简,卻和暖如春瘸羡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背搓茬。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工犹赖, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人卷仑。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓峻村,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親锡凝。 傳聞我的和親對(duì)象是個(gè)殘疾皇子粘昨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容