html 背景图片自动旋转,CSS3 菱形拼图实现只旋转div 背景图片不旋转功能

需求背景

使用 vue 做的项目,业务需求有一个拼图效果,默认是深色的背景图,上面分五个区域,每次会亮一个区域,整张图都亮,拼图完成。先来看一下最终的效果图。

9451c199439771eb37c5268550b4c441.png

应用到的知识点:

background-size

background-position

transform:rotate

实现思路:

外层大盒子用来放暗色背景图,里面的5块拼图,是5个div,每块拼图都使用背景定位的方式展示背景图的固定区域,中间的拼图做了旋转。但是旋转后,又遇到了个问题:背景图片也跟着旋转了,像下面这样:

c73984a2df8a7ad0527918084c2e6b04.png

解决背景旋转的思路:可以在第5块拼图的外层套一个盒子,将外层盒子向右旋转45度,再将背景的元素向左旋转45度。操作完又发现了新的问题,下面图中的黑色边框是外层盒子(为了方便看,把其他的拼图块都设置为不可见)。如果给外层盒子设置 overflow:hidden ,那么中间拼图的上下左右四个角都会缺失。

我们需要把第五块拼图的宽高设置大一些,再设置它外层的盒子 overflow:hidden。宽高设置大的话,对应的 background-size 也要改变。

d1093fa18f065ada31ca0f42c9fa3e59.png

最后,就可以实现刚开始的效果了,完整的 vue 代码如下:

import bgImg from "@/assets/bg.jpeg";

export default {

data() {

return {

bgImg,

item1Show: false,

item2Show: true,

item3Show: true,

item4Show: true,

item5Show: true

};

}

};

@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);

}

}

}

到此这篇关于CSS3 菱形拼图实现只旋转div 背景图片不旋转功能的文章就介绍到这了,更多相关CSS3旋转图片内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值