神奇的CSS sprites,制作特效的新方法
本文主要内容简译自Dava Shea的英文文章 CSS Sprites: Image Slicing’s Kiss of Death,如果觉得博主讲的含糊不清的话,可以看作者原文。
熟悉了常规切图的我们,在浏览大型网站的时候,有时会忍不住审查元素一下,就会发现他们会把所有的小图标整合在一个图片上,比如谷歌的

而且如果你细心一点,你会发现Google的二级搜索结果页面是底下的分页的那一排o也是用CSS Sprite做的。那么什么是CSS Sprite呢?
CSS Sprites是目前大型网站的图片处理的一种方式,原理主要是将网站上的小图片或者图标整合在一张大图上,在用css的background-position属性通过x/y轴的位置来定位图片,从而减少服务器对图片的请求数目,提高网站的加载速度。当然如果你不做大型网站,不需要精细到加载速度的时候,CSS Sprites也会制作和维护带来一些不必要的麻烦。但是当你掌握其用法时,利用CSS Sprites是可以和轻松的做出一些有趣的特效。
CSS Sprites是如何作用的?
我们用到的工具无非就是css,运用我们的想法写出富有创造力的css。
然我们从原图本身说起,把矩形分为四个部分,我们可以看出来上半部分图片,是链接刚开始的效果,下半部分是我们把鼠标悬停在链接上的效果,我们把鼠标悬停在哪个部分哪个部分就会变色。
HTML代码如下:
<ul id="skyline">
<li id="panel1b"><a href="#1"></a></li>
<li id="panel2b"><a href="#2"></a></li>
<li id="panel3b"><a href="#3"></a></li>
<li id="panel4b"><a href="#4"></a></li>
</ul>
我们用四个<li>标签和<a>组成了四个不同部分的链接。
应用css
#skyline{
width: 400px;
background-image: url(img/test-3.jpg);
height: 200px;
position: relative;
margin: 10px auto;
padding: 0;
}
#skyline li{
margin: 0;
padding: 0;
list-style-type: none;
position: absolute;
top: 0;
}
#skyline li,#skyline a{
height: 200px;
display: block;
}
注意我们并没有把图片放在链接里而是放在的ul里,一会儿你将看到原因。
我们将a元素设定空白透明但是有限定大小的block用来出发链接活动,通过定位包含它的li元素来定位,如果这里我们直接来定位a元素而不是定位li元素将在老版本的浏览器中出现错误。
定位链接
li元素被绝对定位了(position:abosulute),那么为什么li元素没有出现在浏览器的窗口的上方,被定位的元素有一个怪异却很有用的特性,被绝对定位的后代元素不是相对于浏览器窗口定位,而是相对离它最近的并且position属性为relative的父元素进行定位。所以这里的li元素相对于#skyline进行定位。
#panel1b {left:; width: 95px;}
#panel2b {left: 96px; width: 75px;}
#panel3b {left: 172px; width: 110px;}
#panel4b {left: 283px; width: 117px;}
所以通过如上代码我们就将每个li元素分别布局到四个小矩形的位置上,这是我们有了带有链接的图片地图,我们来看一下没有加上:hover时的效果和每个部分加border的效果。
hover效果
接下来我们将通过:hover使隐藏的下半部分图片剪裁一部分的方式显现,那么我们将移动图片使它精确定位呢,接下来就是CSS Sptites了,我们要讲的。
#panel1b a:hover {
background: transparent url(test-3.jpg)
0 -200px no-repeat;}
#panel2b a:hover {
background: transparent url(test-3.jpg)
-96px -200px no-repeat;}
#panel3b a:hover {
background: transparent url(test-3.jpg)
-172px -200px no-repeat;}
#panel4b a:hover {
background: transparent url(test-3.jpg)
-283px -200px no-repeat;}
我们从那里获得的像素值呢,让我们把它拆分一下,第一个数值当然水平方向的值(距离左边),第二个值时垂直方向。垂直方向的数值都是相等的200px,因为图片的高度时400px的,上下半部分各占200px,下边的部分需要向上移动200px才能覆盖上半部分,还有一点就是一般background-position值都是负值,因为背景图都是定位在左上方的。
水平方向的偏移量则是li的宽度,第二个链接的偏移量则是前两个li元素宽度的和,以此类推。
Buttons效果和特殊形状
通过以上的方式我们就可以在把网页上的按钮button应用各种效果,比如原图,我们可以做成这样的样式,方法同上
但是我们遇到不规则图形时,这是可能会出现重叠现象(看效果),这是我们可以在原图上做做文章,拆分为两个hover后的效果图,如图,这是我们正确完整的效果。
神奇的CSS sprites,制作特效的新方法的更多相关文章
- 【转】CSS Sprites教程大全(使用方法、工具介绍)
什么是CSS Sprite CSS Sprite 又叫CSS精灵,是目前大型网站中经常运用的图片处理方式.它的原理很简单,将网站上零散的小图片(或图标)整合在一张大图上,再用CSS中“backgrou ...
- CSS Sprites (CSS图像拼合技术)教程工具
什么是CSS Sprites? “Sprite”(精灵)这个词在计算机图形学中有它独特的定义,由于游戏.视频等画质越来越高,必须有一种技术可以智能的处理材质和贴图,并且要 同时保持画面流畅.“Spri ...
- CSS Sprites(CSS图像拼合技术)教程、工具集合
本集合是有一位国外设计师收集整合,并由 oncoding翻译成中文的,感谢他们的辛苦贡献.CSS Sprites技术在国外并不是什么新技术,只不过近两年(尤其08年开始)中国开始流行这个词,大家也开始 ...
- CSS Sprites+CSS3 Icon Font
CSS Sprites+CSS3 Icon Font CSS Sprites在国内很多人叫CSS精灵,是一种网页图片应用处理方式.它允许你将一个页面涉及到的所有零星图片都包含到一张大图中去,这样一来, ...
- 奇思妙想 CSS 3D 动画 | 仅使用 CSS 能制作出多惊艳的动画?
本文将从比较多的方面详细阐述如何利用 CSS 3D 的特性,实现各类有趣.酷炫的动画效果.认真读完,你将会收获到: 了解 CSS 3D 的各种用途 激发你新的灵感,感受动画之美 对于提升 CSS 动画 ...
- CSS3与页面布局学习笔记(五)——Web Font与CSS Sprites(又称CSS精灵、雪碧图)技术
一.web font web font是应用在web中的一种字体技术,在CSS中使用font-face定义新的字体.先了解操作系统中的字体: a).安装好操作系统后,会默认安装一些字体,这些字体文件描 ...
- CSS Sprites的概念、原理、适用范围和优缺点
CSS Sprites概念 CSSSprites在国内很多人叫css精灵,是一种网页图片应用处理方式.它允许你将一个页面涉及到的所有零星图片都包含到一张大图中去,这样一来,当访问该页面时,载入的图片就 ...
- CSS Sprites优缺点
利用CSS Sprites能很好地减少网页的http请求,从而大大的提高页面的性能,这也是CSS Sprites最大的优点,也是其被广泛传播和应用的主要原因: CSS Sprites能减少图片的字节, ...
- Css Sprites 多张图片整合在一张图片上
CSS Sprites原理: CSS Sprites其实就是把网页中一些背景图片整合到一张图片文件中,再利用CSS的"background-image","backgro ...
随机推荐
- 封装jdbc 单例模式的应用
实现增删该查的jdbc封装 import java.io.IOException; import java.io.InputStream; import java.sql.Connection; im ...
- java-并发-活性
浏览以下内容前,请点击并阅读 声明 一个并发程序以适时方式执行的能力叫活性.以下部分介绍最常见的一种活性问题,死锁,并简单介绍其他两种活性问题,饥饿和活锁. 死锁 死锁描述了一种情况:两个或两个以上的 ...
- linux I/O stack cache 强制刷新
linux 存储子系统作为最为复杂的子系统之一,拥有很深的模块栈(如图),其中很多模块又有自己的缓存功能(如下图).实际应用中,用户下发的数据停留在哪个缓存中,是否已经写入磁盘,这些操作对用户来说是个 ...
- 【java基础学习】-【泛型】
参考以下几位同学的总结来学习: http://www.cnblogs.com/lwbqqyumidi/p/3837629.html#!comments http://www.weixueyuan.ne ...
- PHP获取二维数组中的指定若干列【同array_column】
PHP5.3以上 用到了array_map 使用匿名函数进行处理 代码: <?php function array_col($arr = array(), $idx = 0, $newidx ...
- 第一个Mac shell 小脚本
大多数程序员都喜欢偷懒的,我也不例外.相信好多Android开发的coder 在网络http请求方面,会浪费很多时间在接口调试这里..有时候,自己写了一个小测试,行还好,不行的话,还要跟写后台的哥们一 ...
- JS代码将数据导入Excel
如果在别的浏览器中无法导入,尝试用IE浏览器 function AutomateExcelall(){try { oXL = new ActiveXObject('Excel.Application' ...
- python中实现定时器Timer
实现定时器最简单的办法是就是循环中间嵌time.sleep(seconds), 这里我就不赘述了 # encoding: UTF-8 import threading #Timer(定时器)是Thre ...
- SSH学习笔记
Struts2登录模块处理流程: 浏览器发送请求http://localhost/appname/login.action,到web应用服务器: 容器接收到该请求,根据web.xml的配置,服务器将请 ...
- ASP.NET Core 使用 Redis 和 Protobuf 进行 Session 缓存
前言 上篇博文介绍了怎么样在 asp.net core 中使用中间件,以及如何自定义中间件.项目中刚好也用到了Redis,所以本篇就介绍下怎么样在 asp.net core 中使用 Redis 进行资 ...