欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js canvas實現(xiàn)QQ撥打電話特效

 更新時間:2017年05月10日 08:48:06   作者:lovefive5  
這篇文章主要為大家詳細介紹了js canvas實現(xiàn)QQ撥打電話特效,具有一定的參考價值,感興趣的小伙伴們可以參考一下

首先呢,先給特效。自己找手機錄的,有點不清楚,請見諒!

本來是打算做 騰訊的貝塞爾曲線下拉刷新圖。然后和朋友打了個QQ電話,稍微注意了一下未接通時候的動畫。然后就想著實現(xiàn)以下。

這里要注意的就是:

canvas的中心點經(jīng)過變化到canvas的正中后
canvas的 Y軸由上至下 是從(-,+);而數(shù)學坐標系的Y軸由上至下 是從(+,-)的。

首先看一下html代碼。就至少簡單的添加一個canvas,基本沒進行其他操作。

HTML代碼

<canvas id="canvas1" width="500" height="500"></canvas>

JS代碼

var paint, r;    //設置畫筆和半徑
var width, height; //獲得canvas的長度和寬度
var count = 0;   //設置正鉉曲線的便宜量
var colors = ["#66ccff", "#ff0000"];

/*程序入口*/
function main() {
  var canvas1 = document.getElementById("canvas1");
  paint = canvas1.getContext("2d");
  width = paint.canvas.width;
  height = paint.canvas.height;
  r = width / 2;
  start();
  setInterval(start, 200);
}

/*開始進行清除和繪制*/
function start() {
  paint.clearRect(0, 0, width, height);
  drawXY();
  drawSin();
  paint.restore();
}

/*繪制一個坐標系*/
function drawXY() {
  paint.save();
  paint.translate(r, r);
  paint.beginPath();
  paint.lineWidth = 1;
  paint.moveTo(0, -r);
  paint.lineTo(0, r);
  paint.stroke();

  paint.lineWidth = 1;
  paint.moveTo(-r, 0);
  paint.lineTo(r, 0);
  paint.stroke();
}

/*正弦曲線可表示為y=Asin(ωx+φ)+k,定義為函數(shù)y=Asin(ωx+φ)+k在直角坐標系上的圖象,*/

/*繪制sin正弦圖像*/
function drawSin() {
  paint.save();
  count++;//設置每一刻的偏移量
  var i, j, rad, y;
  for (j = 0; j < 2; j++) {
    for (i = -1000; i < 1000; i++) {
      paint.beginPath();
      paint.strokeStyle = colors[j];
      rad = i * Math.PI / 180;
      y = -20 * Math.sin(rad - (count + j));
      paint.arc(i, y, 0.3, 0, 2 * Math.PI, false);
      paint.stroke();
    }
  }

  paint.restore();
}

JS中需要注意的就是。在對圖像進行計時改變的時候,一定要的先進行清除。之后要對繪制過的圖像進行保存和恢復。不然程序會出現(xiàn)重疊或者無法顯示等bug。

這里定義的paint變量名是按照安卓繪圖的習慣來的。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 微信小程序picker組件兩列關聯(lián)使用方式

    微信小程序picker組件兩列關聯(lián)使用方式

    這篇文章主要介紹了微信小程序picker組件兩列關聯(lián)使用方式,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10
  • javascript中簡單的進制轉(zhuǎn)換代碼實例

    javascript中簡單的進制轉(zhuǎn)換代碼實例

    這篇文章介紹了javascript中簡單的進制轉(zhuǎn)換代碼實例,有需要的朋友可以參考一下
    2013-10-10
  • 微信小程序海報繪制示例講解

    微信小程序海報繪制示例講解

    這篇文章主要介紹了微信小程序海報繪制示例,海報分享功能在許多應用中應該是很常見的,因為它作為一種常用的應用推廣和拉新的方式,下面我們來通過案例學習如何繪制
    2024-05-05
  • 解析JavaScript中的不可見數(shù)據(jù)類型

    解析JavaScript中的不可見數(shù)據(jù)類型

    這篇文章主要是對JavaScript中的不可見數(shù)據(jù)類型進行了詳細的介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • js修改元素樣式的九種方式總結(jié)

    js修改元素樣式的九種方式總結(jié)

    用慣了vue和react之后可能會慢慢淡忘掉原生的一些操作dom的幾種方式,有的時候確實需要我們通過原生的方式進行操作,下面這篇文章主要給大家介紹了關于js修改元素樣式的九種方式,需要的朋友可以參考下
    2024-04-04
  • ES6的內(nèi)置對象擴展實現(xiàn)示例

    ES6的內(nèi)置對象擴展實現(xiàn)示例

    本文主要介紹了ES6的內(nèi)置對象擴展實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • Echarts之懸浮框中的數(shù)據(jù)排序問題

    Echarts之懸浮框中的數(shù)據(jù)排序問題

    Echarts非常強大,配置也非常的多,有很多細節(jié)需要深入研究。這篇文章主要介紹了Echarts之懸浮框中的數(shù)據(jù)排序問題,需要的朋友可以參考下
    2018-11-11
  • JavaScript實現(xiàn)定時隱藏與顯示圖片的方法

    JavaScript實現(xiàn)定時隱藏與顯示圖片的方法

    這篇文章主要介紹了JavaScript實現(xiàn)定時隱藏與顯示圖片的方法,可實現(xiàn)javascript定時關閉圖片的功能,涉及javascript針對頁面元素屬性定時操作的相關技巧,需要的朋友可以參考下
    2015-08-08
  • 往光標所在位置插入值的js代碼

    往光標所在位置插入值的js代碼

    往輸入域中插入字符串(光標所在位置),在本文將為大家介紹下使用js是如何實現(xiàn)的,感興趣的朋友可以參考下
    2013-09-09
  • 如何使用pace.js美化你的網(wǎng)站加載進度條詳解

    如何使用pace.js美化你的網(wǎng)站加載進度條詳解

    Pace.js是一個非常有意思的js插件,可以自動的監(jiān)聽頁面的加載數(shù)據(jù),并且能夠定制加載條,下面這篇文章主要給大家介紹了關于使用pace.js如何美化你的網(wǎng)站加載進度條的相關資料,需要的朋友可以參考下
    2022-02-02

最新評論