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


Posted in HTML / CSS onMarch 30, 2021

需求背景

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

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

应用到的知识点:

  • background-size
  • background-position
  • transform:rotate

实现思路:

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

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

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

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

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

最后,就可以实现刚开始的效果了,完整的 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>

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

 
HTML / CSS 相关文章推荐
魔幻般冒泡背景的CSS3按钮动画
Feb 27 HTML / CSS
CSS3模拟IOS滑动开关效果
Sep 28 HTML / CSS
详解background属性的8个属性值(面试题)
Nov 02 HTML / CSS
css3 实现滚动条美化效果的实例代码
Jan 06 HTML / CSS
浅谈pc和移动端的响应式的使用
Jan 03 HTML / CSS
HTML5 对各个标签的定义与规定:body的介绍
Jun 21 HTML / CSS
HTML5单页面手势滑屏切换原理
Mar 21 HTML / CSS
基于MUI框架使用HTML5实现的二维码扫描功能
Mar 01 HTML / CSS
HTML5 video循环播放多个视频的方法步骤
Aug 06 HTML / CSS
HTML5单选框、复选框、下拉菜单、文本域的实现代码
Dec 01 HTML / CSS
如何使用canvas绘制可移动网格的示例代码
Dec 14 HTML / CSS
从QQtabBar看css命名规范BEM的详细介绍
Aug 07 HTML / CSS
CSS3通过var()和calc()函数实现动画特效
CSS3实现模糊背景的三种效果示例
使用css样式设计一个简单的html登陆界面的实现
CSS实现漂亮的时钟动画效果的实例代码
CSS3点击按钮圆形进度打钩效果的实现代码
完美实现CSS垂直居中的11种方法
CSS代码检查工具stylelint的使用方法详解
You might like
漂亮但不安全的CTB
2006/10/09 PHP
dedecms中常见问题修改方法总结
2007/03/21 PHP
php准确获取文件MIME类型的方法
2015/06/17 PHP
php实现的递归提成方案实例
2015/11/14 PHP
PHP最常用的正则表达式
2017/02/13 PHP
[原创]IE view-source 无法查看看源码 JavaScript看网页源码
2009/07/19 Javascript
对javascript的一点点认识总结《javascript高级程序设计》读书笔记
2011/11/30 Javascript
javascript中动态加载js文件多种解决办法总结
2013/11/15 Javascript
javascript中不提供sleep功能如何实现这个功能
2014/05/27 Javascript
JavaScript数组常用方法
2015/03/02 Javascript
轻量级javascript 框架Backbone使用指南
2015/07/24 Javascript
jquery实现手机号码选号的方法
2015/07/31 Javascript
JS实现数字格式千分位相互转换方法
2016/08/01 Javascript
微信小程序BindTap快速连续点击目标页面跳转多次问题处理
2019/04/08 Javascript
inquirer.js一个用户与命令行交互的工具详解
2019/05/18 Javascript
js实现小时钟效果
2020/03/25 Javascript
Python的re模块正则表达式操作
2016/05/25 Python
python实现获取Ip归属地等信息
2016/08/27 Python
Python实现定时任务
2017/02/08 Python
Python中的单行、多行、中文注释方法
2018/07/19 Python
pytorch标签转onehot形式实例
2020/01/02 Python
python 的numpy库中的mean()函数用法介绍
2020/03/03 Python
Python的Tqdm模块实现进度条配置
2021/02/24 Python
html5中为audio标签增加停止按钮动作实现方法
2013/01/04 HTML / CSS
One.com挪威:北欧成长最快的网络托管公司
2016/11/19 全球购物
销售业务员岗位职责
2014/01/29 职场文书
建筑工地门卫岗位职责
2014/04/30 职场文书
2014年端午节演讲稿范文
2014/05/23 职场文书
平面设计师岗位职责
2014/09/18 职场文书
学生会干部自我鉴定2014
2014/09/18 职场文书
工作业绩不及格检讨书
2014/10/28 职场文书
工作作风懒散检讨书
2014/10/29 职场文书
领导新年致辞2016
2015/07/29 职场文书
2016年庆祝六一儿童节活动总结
2016/04/06 职场文书
解决pytorch 损失函数中输入输出不匹配的问题
2021/06/05 Python
Redis RDB技术底层原理详解
2021/09/04 Redis