Java编程Web基础案例:动态时钟 不一样的Java酷炫风 附源码!

Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。

给你Java学习路线:html-css-js-jq-javase-数据库-jsp-servlet-Struts2-hibernate-mybatis-spring4-springmvc-ssh-ssm

一个好的Java工程师应该是全栈的,所以最近小编我补习了一下Web知识,近期做了几个小玩意给大家分享一下,在此也告诉大家,学Java千万不能忽视前端哦。

打造效果如下:

小编推荐一个学Java的学习裙【 六五零,五五四,六零七 】,无论你是大牛还是小白,是想转行还是想入行都可以来了解一起进步一起学习!裙内有开发工具,很多干货和技术资料分享!

动态时钟

接下来就是源码了..大家看了后会不会觉得简单。

HTML部分:

  • CSS部分:

    @import url(https://fonts.googleapis.com/css?family=Open+Sans:300);

    body{

    background:hsl(50,20%,93%);

    margin:0;

    }

    canvas{

    display:block;

    width:100%;

    height:100%;

    position: absolute;

    top: 50%;

    left: 50%;

    transform: translate(-50%, -50%);

    }

    #clock-container{

    position:absolute;

    left:50%;

    top:50%;

    transform:translate(-50%,-50%);

    font-family: "Open Sans", sans-serif;

    font-size: 8vw;

    color:hsl(0,0%,25%);

    list-style-type: none;

    padding: 0;

    margin: 0;

    display: flex;

    justify-content: center;

    align-items: center;

    li {

    &:nth-of-type(-n+2) {

    &:after {

    content:':';

    color: #666;

    }

    }

    }

    }

    JS部分:

    var c = document.body.appendChild(document.createElement("canvas")),

    w = innerWidth,

    h = innerHeight;

    c.width = w;

    c.height = h;

    var ctx = c.getContext("2d"),

    //degrees to radians conversion function

    deg2rad = d => (Math.PI / 180) * d;

    //constructor for the circles

    function radialBar(x, y, r, max, value) {

    var self = this;

    self.X = x || 0;

    self.Y = y || 0;

    self.R = r || 0;

    self.MAX = max || 1;

    self.value = value || 0;

    self.target = value || 0;

    self.update = function(v) {

    //lerp

    self.target = v > 0 ? v : 0.1;

    self.value += (self.target - self.value) * 0.05;

    ctx.arc(

    this.X,

    this.Y,

    this.R,

    //move starting point to top

    deg2rad(-90),

    deg2rad(-90) + (deg2rad(360) * (self.value / self.MAX))

    );

    }

    }

    小编推荐一个学Java的学习裙【 六五零,五五四,六零七 】,无论你是大牛还是小白,是想转行还是想入行都可以来了解一起进步一起学习!裙内有开发工具,很多干货和技术资料分享!

    ctx.lineWidth = 3;

    ctx.lineCap = "round";

    var spacing = 12,

    radius = 150,

    //contains values for hours, minutes, seconds

    times,

    //create circles

    circles = {

    H: new radialBar(w / 2, h / 2, radius, 12, 0),

    M: new radialBar(w / 2, h / 2, radius - spacing, 60, 0),

    S: new radialBar(w / 2, h / 2, radius - spacing - spacing, 60, 0)

    },

    //text elements

    elements = {

    H: document.getElementById("H"),

    M: document.getElementById("M"),

    S: document.getElementById("S")

    };

    //set text colors

    Object.keys(elements).forEach((k, i) =>

    elements[k].style.color =

    "hsl(" + k.charCodeAt(0) * i + ", 50%, 50%)");

    //update time values and text once per second

    function updateTime {

    var time = new Date;

    var hours = time.getHours;

    if (hours > 12) {

    hours -= 12;

    } else if (hours === 0) {

    hours = 12;

    }

    times = {

    H: hours,

    M: time.getMinutes,

    S: time.getSeconds

    };

    //update text

    Object.keys(times).forEach(k =>

    elements[k].innerHTML =

    //pad with 0s if needed

    String(times[k]).length > 1 ?

    times[k] :

    times[k] = "0" + times[k]

    );

    setTimeout(updateTime, 1000);

    }

    function draw {

    ctx.clearRect(0, 0, w, h);

    //update circles, set their color, draw

    Object.keys(circles).forEach((k, i) => {

    ctx.beginPath;

    // ctx.setLineDash([.5, 15]);

    circles[k].update(times[k]);

    ctx.strokeStyle = "hsl(" + k.charCodeAt(0) * i + ", 50%, 50%)";

    ctx.stroke;

    ctx.lineWidth=10;

    });

    requestAnimationFrame(draw);

    }

    //start

    updateTime;

    draw;

    好啦,代码就分享到这里,大家觉得是不是挺简单的,一个好的项目是需要几个小玩意的,近期会继续分享类似小案例,大家可以关注我的动态哦!

  • 最后编辑于
    ©著作权归作者所有,转载或内容合作请联系作者
    • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
      沈念sama阅读 218,036评论 6 506
    • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
      沈念sama阅读 93,046评论 3 395
    • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
      开封第一讲书人阅读 164,411评论 0 354
    • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
      开封第一讲书人阅读 58,622评论 1 293
    • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
      茶点故事阅读 67,661评论 6 392
    • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
      开封第一讲书人阅读 51,521评论 1 304
    • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
      沈念sama阅读 40,288评论 3 418
    • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
      开封第一讲书人阅读 39,200评论 0 276
    • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
      沈念sama阅读 45,644评论 1 314
    • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
      茶点故事阅读 37,837评论 3 336
    • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
      茶点故事阅读 39,953评论 1 348
    • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
      沈念sama阅读 35,673评论 5 346
    • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
      茶点故事阅读 41,281评论 3 329
    • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
      开封第一讲书人阅读 31,889评论 0 22
    • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
      开封第一讲书人阅读 33,011评论 1 269
    • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
      沈念sama阅读 48,119评论 3 370
    • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
      茶点故事阅读 44,901评论 2 355

    推荐阅读更多精彩内容