每周一个前端动画之二:支持率展示动画

就在这样不算浓郁的过年气息中,更新第二篇每周一个前端动画系列。

今天地铁上人明显少了很多,大家相视而笑,互相点头示意但是眼神坚定。因为他们知道,只有共和国最优秀的人才,各部门最重要的岗位才会在这个时候出现在这个车厢里.拖着行李箱的人羞愧的低下了头,但是没有人责怪他们,毕竟每个人的能力都是有限的,与其让他们继续工作,不如放他们回家过年。

本文分析实现的某些效果,仅仅作为一个思路分享,仅仅作为学习素材使用。

源动画效果

结合上一篇的球队logo的展示,在其下方放置了一个bar,用来展示球队的支持率。这条支持率显示bar可以点击,为球队增加支持率。这个效果展示如下:


image

实现分析

经过观察可发现:

  • 动画左右对称,实现一边即可
  • 点击时支持率的变化是宽度的变化,两方占有的宽度是按照比例(支持人数/总人数)设置的,点击时该队的支持人数和总人数同时改变
  • 红蓝相连接的地方是一个斜角,这里的实现可以用到border-width的一个技巧
  • 点击是“+1”效果是一个放大动画

分析完这些怎么样,是不是已经有思路了,来让我们看代码。

代码实现

宽度改变效果

注意点击时候需要将支持数和总数同时加1,然后根据此数量修改支持率的宽度。

one.width(oneValue / allVote * 100 + "%");
other.width(100 - oneValue / allVote * 100 + "%");

倾斜角的实现

倾斜角一般我们都是通过-webkit-transform:rotate(xxdeg)实现,但是该方式在设置两个不同颜色时候显得不是那么的方便。上面说到我们可以利用border-width技巧实现这个倾斜角。当我们设置一个元素的width,height都为0的时候,我们设置的border-width将进行占位,该属性设置的值将会平分该块,假如将左右块重复,效果可以展示为如下:

image

这时只要设置其他部分边框的颜色为透明,就可以实现这个倾斜角的效果。

设置代码如下

.team-vs-bar .bar-a:after, .team-vs-bar .bar-b:after {
    position: absolute;
    display: block;
    height: 0;
    width: 0;
    border-style: solid;
    border-width: 20px;
    border-color: transparent;
    -webkit-transform: rotate(-15deg)
}

.team-vs-bar .bar-a:after {
    border-top-color: #c93c5d;
    right: -20px;
    top: 0;
    z-index: 1
}

.team-vs-bar .bar-b:after {
    border-bottom-color: #306dca;
    left: -20px;
    bottom: 0
}

“+1”动效的实现

继续使用关键帧,可以进行如下的设置,注意每次点击时候需要将未完成的动画清除掉,只显示最后一次。

@-webkit-keyframes bar_plus {
    0% {
        opacity: 0;
        -webkit-transform: scale(0)
    }
    50% {
        opacity: 1
    }
    60% {
        opacity: 1
    }
    100% {
        opacity: 0;
        -webkit-transform: scale(1.4)
    }
}

效果展示

image

关键点解读

本文的关键点的实现除了“+1”动效,就是倾斜角的实现。“+1”动效依然可以使用关键帧实现,而倾斜角使用after伪类以及border-width的方法进行实现的方式希望可以给大家带来新鲜的感觉。代码已上传到github,欢迎提出Issues。

最后的惯例,贴上我的博客,欢迎关注

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

推荐阅读更多精彩内容

  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,747评论 0 2
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,314评论 0 11
  • 各种纯css图标 CSS3可以实现很多漂亮的图形,我收集了32种图形,在下面列出。直接用CSS3画出这些图形,要比...
    剑残阅读 9,537评论 0 8
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,748评论 1 92
  • 一换地方一换季节身体就莫名会过敏?有的人即使过了青春期仍然满脸痘痘甚至痘坑还很深? 同样生活的环境,却有的人面临总...
    郁茹阅读 335评论 0 0