用CSS怎样实现菱形拼图的效果?
Admin 2021-10-18 群英技术资讯 974 次浏览
本文给大家分享怎样用CSS实现拼图的内容,本文实现的拼图效果是菱形拼图,需要实现的需求有div旋转拼图,但是图片不旋转,具体的实现效果及代码如下,感兴趣的朋友可以了解看看。
使用 vue 做的项目,业务需求有一个拼图效果,默认是深色的背景图,上面分五个区域,每次会亮一个区域,整张图都亮,拼图完成。先来看一下最终的效果图。
应用到的知识点:
外层大盒子用来放暗色背景图,里面的5块拼图,是5个div,每块拼图都使用背景定位的方式
展示背景图的固定区域,中间的拼图做了旋转。但是旋转后,又遇到了个问题:背景图片也跟着旋转了,像下面这样:
解决背景旋转的思路:可以在第5块拼图的外层套一个盒子,将外层盒子向右旋转45度,再将背景的元素向左旋转45度。操作完又发现了新的问题,下面图中的黑色边框是外层盒子(为了方便看,把其他的拼图块都设置为不可见)。如果给外层盒子设置 overflow:hidden
,那么中间拼图的上下左右四个角都会缺失。
我们需要把第五块拼图的宽高设置大一些,再设置它外层的盒子 overflow:hidden
。宽高设置大的话,对应的 background-size
也要改变。
最后,就可以实现刚开始的效果了,完整的 vue 代码如下:
<template> <section class="box"> <div class="bg" :style="{ backgroundImage: `url(${bgImg}) ` }"></div> <div v-if="item1Show" class="item item1" :style="{ backgroundImage: `url(${bgImg}) ` }"></div> <div v-if="item2Show" class="item item2" :style="{ backgroundImage: `url(${bgImg}) ` }"></div> <div v-if="item3Show" class="item item3" :style="{ backgroundImage: `url(${bgImg}) ` }"></div> <div v-if="item4Show" class="item item4" :style="{ backgroundImage: `url(${bgImg}) ` }"></div> <div v-if="item5Show" class="item item5wrap"> <div class="item5" :style="{ backgroundImage: `url(${bgImg}) ` }"></div> </div> </section> </template> <script> import bgImg from "@/assets/bg.jpeg"; export default { data() { return { bgImg, item1Show: false, item2Show: true, item3Show: true, item4Show: true, item5Show: true }; } }; </script> <style lang="less"> @borderColor: #333; .box { margin: 0px auto; width: 300px; height: 200px; background-color: #000; position: relative; .bg { width: 100%; height: 100%; position: absolute; left: 0; top: 0; background-position: center center; background-repeat: no-repeat; background-size: 100% 100%; opacity: 0.5; } .item { width: 50%; height: 50%; box-sizing: border-box; background-size: 200% 200%; border-right: 1px solid @borderColor; border-bottom: 1px solid @borderColor; position: absolute; } .item1 { background-position: 0 0; left: 0; top: 0; } .item2 { background-position: 100% 0; left: 50%; top: 0; } .item3 { background-position: 0 100%; left: 0; top: 50%; } .item4 { background-position: 100% 100%; left: 50%; top: 50%; } .item5wrap { width: 100px; height: 100px; border-left: 1px solid @borderColor; border-top: 1px solid @borderColor; transform: rotate(45deg); left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(45deg); overflow: hidden; .item5 { width: 150px; height: 150px; background-position: 50% 50%; background-size: 200% 133%; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(-45deg); } } } </style>
关于用CSS实现菱形拼图的内容就介绍到这,上述实例具有一定的借鉴价值,需要的朋友可以参考,希望能对大家有帮助,想要了解更多CSS实现拼图的内容,大家可以关注其它的相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
怎样用CSS3写一个倒计时效果?现在很多网站都会使用倒计时效果,尤其是电子商务网站,常能看到秒杀倒计时,抢购倒计时等等,那么倒计时效果要怎么实现呢?这篇文章就给大家分享如何实现一个简单倒计时效果的实例,感兴趣的朋友可以看一下。
这篇文章主要介绍了完美解决谷歌浏览器自动填充问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
目录一、背景二、什么是css原子化,又有什么用?1.含义分析2.方案选择三、开发体验可行性优点1.开发的效率和舒适2.灵活和可维护缺点1.仍存在的上手门槛2. 小程序使用windicss受
本文将探讨一下,在多行文本情形下的一些有意思的文字动效。多行文本,相对于单行文本,场景会复杂一些,但是在实际业务中,多行文本也是非常之多的,但是其效果处理比起单行文本会更困难。
这篇文章主要介绍了详解如何获取localStorage最大存储大小的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008