经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » CSS3 » 查看文章
CSS3 菱形拼图实现只旋转div 背景图片不旋转功能_css3_CSS
来源:jb51  时间:2021/4/6 9:28:11  对本文有异议

需求背景

使用 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 代码如下:

  1. <template>
  2. <section class="box">
  3. <div class="bg" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
  4. <div v-if="item1Show" class="item item1" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
  5. <div v-if="item2Show" class="item item2" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
  6. <div v-if="item3Show" class="item item3" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
  7. <div v-if="item4Show" class="item item4" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
  8. <div v-if="item5Show" class="item item5wrap">
  9. <div class="item5" :style="{ backgroundImage: `url(${bgImg}) ` }"></div>
  10. </div>
  11. </section>
  12. </template>
  13. <script>
  14. import bgImg from "@/assets/bg.jpeg";
  15. export default {
  16. data() {
  17. return {
  18. bgImg,
  19. item1Show: false,
  20. item2Show: true,
  21. item3Show: true,
  22. item4Show: true,
  23. item5Show: true
  24. };
  25. }
  26. };
  27. </script>
  28. <style lang="less">
  29. @borderColor: #333;
  30. .box {
  31. margin: 0px auto;
  32. width: 300px;
  33. height: 200px;
  34. background-color: #000;
  35. position: relative;
  36. .bg {
  37. width: 100%;
  38. height: 100%;
  39. position: absolute;
  40. left: 0;
  41. top: 0;
  42. background-position: center center;
  43. background-repeat: no-repeat;
  44. background-size: 100% 100%;
  45. opacity: 0.5;
  46. }
  47. .item {
  48. width: 50%;
  49. height: 50%;
  50. box-sizing: border-box;
  51. background-size: 200% 200%;
  52. border-right: 1px solid @borderColor;
  53. border-bottom: 1px solid @borderColor;
  54. position: absolute;
  55. }
  56. .item1 {
  57. background-position: 0 0;
  58. left: 0;
  59. top: 0;
  60. }
  61. .item2 {
  62. background-position: 100% 0;
  63. left: 50%;
  64. top: 0;
  65. }
  66. .item3 {
  67. background-position: 0 100%;
  68. left: 0;
  69. top: 50%;
  70. }
  71. .item4 {
  72. background-position: 100% 100%;
  73. left: 50%;
  74. top: 50%;
  75. }
  76. .item5wrap {
  77. width: 100px;
  78. height: 100px;
  79. border-left: 1px solid @borderColor;
  80. border-top: 1px solid @borderColor;
  81. transform: rotate(45deg);
  82. left: 50%;
  83. top: 50%;
  84. transform: translate(-50%, -50%) rotate(45deg);
  85. overflow: hidden;
  86. .item5 {
  87. width: 150px;
  88. height: 150px;
  89. background-position: 50% 50%;
  90. background-size: 200% 133%;
  91. position: absolute;
  92. left: 50%;
  93. top: 50%;
  94. transform: translate(-50%, -50%) rotate(-45deg);
  95. }
  96. }
  97. }
  98. </style>

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号