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

JS html時鐘制作代碼分享

 更新時間:2017年03月03日 16:14:46   作者:笑逗逗  
這篇文章主要為大家分享了JS html時鐘的制作代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下

時鐘效果圖:


閑來無聊做了一個網(wǎng)頁的時鐘,效果模擬傳統(tǒng)時鐘的運行方式,

運用了html 的畫布實現(xiàn)指針,背景圖片引用了網(wǎng)絡(luò)圖片。

具體原理:

首先將時鐘分為四個不同區(qū)域,對每個區(qū)域計算cos,sin 來確實指針頂點位置。在通過畫布來繪畫出指針。
通過setInterval 每秒刷新指針位置實現(xiàn) 傳統(tǒng)機械表針的動態(tài)跳動。

本人是JS開發(fā)程序員,從業(yè)1年多。閑來無聊的簡單頁面,

歡迎大家提問,或者建議。共同進步

代碼部分,直接復制HTML 文件中即可查看效果:

<!DOCTYPE html>
<html>
<head>
  <meta charset=utf-8>
  <title>clock</title>
</head>
<body style="color:green; <!--background-image:url('http://image.lxway.com/upload/b/f0/bf0d97dcee487096548e6edbc89d4963_thumb.png');--> background-size:100%; background-repeat: no-repeat; background-attachment:fixed">
  <div style="width: 900px; height: 900px; margin-top: 50px; margin-left: 50px;">
    <div style="position: absolute; left:119px;top: 193px; width: 900px; height: 900px; background-image:url('http://image.lxway.com/upload/b/f0/bf0d97dcee487096548e6edbc89d4963_thumb.png'); background-repeat: no-repeat; z-index: -1;">
    </div>
    <canvas id="t" width="800" height="800"></canvas>
    <div style="position: absolute; left:118px;top: 464px; width: 100px; height: 200px; background-color: white; background-repeat: no-repeat; z-index: 10;">
    </div>
  </div>
  <script language="javascript">
        var s = setInterval(moveI, 1000);
        function moveI() {
          var c = document.getElementById("t");
          var pc = c.getContext("2d");
          c.height = c.height;
          //秒
          pc.lineWidth = 3;
          pc.strokeStyle = 'rgba(255,0,0,0.8)';
          var now = new Date();
          var sindex = getxy(150, now.getSeconds());
          pc.moveTo(400, 400);
          pc.lineTo(sindex.x, sindex.y);
          pc.stroke();
          pc.beginPath();
          //分
          pc.lineWidth = 7;
          pc.strokeStyle = 'rgba(50,50,50,0.8)';
          var mindex = getxy(120, now.getMinutes() + (now.getSeconds() / 60));
          pc.moveTo(400, 400);
          pc.lineTo(mindex.x, mindex.y);
          pc.stroke();
          pc.beginPath();
          //時
          pc.lineWidth = 10;
          pc.strokeStyle = 'rgba(0,0,0,0.8)';
          var hindex = getxy(80, ((now.getHours() > 12 ? now.getHours() - 12 : now.getHours()) + (now.getMinutes() / 60)) * 5);
          pc.moveTo(400, 400);
          pc.lineTo(hindex.x, hindex.y);
          pc.stroke();
        };

        function getxy(r, t) {
          //計算分區(qū) 0,1,2,3
          var a = parseInt(t / 15);
          //分區(qū)角度
          t = t - 15 * a;
          var y;
          var x;
          //基于分區(qū)的坐標計算
          switch (a) {
            case 0:
              y = r - (r * Math.cos(2 * Math.PI / 360 * 90 * (t / 15)));
              x = r + (r * Math.sin(2 * Math.PI / 360 * 90 * (t / 15)));
              break;
            case 1:
              y = r + (r * Math.sin(2 * Math.PI / 360 * 90 * (t / 15)));
              x = r + (r * Math.cos(2 * Math.PI / 360 * 90 * (t / 15)));
              break;
            case 2:
              y = r + (r * Math.cos(2 * Math.PI / 360 * 90 * (t / 15)));
              x = r - (r * Math.sin(2 * Math.PI / 360 * 90 * (t / 15)));
              break;
            case 3:
              y = r - (r * Math.sin(2 * Math.PI / 360 * 90 * (t / 15)));
              x = r - (r * Math.cos(2 * Math.PI / 360 * 90 * (t / 15)));
              break;
            default:
              break;
          }
          y = (400 - r) + y;
          x = (400 - r) + x;
          return {
            'x': x,
            'y': y
          };
        };
  </script>
</body>

</html>

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

相關(guān)文章

  • JavaScript 格式字符串的應(yīng)用

    JavaScript 格式字符串的應(yīng)用

    在使用JavaScript中的Date對象時,有一個常用的操作就是輸出。但Date對象自帶的toString()方法輸出的格式并不能滿足用戶多樣化的需求。我在想,是不是可以將C#中DateTime.ToString(string format)方法的形式引入到JavaScript中呢?
    2010-03-03
  • Mysql內(nèi)儲存JSON字符串根據(jù)條件進行查詢

    Mysql內(nèi)儲存JSON字符串根據(jù)條件進行查詢

    本文主要介紹了Mysql內(nèi)儲存JSON字符串根據(jù)條件進行查詢,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • JavaScript實現(xiàn)二叉樹層序遍歷

    JavaScript實現(xiàn)二叉樹層序遍歷

    這篇文章主要為大家簡單介紹一下JS中如何實現(xiàn)二叉樹層序遍歷,感興趣的小伙伴可以詳細參考閱讀
    2023-03-03
  • JavaScript制作windows經(jīng)典掃雷小游戲

    JavaScript制作windows經(jīng)典掃雷小游戲

    掃雷是一款相當大眾的小游戲,游戲目標是在最短的時間內(nèi)根據(jù)點擊格子出現(xiàn)的數(shù)字找出所有非雷格子,同時避免踩雷。今天我們來看看如何使用javascript來實現(xiàn)這款小游戲
    2015-03-03
  • 基于Web標準的UI組件 — 樹狀菜單(2)

    基于Web標準的UI組件 — 樹狀菜單(2)

    基于Web標準的UI組件 — 樹狀菜單(2)...
    2006-09-09
  • 詳解JavaScript中ora庫的使用教程

    詳解JavaScript中ora庫的使用教程

    使用 ora 這個 JavaScript 庫可以在命令行應(yīng)用程序中提供漂亮的加載狀態(tài)提示,本文詳細介紹如何使用該庫,希望對大家有一定的幫助
    2024-02-02
  • 詳解用函數(shù)式編程對JavaScript進行斷舍離

    詳解用函數(shù)式編程對JavaScript進行斷舍離

    本篇文章主要介紹了用函數(shù)式編程對JavaScript進行斷舍離,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • javascript實現(xiàn)日期按月份加減

    javascript實現(xiàn)日期按月份加減

    JavaScript實現(xiàn)日期加減計算功能代碼實例,因為在js中沒有類似C#中的AddDays方法,所以要想實現(xiàn)日期加減的話,就需要自己寫函數(shù)來實現(xiàn)。這里分享給大家,有需要的小伙伴可以參考下
    2015-05-05
  • JavaScript實現(xiàn)文件的拖拽上傳功能

    JavaScript實現(xiàn)文件的拖拽上傳功能

    文件上傳,可以說是我們在項目中最常用的功能之一,文件上傳一般有兩種形式:點擊上傳和拖拽上傳,而上傳的內(nèi)容,又大體包括:文件和文件夾,本文給大家介紹了JavaScript實現(xiàn)文件的拖拽上傳功能的方法,需要的朋友可以參考下
    2024-02-02
  • 微信開發(fā)之調(diào)起攝像頭、本地展示圖片、上傳下載圖片實例

    微信開發(fā)之調(diào)起攝像頭、本地展示圖片、上傳下載圖片實例

    這篇文章主要介紹了微信開發(fā)之調(diào)起攝像頭、本地展示圖片、上傳下載圖片實例,具有一定的參考價值有興趣的可以了解一下。
    2016-12-12

最新評論