当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > CSS简单实例:用css来实现透视效果

CSS样式表
CSS样式表定义标签li前面样式
符合标准的div css制作的弹出菜单
CSS实现在文章每段后面加入带连接的隐藏文字
CSS:浏览器特定选择器介绍
WEB标准学习,认识两种网页声明的含义
CSS样式表中继承关系的空格与不空格
CSS框架的利与弊(下)
让广告代码不影响网页站打开速度
CSS教程:position 绝对定位的问题
标签增加CSS的overflow属性来清除浮动
跨浏览器的CSS固定定位
IE7对css选择器的改进
IE7新支持的CSS属性和属性选择符
CSS设计符合Web标准的网页表单的几个技巧
HTML网页中无刷新的更换CSS样式
CSS定义网页局部链接的技巧
关于学习DIV CSS的一些精妙问答
论web标准的网页制作和符合web标准的网站UI
CSS学习者:2008年不要作浮躁的人
学习CSS布局网页的一些实例

CSS样式表 中的 CSS简单实例:用css来实现透视效果


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-28   浏览: 51 ::
收藏到网摘: n/a

用css实现透视效果

今天萌发一个想法,用css来实现透视效果。起初,我想到的是我们常见的添加阴影效果的方法,用多个div通过偏移来实现,但这需要很多 div,不够理想。随后,我想到css的一个属性:border,在border相连接处可以产生对角线效果。这样用两个div就可以实现,我们先看看 最终效果 ,然后再分析实现过程。

首先,我们看看border如何生成的对角线效果,在你的html的头部增加以下代码,你就会看到 这样的效果 。

.border{width:0;height:0;border-width:50px;border-color:#f00 #0f0 #00f #000;border-style:solid;}

有了上面的基础,我们就可以用两个额外的div来实现透视效果。

一、html代码如下

<div class="perspective-outer">
 <div class="perspective-r"></div>
 <div class="perspective-b"></div>
 <div class="perspective-inner">透视效果元素</div>
</div>

二、Css代码:

.perspective-outer{
 position:relative;
 width:170px;/*要实现透视效果元素的宽度+透视距离*/
 height:140px;/*要实现透视效果元素的高度+透视距离*/
}
.perspective-inner{
 border:1px solid #f60;
 height:118px;
 width:148px;
 background-color:#fff;
}
.perspective-r,
.perspective-b{
 position:absolute;
 width:0;
 height:0;
}
.perspective-r{
 right:0;
 height:100px;/*要实现透视效果元素的高度(120px) - (border-top:20px)*/
 border-left:20px solid #000;/*右边透视距离*/
 border-top:20px solid #fff;/*下边透视距离*/
}
.perspective-b{
 bottom:0;
 width:150px;/*最外元素的宽度(170px) - border-left*/
 border-left:20px solid #fff;
 border-top:20px solid #000;
}

.perspective-outer定义高度和宽度,并相对定位,确保右边和下边的透视区域能定位的相应的位置,高度值和宽度值为要实现透视效果元素的高度加上相应的透视距离。.perspective-r只需设置高度值,其值为.perspective-outer的高度减去border-top,.perspective-b只需设置宽度值,其值为.perspective-outer的宽度减去border-left。.perspective-r的border-top和.perspective-b的border-left的width值决定透视角度。.perspective-r的border-left和.perspective-b的border-top的width值 决定透视距离。其中.perspective-r的border-top和.perspective-b的border-left的color为父元素的背景颜色,我这里的测试页面父元素为body,所以为白色。

三、后记

本文只是做一个简单得测试,其目的在于抛砖引玉。这种方法其实用性究竟有多大,咱姑且不论,但至少可以给我们一种解决问题的思路。希望此文能对你有所帮助。

原文:http://www.denisdeng.com/?p=474;