zoukankan      html  css  js  c++  java
  • 通过数学模型用CSS绘制以色列国旗

    以色列国旗长度为220厘米X160厘米,白色背景。两条25厘米宽的水平蓝色条纹放在距边缘15厘米处。大卫之盾由两个相交的等边三角形组成,位于旗帜的中央。它的高度为69厘米,每边长60厘米,宽度为5.5厘米。条纹和星星的颜色范围可以从蓝色到耶鲁蓝色。“大卫盾”在旗帜中与四方边沿等距。

    初步观察到,绘制这个图案的重点在于中间的六芒星,蓝色边框以内阴影来实现。代表“大卫盾”的六芒星的外接圆圆心位于旗帜的几何中心。旗帜中的白、蓝相间效果可以通过线性渐变来实现。

    根据六芒星几何图形的性质:六芒星可以通过一个等边三角形AHI通过绕其外心O旋转60°、120°、180°、240°、300°后所共同组成的图形获得。这也是CSS绘制镂空三角形组合成为六芒星的原理。

    难点在于构成“大卫盾”的基础镂空三角形的绘制。

    构建数学模型:

    六芒星ABCDEF中,O为其外接圆圆心,过O做BF的垂线,垂足为G。根据几何图形的性质,G为BF的中点,并且BO为∠DBF的角平分线。设六芒星的外接圆半径为R。

    OG=0.5R

    GB=√3 ·R/2

    而BF=2GB

    即R=√3/3 ·BF

    OG=√3/6 ·BF

    GD=√3/2 ·BF

    设计尺寸:旗帜主体宽440px,高320px,那么BF=120px

    GD=103.9230px,OG=34.6410px

    满足大卫盾的要求需要是△ARS进行旋转,△MTU为内部填充白色,相对于△ARS进行绝对定位,这样就构成了基础的类似三条等宽、等长线段构成的三角形。(W为构成大卫盾的条纹宽度值)

    △ARS的高为:H=AG+W

    H=34.6410+11=45.6410

    边长的一半RS/2为:HG+W/√3

    HG=0.5HI

    HI=BF/3

    所以

    HG+W/√3= BF/6 + (W/√3)=20+6.3508=26.3508

    旋转基点坐标: 26.3508    69.2820

    对于内部填充△MTU进行相关数据计算:

    过T做△ARS的两边的垂线,垂足为G1和F1,G1T=TF1=11

    RF1=√3 TF1=√3·11=19.0525

    构成小三角形底边的一半值UT/2:

    RS/2  - RF1=26.3508 -19.0525=7.2983

    △MTU的高:

    H=√3·7.2983=12.6410

    △MTU绝对定位的数据:

    水平方向:7.2983

    垂直方向:AM=RT=2TF1

    AM=2W=22

    最后是对“大卫盾”进行定位。

    外接圆圆心的坐标(220,160)

    转换三角形的绝对定位坐标距离:

    水平方向 220-26.3508=193.6492

    垂直方向 160-R=160-69.2820=90.7179

    水平方向距离:

    HTML代码:

        <div class='flag'>
            <div class='star'>
    
            </div>
            <div class='star'>
    
            </div>
            <div class='star'>
    
            </div>
            <div class='star'>
    
            </div>
            <div class='star'>
    
            </div>
            <div class='star'>
    
            </div>
        </div>
    

      CSS代码:

      * {
                border- 0;
            }
    
            .flag {
                 440px;
                height: 320px;
                background: linear-gradient(0deg, white 0, white 6.8181%, blue 6.8181%, blue 18.1818%, white 0, white 81.8181%, blue 0, blue 93.1818%, white 0, white 100%);
                position: relative;
    
            }
    
            .star {
    
                 0;
                height: 0;
                border-bottom: 45.6410px solid #0138b9;
                border-left: 26.3508px solid transparent;
                border-right: 26.3508px solid transparent;
                position: absolute;
                transform-origin: 26.3508px 69.2820px;
                top:90.7179px;
                left:193.6492px;
            }
    
            .star:before {
                content: '';
                display: block;
                 0;
                height: 0;
                border-bottom: 12.6410px solid white;
                border-left: 7.2983px solid transparent;
                border-right: 7.2983px solid transparent;
                position: absolute;
                left: -7.2983px;
                top: 22px;
            }
    
            .flag .star:nth-child(2) {
                transform: rotate(-60deg);
            }
    
            .flag .star:nth-child(3) {
                transform: rotate(-120deg);
            }
    
            .flag .star:nth-child(4) {
                transform: rotate(-180deg);
            }
    
            .flag .star:nth-child(5) {
                transform: rotate(-240deg);
            }
    
            .flag .star:nth-child(6) {
                transform: rotate(-300deg);
            }
    

    实现效果较为理想:

  • 相关阅读:
    python中使用scikit-learn和pandas决策树进行iris鸢尾花数据分类建模和交叉验证
    CNN+ Auto-Encoder 实现无监督Sentence Embedding ( 基于Tensorflow)
    R语言数据可视化分析案例:探索BRFSS数据
    1.微信小程序里如何设置当地时间?
    63.1拓展之纯 CSS 创作一个摇摇晃晃的 loader
    63.(原65)纯 CSS 创作一个摇摇晃晃的 loader
    6.HTML+CSS制作一双眼睛
    62.纯 CSS 创作一只蒸锅(感觉不好看呀)
    61.纯 CSS 创作一只咖啡壶(这个不好看)
    60.纯 CSS 创作一块乐高积木
  • 原文地址:https://www.cnblogs.com/f6056/p/14151182.html
Copyright © 2011-2022 走看看