zoukankan      html  css  js  c++  java
  • css画图

    原理是利用边框实现,好处是不用加载图片,节省流量;坏处就是会有很长一段css样式

    基本:1.设置width,height为0 ,然后设置一个border-width

    利用border可以画很多有趣的图

    1.正方形

    #square{
    	0px;
    	height:0px;
    	border- 100px;
    	border-style: solid;
    	border-color: blue red green yellow;
    }
    

    2.三角形:设置其他边颜色为透明值transparent

    #triangle{
    	 0px;
    	height: 0px;
    	border- 100px;
    	border-style: solid;
    	border-color: blue transparent transparent transparent;
    }
    

    3.圆形:设置圆角属性border-radius

    #circle{
    	0px;
    	height:0px;
    	border- 100px;
    	border-style: solid;
    	border-color: blue red green yellow;
    	border-radius: 100px;
    }
    

    4.扇形:同理设置透明色

    #fan{
    	 0px;
    	height: 0px;
    	border- 100px;
    	border-style: solid;
    	border-color: transparent transparent transparent yellow;
    	border-radius: 100px;
    }
    

    5.同心圆:在圆的基础上添加width/height值

    #circle-circle{
    	 200px;
    	height: 200px;
    	border: 50px solid red;
    	border-radius: 200px;
    }
    

    5.半圆:利用border-radius分别设置左上角,右上角,右下角,左下角的值

    #circle-half{
    	 200px;
    	height: 100px;
    	background-color: red;
    	/*border-color: red;*/
    	/*border-style: solid;*/
    	border-radius: 100px 100px 0 0;
    }
    

    6.四分之一圆:同半圆原理

    #circle-double-half{
    	 200px;
    	height: 200px;
    	background-color: red;
    	border-radius: 200px 0 0 0;
    }

    7.小尾巴 :主要是在半圆的基础上添加某一侧的Border,border-top,border-right,border-left,border-bottom,大家阔以动手试一试

    #tail{
    	 100px;
    	height: 100px;
    	border-radius: 100px 0 0 0;
    	border-top:30px solid red;
    	/*border-radius: 0 100px 0 0;
    	border-top: 30px solid red;*/
    }

     8.提示框:用到了:after伪类去实现小尾巴的功能

    #pop{
    	margin-top: 20px;
    	 400px;
    	height: 200px;
    	border-radius: 20px;
    	background-color: red;
    	position: relative;
    }
    #pop:after{
    	content: "";
    	height: 100px;
    	100px;
    	border-radius: 0 0 200px 0;
    	border-right: 50px solid red;
    	position: absolute;
    	top:180px;
    }
    

    9.椭圆:这里用到border-radius: 100px / 50px,其中"/"前面的表示水平半径(其值为width/2),后面的表示垂直半径(其值为height/2).

    #ellipse{
    	margin-top: 20px;
    	 200px;
    	height: 100px;
    	border-radius: 100px/50px;
    	background-color: red;
    }
    

    10.梯形:主要是理解Border属性,也就是第一幅图,梯形就比较容易画了

    #trapezium {
    	height: 0;
    	 200px;
    	border-bottom: 100px solid red;
    	border-left: 50px solid transparent;
    	border-right: 50px solid transparent;
    
    }
    

    11.菱形:主要是用到旋转transform,不过要考虑到浏览器内核不同,要实现兼容,我这里就省略了

    #diamond {
    	 100px;
    	height: 100px;
    	background-color: red;
    	transform:rotate(-45deg);
    }
    

    12.平行四边形:也是主要用到transform,但菱形用的是skew,倾斜

    #parallelogram {
    	160px;
    	height: 100px;
    	background-color: red;
    	transform:skew(30deg);
    }
    

    13.五角星:主要是画三个三角形,通过旋转,然后拼接成一个五角星,各种画法自己去体会.....(可以通过不同的三角形去拼接,但原理是一样的)

    #star{
    	 0;
    	height: 0;
    	color: red;
    	position: relative;
    	border-left: 100px solid transparent;
    	border-right: 100px solid transparent;
    	border-bottom: 70px solid red;
    	transform:rotate(35deg);
    }
    #star:before{
            content: '';
    	 0;
    	height: 0;
    	position: absolute;
    	border-bottom: 80px solid red;
            border-left: 30px solid transparent;
        	border-right: 30px solid transparent;
        	top:-50px;
        	left:-60px;
        	transform:rotate(-35deg);
    }
    #star:after{
            content: "";
    	 0px;
    	height: 0px;
    	position: absolute;
    	border-top: 70px solid red;
    	border-left: 100px solid transparent;
    	border-right: 100px solid transparent;
    	left:-100px;
    	transform:rotate(110deg);
    }
    

    14:爱心:用菱形和胶囊拼接一个爱心形

    #love{
    	position: relative;
    	 100px;
    	height: 100px;
    	background-color: red;
    	transform:rotate(45deg);
    }
    #love:before{
    	position: absolute;
    	left: -75px;
    	content: "";
    	 80px;
    	height: 100px;
    	background: red;
    	border-radius: 50px 0 0 50px;
    }
    #love:after{
    	position: absolute;
    	left: 10px;
    	top:-85px;
    	content: "";
    	 80px;
    	height: 100px;
    	background: red;
    	border-radius:0 50px 50px 0;
    	transform:rotate(-90deg);
    }
    

      

     

  • 相关阅读:
    获取某表所有列名和字段类型
    C++ 长指针与指针的区别
    C# WinForm 控件光标
    不错的UML建模工具StarUML
    给控件做数字签名之一:将控件打包为Web发布包(转)
    MsComm控件注册失败
    微软发布Microsoft图表控件
    C与C++中的宏
    WinForm DataGridView 显示行号
    C#ToString格式大全
  • 原文地址:https://www.cnblogs.com/thonrt/p/5779948.html
Copyright © 2011-2022 走看看