時(shí)鐘的繪制---canvas

1.png
<!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <style>
            canvas{
                position: absolute;
                left:10;
                top:10;
            }
        </style>
    </head>
    <body>
        <canvas id="dialCanvas"></canvas>
        <canvas id="handCanvas"></canvas>

    </body>
    <script>
        var dialCanvas=document.getElementById('dialCanvas');
        var handCanvas=document.getElementById('handCanvas');


        //定義寬度,高度和半徑
        var w=800;
        var h=600;
        var r=200;

        //定義畫(huà)布的大小
        dialCanvas.width=w;
        dialCanvas.height=h;
        handCanvas.width=w;
        handCanvas.height=h;


        //獲取畫(huà)布的環(huán)境
        var dialCxt=dialCanvas.getContext("2d");
        var handCxt=handCanvas.getContext("2d");


        //畫(huà)表盤(pán)
        /*
            1.畫(huà)表盤(pán)其實(shí)就是畫(huà)圓。
            2.為了數(shù)據(jù)的靈動(dòng)性速蕊,數(shù)據(jù)成變量
        */
        dialCxt.beginPath();
        dialCxt.arc(w/2,h/2,r,0,Math.PI*2);
        dialCxt.lineWidth=10;
        dialCxt.strokeStyle="#000";
        dialCxt.stroke();

        //畫(huà)刻度
        //封裝畫(huà)刻度函數(shù)
        /*
            * 確定刻度上的兩個(gè)點(diǎn) x1,y1;x2,y2.確定內(nèi)部點(diǎn)的時(shí)候驾诈,需要定義一個(gè)內(nèi)圓
            *刻度是通過(guò)畫(huà)線來(lái)實(shí)現(xiàn)的帮孔。
            *                   
        */
        function dialScale(cxt,x,y,innerRadius,outerRadius,number=12,lineWidth=10,strokeStyle="#000"){
            var angle=0;
            var angleDiff= 360 / number;
            for(var i=0;i<number;i++){
                var x1=Math.cos(angle/180*Math.PI)*outerRadius+w/2;
                var y1=Math.sin(angle/180*Math.PI)*outerRadius+h/2;
                var x2=Math.cos(angle/180*Math.PI)*innerRadius+w/2;
                var y2=Math.sin(angle/180*Math.PI)*innerRadius+h/2;
                cxt.beginPath();
                cxt.moveTo(x1,y1);
                cxt.lineTo(x2,y2);
                cxt.lineWidth=lineWidth;
                cxt.strokeStyle=strokeStyle;
                cxt.stroke();
                angle=angle+angleDiff;  
            }   
        }
        //調(diào)用
        //畫(huà)小時(shí)刻度
        dialScale(dialCxt,w/2,h/2,r,r-20,12,10);
        //畫(huà)分鐘和秒的刻度
        dialScale(dialCxt,w/2,h/2,r,r-10,60,2);


        //畫(huà)指針
        //封住畫(huà)指針函數(shù)
        //需要特別注意利用環(huán)境保存祭务,不然畫(huà)不了中狂。
        function drawHand(cxt,x,y,angle,length,lineWidth,strokeStyle){
            cxt.save();
            cxt.beginPath();
            cxt.translate(x,y);
            cxt.rotate((angle-90)/180*Math.PI)
            cxt.moveTo(-20,0);
            cxt.lineTo(length,0);
            cxt.lineWidth=lineWidth;
            cxt.strokeStyle=strokeStyle;
            cxt.stroke();

            cxt.restore();
        }

        //畫(huà)秒針
        //drawHand(dialCxt,w/2,h/2,6,180,1,"red");
        //畫(huà)分針
        //drawHand(dialCxt,w/2,h/2,6,150,5,"#000");
        //畫(huà)時(shí)針
        //drawHand(dialCxt,w/2,h/2,30,140,5,"#000");



        //時(shí)針轉(zhuǎn)動(dòng)
        function run(){
            var date=new Date();

            //清空畫(huà)布
            handCxt.clearRect(0,0,w,h);
            var seconds=date.getSeconds();
            drawHand(handCxt,w/2,h/2,6*seconds,180,1,"red");

            var minutes=date.getMinutes()+seconds / 60;
            drawHand(handCxt,w/2,h/2,6*minutes,150,5,"#000");

            var hours=date.getHours() % 12+minutes / 60;
            drawHand(handCxt,w/2,h/2,30*hours,100,5,"#ccc");

            //console.log(hours);

            setTimeout(run,1000);
        }
        run();




    </script>
    </html>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末屁柏,一起剝皮案震驚了整個(gè)濱河市啦膜,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌淌喻,老刑警劉巖僧家,帶你破解...
    沈念sama閱讀 216,919評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異裸删,居然都是意外死亡八拱,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)肌稻,“玉大人清蚀,你說(shuō)我怎么就攤上這事〉罚” “怎么了枷邪?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,316評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)诺凡。 經(jīng)常有香客問(wèn)我东揣,道長(zhǎng),這世上最難降的妖魔是什么腹泌? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,294評(píng)論 1 292
  • 正文 為了忘掉前任嘶卧,我火速辦了婚禮,結(jié)果婚禮上凉袱,老公的妹妹穿的比我還像新娘脸候。我一直安慰自己,他們只是感情好绑蔫,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布运沦。 她就那樣靜靜地躺著,像睡著了一般配深。 火紅的嫁衣襯著肌膚如雪携添。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,245評(píng)論 1 299
  • 那天篓叶,我揣著相機(jī)與錄音烈掠,去河邊找鬼。 笑死缸托,一個(gè)胖子當(dāng)著我的面吹牛左敌,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播俐镐,決...
    沈念sama閱讀 40,120評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼矫限,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了佩抹?” 一聲冷哼從身側(cè)響起叼风,我...
    開(kāi)封第一講書(shū)人閱讀 38,964評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎棍苹,沒(méi)想到半個(gè)月后无宿,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,376評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡枢里,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評(píng)論 2 333
  • 正文 我和宋清朗相戀三年孽鸡,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蹂午。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,764評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡彬碱,死狀恐怖画侣,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情堡妒,我是刑警寧澤配乱,帶...
    沈念sama閱讀 35,460評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站皮迟,受9級(jí)特大地震影響搬泥,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜伏尼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評(píng)論 3 327
  • 文/蒙蒙 一忿檩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧爆阶,春花似錦燥透、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,697評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至故河,卻和暖如春吱韭,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背鱼的。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,846評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工理盆, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人凑阶。 一個(gè)月前我還...
    沈念sama閱讀 47,819評(píng)論 2 370
  • 正文 我出身青樓猿规,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親宙橱。 傳聞我的和親對(duì)象是個(gè)殘疾皇子姨俩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評(píng)論 2 354

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