關于JavaScript的動畫原理

運動也可以叫做動畫

1戏自、運動原理

通過連續(xù)不斷的改變物體的位置壁酬,而發(fā)生移動變化望浩。

使用setInterval實現(xiàn)辖所。

勻速運動:速度值一直保持不變。

多物體同時運動:將定時器綁設置為對象的一個屬性磨德。

注:物體每次運動都應該把之前的定時器清除掉缘回。


//box為絕對定位

var speedX = 2

?box.timer = setInterval(function(){

? ? ? box.style.left = box.offsetLeft + speedX +'px';


},80)



2、邊界處理

遇到邊界是應該停止掉還是反彈典挑,方向相反酥宴。

改變物體運動方向:將物體的速度值取反。


//邊界屬性 ?瀏覽器視口寬高

//返回當前視口的高度(即瀏覽器窗口的高度)

console.log(document.documentElement.clientHeight)


console.log(document.documentElement.clientWidth)



// 網(wǎng)頁總高度 ? ? body默認有margin您觉,記得重置

console.log(document.body.clientHeight)


console.log(document.body.clientWidth)




var speedX = 2

?box.timer = setInterval(function(){

? ? ? box.style.left = box.offsetLeft + speedX +'px';

? ? ?//左右邊界

?????if(box.offsetLeft <=0?|| box.offsetLeft >= cWidth - box.offsetWidth){

? ? ? ? ? speedX = -speedX;

? ?? }


},80



3幅虑、加速減速

加速:速度越來越快。

減速:速度越來越慢顾犹。


box.timer = setInterval(function() {

?????speedX = speedX + 2;

?????div.style.left = div.offsetLeft + speedX + 'px';


}, 50);


4倒庵、拋物線

水平方向有一速度,垂直方向有一速度炫刷,并做自由落體擎宝。


var speedY = 0;

var speedX = 10;

// x 方向? 勻速

// y 方向? 勻加速

box.timer = setInterval(function() {

?????speedY += 9.8

?????box.style.left = box.offsetLeft + speedX + 'px';

?????box.style.top = box.offsetTop + speedY + 'px'


}, 80)


5、透明度的變換

box逐漸消失


//使用css將box的opacity 設置為1?

var op = 1;

box.timer = setInterval(function() {

?????op = op - 0.01;

?????div.style.opacity = op

?????//或者

?????//div.style.opacity = getComputedStyle(div).opacity - 0.01;


}, 80);


6浑玛、緩沖運動

速度一開始很大绍申,然后慢慢變小,比較類似自然界中的緩沖運動


//一開始box 在 (0,0)位置极阅,我們將box運動到(300,0)位置

var target = 300; //目標位置

box.timer = setInterval(function() {


? ?//target - div.offsetLeft

是元素距離目標的路程胃碾,隨著越來越靠近目標,這個值就越來越小筋搏,如果把這個值當做速度仆百,速度一開始很大,然后慢慢變小奔脐,比較類似自然界中的緩沖運動俄周。如果把這個值直接當速度,一下子就到髓迎,所以除以8以后當做速度

?????var speed = (target - div.offsetLeft) / 8;

?????//所以要對速度向上取整得到速度1峦朗,當speed小于0.375的時候,div就不會移動了

?????speed = Math.ceil(speed);

? ? ?box.style.left = div.offsetLeft + speed + 'px';

?????if(box.offsetLeft == target) {

? ? ? ? ? //到達目標清除定時器

??????????clearInterval(box.timer);

?????}

}, 30);


考慮到運動的時候可能往前排龄,也可以能往后波势,增加判斷

//一開始box 在 (0,0)位置橄维,我們將box運動到(300,0)位置

var target = 300; //目標位置

div.timer = setInterval(function() {

?????var speed = (target - div.offsetLeft) / 8;

?????//當speed小于0.375的時候尺铣,div就不會移動了

?????//所以要對速度向上取整或者向下取整

?????if(speed > 0) {

??????????//speed大于0 說明是往前運動

??????????//當speed小于0.375的時候,div就不會移動了

??????????//所以要對速度向上取整或者向下取整

??????????speed = Math.ceil(speed);

?????} else {

??????????//speed大于0 說明是往后運動

??????????speed = Math.floor(speed);

?????}

?????div.style.left = div.offsetLeft + speed + 'px';

?????if(div.offsetLeft == target) {

??????????clearInterval(div.timer);

?????}

}, 30);

上面代碼封裝為函數(shù)


function animate(div,targetX) {

??? var target = targetX;

??? div.timer =? setInterval(function () {

??????? var speed = (target - div.offsetTop)/8;

??????? speed = (speed>0? Math.ceil(speed): Math.floor(speed));

??????? div.style.top = div.offsetTop + speed +'px';

??????? if(div.offsetTop == target){

??????????? clearInterval(div.timer);

??????? }

??? },30);

}


7挣郭、多屬性緩沖運動函數(shù)封裝

上面的封裝只能固定的在x方向做動畫

如果想讓一個div 從一個點運動到另一個點,怎么辦疗韵?

比如從(0兑障,0)到(100,200)

這個時候我們把第二個參數(shù)改為一個這樣的對象?{left:100;top:200} ?


function animate(div, obj) {

?????//{left:100;top:200}

?????//{left:100}

?????clearInterval(div.timer);

?????div.timer = setInterval(function() {

??????????var flag = true; //假設已經(jīng)到了目的地


??????????for(var key in obj) {

??????????????console.log(key) //left?? top

??????????????console.log(obj[key]) //300

??????????????var target = obj[key]; //目標值

??????????????// getComputedStyle['left']? 元素left 屬性 當前值

??????????????var speed = (target - parseInt(getComputedStyle(div)[key])) / 8;

??????????????speed = (speed > 0 ? Math.ceil(speed) : Math.floor(speed));

??????????????div.style[key] = parseInt(getComputedStyle(div)[key]) + speed + 'px';

??????????????if(parseInt(getComputedStyle(div)[key]) != target) {

???????????????????flag = false;

??????????????}


??????????}


??????????//必須等到所有的 屬性都到達目的地 才能結束定時器

??????????if(flag == true) {

??????????????clearInterval(div.timer);

??????????}


?????}, 30);

}


上面咱們就封裝了一個運動函數(shù)蕉汪,也可以叫運動框架流译,說白了,就是封裝一次以后者疤,我們再做一些動畫就非常方便福澡!前人栽樹后人乘涼,便是框架的好處驹马!


如果想讓框架支持透明度動畫怎么辦呢革砸?無非是增加更多的判斷

運動框架最終封裝見animateBak.j

編輯:千鋒HTML5

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市糯累,隨后出現(xiàn)的幾起案子算利,更是在濱河造成了極大的恐慌,老刑警劉巖泳姐,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件效拭,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機缎患,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進店門慕的,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人挤渔,你說我怎么就攤上這事肮街。” “怎么了蚂蕴?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵低散,是天一觀的道長。 經(jīng)常有香客問我骡楼,道長熔号,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任鸟整,我火速辦了婚禮引镊,結果婚禮上,老公的妹妹穿的比我還像新娘篮条。我一直安慰自己弟头,他們只是感情好,可當我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布涉茧。 她就那樣靜靜地躺著赴恨,像睡著了一般。 火紅的嫁衣襯著肌膚如雪伴栓。 梳的紋絲不亂的頭發(fā)上伦连,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天,我揣著相機與錄音钳垮,去河邊找鬼惑淳。 笑死,一個胖子當著我的面吹牛饺窿,可吹牛的內(nèi)容都是我干的歧焦。 我是一名探鬼主播,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼肚医,長吁一口氣:“原來是場噩夢啊……” “哼绢馍!你這毒婦竟也來了?” 一聲冷哼從身側響起肠套,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤痕貌,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后糠排,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體舵稠,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了哺徊。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片室琢。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖落追,靈堂內(nèi)的尸體忽然破棺而出盈滴,到底是詐尸還是另有隱情,我是刑警寧澤轿钠,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布巢钓,位于F島的核電站,受9級特大地震影響疗垛,放射性物質發(fā)生泄漏症汹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一贷腕、第九天 我趴在偏房一處隱蔽的房頂上張望背镇。 院中可真熱鬧,春花似錦泽裳、人聲如沸瞒斩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽胸囱。三九已至,卻和暖如春瀑梗,著一層夾襖步出監(jiān)牢的瞬間烹笔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工夺克, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留箕宙,地道東北人嚎朽。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓铺纽,卻偏偏與公主長得像,于是被迫代替她去往敵國和親哟忍。 傳聞我的和親對象是個殘疾皇子狡门,可洞房花燭夜當晚...
    茶點故事閱讀 44,611評論 2 353

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