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结构性伪类选择器九种写法
Apr 18 HTML / CSS
CSS3效果:自定义“W”形运行轨迹实例
Mar 29 HTML / CSS
CSS3实现红包抖动效果
Dec 23 HTML / CSS
使用HTML5捕捉音频与视频信息概述及实例
Aug 22 HTML / CSS
HTML5仿手机微信聊天界面
Mar 18 HTML / CSS
html5 canvas-1.canvas介绍(hello canvas)
Jan 07 HTML / CSS
Html5游戏开发之乒乓Ping Pong游戏示例(一)
Jan 21 HTML / CSS
HTML5和以前HTML4的区别整理
Oct 20 HTML / CSS
使用html5 canvas 画时钟代码实例分享
Nov 11 HTML / CSS
html5给汉字加拼音加进度条的实现代码
Apr 07 HTML / CSS
Html5在手机端调用相机的方法实现
May 13 HTML / CSS
详解CSS不定宽溢出文本适配滚动
May 24 HTML / CSS
CSS3通过var()和calc()函数实现动画特效
CSS3实现模糊背景的三种效果示例
使用css样式设计一个简单的html登陆界面的实现
CSS实现漂亮的时钟动画效果的实例代码
CSS3点击按钮圆形进度打钩效果的实现代码
完美实现CSS垂直居中的11种方法
CSS代码检查工具stylelint的使用方法详解
You might like
PHP4实际应用经验篇(8)
2006/10/09 PHP
一些php技巧与注意事项分析
2011/02/03 PHP
php中session_id()函数详细介绍,会话id生成过程及session id长度
2015/09/23 PHP
PHP内存缓存功能memcached示例
2016/10/19 PHP
PHP开发之归档格式phar文件概念与用法详解【创建,使用,解包还原提取】
2017/11/17 PHP
从sohu弄下来的flash中展示图片的代码
2007/04/27 Javascript
JavaScript 设计模式 富有表现力的Javascript(一)
2010/05/26 Javascript
ExtJs的Date格式字符代码
2010/12/30 Javascript
一行代码实现纯数据json对象的深度克隆实现思路
2013/01/09 Javascript
js window.open弹出新的网页窗口
2014/01/16 Javascript
用jquery写的一个万年历(自写)
2014/01/20 Javascript
jquery中EasyUI实现同步树
2015/03/01 Javascript
EditPlus 正则表达式 实战(3)
2016/12/15 Javascript
js判断iframe中元素是否存在的实现代码
2016/12/24 Javascript
Avalonjs双向数据绑定与监听的实例代码
2017/06/23 Javascript
BootStrap给table表格的每一行添加一个按钮事件
2017/09/07 Javascript
EasyUI框架 使用Ajax提交注册信息的实现代码
2017/09/27 Javascript
微信小程序 动画的简单实例
2017/10/12 Javascript
vue刷新和tab切换实例
2018/02/11 Javascript
jQuery判断自定义属性data-val用法示例
2019/01/07 jQuery
JS添加或删除HTML dom元素的方法实例分析
2019/03/05 Javascript
[03:33]TI9战队采访 - Infamous
2019/08/20 DOTA
python使用xauth方式登录饭否网然后发消息
2014/04/11 Python
对pyqt5中QTabWidget的相关操作详解
2019/06/21 Python
django之使用celery-把耗时程序放到celery里面执行的方法
2019/07/12 Python
python实现微信打飞机游戏
2020/03/24 Python
pycharm 配置svn的图文教程(手把手教你)
2021/01/15 Python
纯CSS3实现圆角效果(含IE兼容解决方法)
2014/05/07 HTML / CSS
使用CSS3编写灰阶滤镜来制作黑白照片效果的方法
2016/05/09 HTML / CSS
css3实现椭圆轨迹旋转的示例代码
2018/10/29 HTML / CSS
HTML5中使用postMessage实现Ajax跨域请求的方法
2016/04/19 HTML / CSS
影视艺术学院毕业生自荐信
2013/11/13 职场文书
单身联谊活动方案
2014/01/29 职场文书
大学活动总结范文
2014/04/29 职场文书
工人先锋号申报材料
2014/12/29 职场文书
MySQL RC事务隔离的实现
2022/03/31 MySQL