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之边框多颜色Border-color属性使用示例
Oct 11 HTML / CSS
如何用border-image实现文字气泡边框的示例代码
Jan 21 HTML / CSS
HTML5 Canvas绘制文本及图片的基础教程
Mar 14 HTML / CSS
详解如何用canvas画一个微笑的表情
Mar 14 HTML / CSS
html5 Canvas画图教程(7)—canvas里画曲线之quadraticCurveTo方法
Jan 09 HTML / CSS
HTML5本地数据库基础操作详解
Apr 26 HTML / CSS
使用canvas压缩图片大小的方法示例
Aug 02 HTML / CSS
Html5监听手机摇一摇事件的实现
Nov 07 HTML / CSS
HTML利用九宫格原理进行网页布局
Mar 13 HTML / CSS
CSS的class与id常用的命名规则
May 18 HTML / CSS
el-form每行显示两列底部按钮居中效果的实现
Aug 05 HTML / CSS
使用CSS实现音波加载效果
May 07 HTML / CSS
CSS3通过var()和calc()函数实现动画特效
CSS3实现模糊背景的三种效果示例
使用css样式设计一个简单的html登陆界面的实现
CSS实现漂亮的时钟动画效果的实例代码
CSS3点击按钮圆形进度打钩效果的实现代码
完美实现CSS垂直居中的11种方法
CSS代码检查工具stylelint的使用方法详解
You might like
PHP中英混合字符串截取函数代码
2011/07/17 PHP
ThinkPHP实现一键清除缓存方法
2014/06/26 PHP
使用新浪微博API的OAuth认证发布微博实例
2015/03/27 PHP
cakephp2.X多表联合查询join及使用分页查询的方法
2017/02/23 PHP
用js自动判断浏览器分辨率的代码
2007/01/28 Javascript
用javascript实现计算两个日期的间隔天数
2007/08/14 Javascript
JavaScript效率调优经验
2009/06/04 Javascript
JavaScript实现点击按钮后变灰避免多次重复提交
2013/07/15 Javascript
可自己添加html的伪弹出框实现代码
2013/09/08 Javascript
JavaScript动态修改背景颜色的方法
2015/04/16 Javascript
跟我学习javascript的最新标准ES6
2015/11/20 Javascript
js解决movebox移动问题
2016/03/29 Javascript
详解堆的javascript实现方法
2016/11/29 Javascript
ES7中利用Await减少回调嵌套的方法详解
2017/11/01 Javascript
JavaScript门道之标准库
2018/05/26 Javascript
Vue中CSS动画原理的实现
2019/02/13 Javascript
Vue中的验证登录状态的实现方法
2019/03/09 Javascript
详解easyui 切换主题皮肤
2019/04/04 Javascript
[00:59]DOTA2荣耀之路1:Doom is back!weapon X!
2018/05/22 DOTA
从零学python系列之新版本导入httplib模块报ImportError解决方案
2014/05/23 Python
用于统计项目中代码总行数的Python脚本分享
2015/04/21 Python
python字符串Intern机制详解
2019/07/01 Python
Python的numpy库下的几个小函数的用法(小结)
2019/07/12 Python
Python中Subprocess的不同函数解析
2019/12/10 Python
python GUI库图形界面开发之PyQt5窗口类QMainWindow详细使用方法
2020/02/26 Python
Python编程快速上手——strip()函数的正则表达式实现方法分析
2020/02/29 Python
python的flask框架难学吗
2020/07/31 Python
python实现在列表中查找某个元素的下标示例
2020/11/16 Python
YOOX美国官方网站:全球著名的多品牌时尚网络概念店
2016/09/11 全球购物
英国最出名高街品牌:Forever Unique
2018/02/24 全球购物
限量版运动鞋和街头服饰:TheDrop
2020/09/06 全球购物
排序都有哪几种方法?请列举。用JAVA实现一个快速排序
2014/02/16 面试题
中班开学寄语
2014/04/04 职场文书
民政局个人整改措施
2014/09/24 职场文书
利用Nginx代理如何解决前端跨域问题详析
2021/04/02 Servers
Java SSH 秘钥连接mysql数据库的方法
2021/06/28 Java/Android