服务粉丝

我们一直在努力
当前位置:首页 > 财经 >

社区精选|世界杯火热进行中, 用一个div画个足球场助助兴

日期: 来源:SegmentFault思否收集编辑:南城

今天小编为大家带来的是社区作者 南城FE 的文章,让我们一起来学习用一个div画个足球场。




四年一度的世界杯正在火热进行中,有没有熬夜看你喜欢的队伍比赛呢。在这欢庆的氛围中,我决定用代码参与一把世界杯,擦边参与,那就是用CSS画一个足球场,正常的用CSS布局肯定是非常easy的,所以决定只用一个div完成,接下来开始正文。


足球场的尺寸


画之前首先要获取几个关键位置的尺寸,查询度娘的结果如下:


  • 场地:长105米,宽68米;
  • 球门:长7.32米,高2.44米;
  • 大禁区(罚球区):长40.32米,宽16.5米;
  • 小禁区(球门区):长18.32米,宽5.5米
  • 中圈区:半径9.15米;
  • 角球去:半径1米;
  • 罚球弧:半径9.15的半圆


基于这份数据定义一些基本的变量,本次实现基于上面的值乘以2作为像素值,部分小区域数值有所调整。整体变量定义如下:


:root {
  --lineColor: #fff;
  --fieldWidth: 210px;
  --fieldHeight: 136px;
  --centerCircle: 18px;
  --cornerCircle: 4px;
  --grandForbiddenAreaWidth: 32px;
  --grandForbiddenAreaHeight: 80px;
  --smallRestrictedAreaWidth: 11px;
  --smallRestrictedAreaHeight: 36px;
  --goalWidth: 4px;
  --goalHeight: 14px;
}


CSS倒影


这里用到了CSS倒影 box-reflect,因为只能用一个div,所以要尽可能利用现有的CSS能力,减少额外的代码量。足球场本质是一个对称图形,在这里使用CSS倒影就很合适,如果不考虑只用一个div,还可以多次使用倒影。本次CSS逻辑只实现内容左侧部分,右侧内容由 box-reflect 倒影实现。


-webkit-box-reflect: right;


实现过程


首先增加边框部分,本文所有的线条都是按2px实现。


div {
  width: calc(var(--fieldWidth) / 2);
  height: var(--fieldHeight);
  border: 2px solid var(--lineColor);
}




接下来开始画中心部分的圆圈,因为只使用一个div,所以将大量使用CSS渐变实现各种线条部分内容,这里需要注意的地方是有倒影的使用代码上只需要画出半圆,所以要增加 no-repeat 避免在左侧绘制出另一半圆。


radial-gradient(
  circle,
  #0000 var(--centerCircle) 0,
  var(--lineColor) calc(var(--centerCircle)),
  var(--lineColor) calc(var(--centerCircle) + 2px),
  #0000 calc(var(--centerCircle) + 2px)
) no-repeat calc(var(--fieldWidth) / 4) 50% / 100% 100%


然后绘制四个角落的角球区域圆圈,上下两个角球部分需要分开绘制,核心代码都是一样,只是 background-position 的位置不一样。


// 上面角球 1/4 圆
radial-gradient(
  circle, 
  #0000 var(--cornerCircle),
  var(--lineColor) calc(var(--cornerCircle)),
  var(--lineColor) calc(var(--cornerCircle) + 2px),
  #0000 calc(var(--cornerCircle) + 2px)
) no-repeat calc(var(--fieldWidth) / 4 * -1) calc(var(--fieldHeight) / 2 * -1) / 100%





然后绘制大禁区部分,这部分本质是一个矩形,但是左边线条和底部的线条是重合的,所以还需要绘制剩余的三根线条,这里为了减少一部分代码,其中两条线使用 conic-gradient 绘制,剩余的一条线使用 linear-gradient 绘制。


小禁区和大禁区实现方式是一样的,只是在于区域的大小尺寸不一样,增加两个禁区后的效果如下:

conic-gradient(
  from -90deg at right 2px bottom 2px,
   rgba(31, 157, 161, 0) 0 90deg,#fff 0) 0 calc((var(--fieldHeight) - var(--grandForbiddenAreaHeight)) / 2)/var(--grandForbiddenAreaWidth) var(--grandForbiddenAreaHeight) no-repeat,
linear-gradient(
  0deg,
  var(--lineColor) 2px,
  #0000 2px
) 0px calc((var(--fieldHeight) - var(--grandForbiddenAreaHeight)) / 2)/var(--grandForbiddenAreaWidth) 2px no-repeat




接下来绘制罚球弧,这个是一条圆弧,貌似渐变不能单纯的只绘制一条弧线,如果有知道的欢迎交流,这里使用伪元素实现,基于伪元素的边框加圆角并隐藏其中的三边边框即可达到期望的效果。


&::after {
  ...
  border: 2px solid #fff;
  border-radius: 50%;
  background: #0000;
  border-top-color: #0000;
  border-left-color: #0000;
  border-bottom-color: #0000;
}



此时的基本效果图已经差不多了,再使用另外一个伪元素绘制一下球门的位置。



最后再增加一下球场内的草坪效果。这里使用了重复线性渐变,代码如下:


repeating-linear-gradient(
  90deg,
  #56a224 0px,
  #56a224 10px, 
  #a9da27 10px, 
  #a9da27 20px
)

最后完整的效果图如下:


在线代码:https://code.juejin.cn/pen/7171244744473853991


最后


完整的实现过程就结束了,这只是一种实现的思路,在实际的项目中不建议使用,除此之外也还有很多其他的实现方式,欢迎讨论你的实现方式。看完觉得有用记得点个赞再走,收藏起来说不定哪天就用上啦~




点击左下角阅读原文,到 SegmentFault 思否社区 和文章作者展开更多互动和交流,“公众号后台“回复“ 入群 ”即可加入我们的技术交流群,收获更多的技术文章~

- END -


相关阅读

  • 智能家居大百科|智能家居的专业术语

  • 点击上方“蓝字”,关注更多精彩在信息泛滥的时代,想要获得各类信息,几乎都能0成本搜索获取,但在这个搜索的过程中所耗费的时间与精力是非常多的。为此,零狐特地以“智能家居大百
  • 智能家居大百科二|智能家居起源与运用

  • 点击上方“蓝字”,关注更多精彩据申万宏源测算,2022年全屋智能市场规模将达到215亿元,2025年则有望突破500亿元,对智能家居行业贡献将超过15%。智能家居市场正在飞速发展,它是如
  • 用人经理使用的报告,不培训即可懂

  • 北森的测评新品「关键岗位计算机自适应测评」自发布后,受到了市场的广泛关注。除了其本身具备的先进技术,切实解决了企业一直以来关注的痛点,具体可见[人才测评届的国货之光 |
  • 中铁十八局集团2023届校园招聘正式启动

  • 制图、编辑:王睿、王晓珏来源:集团公司党委干部部(人力资源部)审核:李慧楠、王飞辉、曾凡泓、吴东主办:中铁十八局集团党委工作部(党委宣传部、团委、企业文化部)近期热文,欢迎回顾!

热门文章

  • “复活”半年后 京东拍拍二手杀入公益事业

  • 京东拍拍二手“复活”半年后,杀入公益事业,试图让企业捐的赠品、家庭闲置品变成实实在在的“爱心”。 把“闲置品”变爱心 6月12日,“益心一益·守护梦想每一步”2018年四

最新文章

  • 媒体专访 NVIDIA :携手百度共建智能搜索

  • 21 世纪初诞生的搜索引擎迄今已有近二十年的发展历程。伴随着互联网技术的发展,今天的搜索引擎已经能够直接响应用户的自然语言指令,搜索体验全面提升,使用场景也深入到了互联
  • SegmentFault 思否写作挑战赛!

  • SegmentFault 思否写作挑战赛 是思否社区新上线的系列社区活动,在 2 月 8 日 正式面向社区所有用户开启;挑战赛中包含多个可供作者选择的热门技术方向,根据挑战难度分为多个等
  • 社区精选|微服务的版本号要怎么设计?

  • 今天小编为大家带来的是社区作者 江南一点雨 的文章,让我们一起来学习设计微服务的版本号。今天我们来聊一下微服务项目中的版本号要怎么设计。小伙伴们平时看到的项目版本号