RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 615186
Accepted
Александр
Александр
Asked:2020-01-16 15:44:40 +0000 UTC2020-01-16 15:44:40 +0000 UTC 2020-01-16 15:44:40 +0000 UTC

如何在 CSS 中制作不均匀的形状?

  • 772

我需要制作这样的图,但我不知道如何正确制作。我制作了一个正方形并在其中before添加了一个裁剪的正方形border,但在不同的屏幕分辨率下它似乎“剥落”了。

在此处输入图像描述

html
  • 3 3 个回答
  • 10 Views

3 个回答

  • Voted
  1. Best Answer
    Alexey Giryayev
    2020-01-16T16:25:52Z2020-01-16T16:25:52Z

    渐变的第一个选项:

    div {
      width: 500px;
      padding-bottom: 40%;
      max-width: 100%;
      background: #000;
      margin: 30px auto;
      border-top: 2px solid #000;
    
      background: linear-gradient(105deg,  #000 0%, #000 25%, #ae0000 25%, #ae0000 100%);
    
    }
    <div></div>

    而且体积更大:before

    div {
      position: relative;
      width: 500px;
      padding-bottom: 40%;
      max-width: 100%;
      background: #ae0000;
      margin: 30px auto;
      border-top: 2px solid #000;
      overflow: hidden;
    }
    div:before {
      content: '';
      position: absolute;
      background: #000;
      width: 100%;
      height: 100%;
      right: 50%;
      transform: rotate(-80deg);
      -webkit-transform: rotate(-80deg);
      -moz-transform: rotate(-80deg);
      -o-transform: rotate(-80deg);
      -ms-transform: rotate(-80deg);
    }
    <div></div>

    以及带有 SVG 背景的版本:

    div {
      width: 500px;
      padding-bottom: 40%;
      max-width: 100%;
      margin: 30px auto;
      border-top: 2px solid #000;
    
      background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2NjAuMDAwMSAzNjQuNDU3Ij48cG9seWdvbiBwb2ludHM9IjE4Ni44MzYgMCAxNzkuMzMzIDAgMTMyLjE0MyAzNjQuNDU3IDY2MCAzNjQuNDU3IDY2MCAwIDE4Ni44MzYgMCIgZmlsbD0iI2FlMWExNyIvPjxwb2x5Z29uIHBvaW50cz0iMCAwIDAgMzY0LjQ1NyAxMzIuMTQzIDM2NC40NTcgMTc5LjMzMyAwIDAgMCIvPjwvc3ZnPg==') no-repeat center / cover;
      
    }
    <div></div>

    要在所有浏览器中使用最后一个选项,您需要通过任何Base64 编码器取代 SVG 代码。例如,像这样的样式:

    background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 660.0001 364.457"><polygon points="186.836 0 179.333 0 132.143 364.457 660 364.457 660 0 186.836 0" fill="#ae1a17"/><polygon points="0 0 0 364.457 132.143 364.457 179.333 0 0 0"/></svg>') no-repeat center / cover;
    

    我们编码和替换,如示例中所示。

    • 16
  2. Sasha Omelchenko
    2020-01-16T19:23:41Z2020-01-16T19:23:41Z

    除了特定的应用程序,显然,使用渐变的解决方案就足够了,这些形状可以使用clip-path.

    .megablock {
      display: flex;
    }
    
    .block {
      height: 400px;
      flex-grow: 1;
    }
    .block--black {
      background-image: linear-gradient(#000, #999);
      clip-path: url(#polygon-1);
      clip-path: polygon(0 0, 80% 0, 100% 100%, 0% 100%);
    }
    
    .block--color {
      background-image: linear-gradient(rgba(0, 192, 255, 0.8), #ff9);
      clip-path: url(#polygon-2);
      clip-path: polygon(0 0, 100% 0, 100% 100%, 20% 100%);
    }
    <div class="megablock">
      <div class="block block--black"></div>
      <div class="block block--color"></div>
    </div>
    
    <svg class="clip">
      <defs>
        <clipPath id="polygon-1" clipPathUnits="objectBoundingBox" >
          <polygon points="0 0, 0.8 0, 1 1, 0 1" />
        </clipPath>
        
        <clipPath id="polygon-2" clipPathUnits="objectBoundingBox" >
          <polygon points="0 0, 1 0, 1 1, 0.2 1" />
        </clipPath>
      </defs>
    </svg>

    • 13
  3. Vadim Ovchinnikov
    2020-01-16T16:12:27Z2020-01-16T16:12:27Z

    通过梯度解决方案:

    /* Чтобы не было скролла */
    body {
      margin: 0;
    }
    
    .with-gradient {
      background: linear-gradient(100deg, #000 30%, #ac0000 0);
      
      /* Просто для демонстрации */
      height: 100vh;
    }
    <div class="with-gradient">
    </div>

    小记:

    我使用0两个渐变步长以避免重复之前的值,因为根据规范,渐变步长不能小于之前的值。

    如果色标的位置小于列表中它之前任何色标的指定位置,则将其位置设置为等于它之前任何色标的最大指定位置。

    • 8

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5