转:http://www.cnblogs.com/iyangyuan/archive/2013/06/01/3111704.html

相信很多喜欢研究网页界面的童鞋都遇到过一个奇妙的现象:网页中很多图片素材被合成在一张图片上。

起初小菜模仿网站的时候,经常遇到这个现象,那时候也不知道这时什么技术,人家的整张图片素材不会利用,只能用ps切图,切成单个的再用。。。

其实,这是一个非常简单的技术,就是因为想象的太难了,才一直找不到问题的关键。

要想实现CSS抠图,只需要用到一个属性:background-position。

按照字面理解,这个属性就是背景定位,先看看google网站的素材图,如下:

假如小菜现在想做一个+1按钮,利用上边的素材图,普通状态显示A图,鼠标移上去显示后显示B图,实现这么一个动态效果。

按钮是用来实现功能的,一般是用超链接响应单击事件,但是不能把背景图直接加在超链接上,那样就不叫样式啦,因为超链接的文本长度变化时,样式也变了。

地球人一般的做法是,div里边套一个超链接,超链接负责实现功能,div负责装载背景图。html结构如下:

1 <div class="btn">
2     <a href="http://www.kpdown.com">+1</a>
3 </div>

有了html骨架,接下来就要写css样式啦。

假如我们什么都不考虑,直接把整张图片设为背景,样式如下:

1 .btn{
2     background:url(bg.png);
3 }

 效果如图:

div是块级元素,默认是占一行的,这个先不用关心,但看到背景图重复了,这显然不是我们想要的,加上background-repeat:no-repeat;属性,改进样式如下:

1 .btn{
2     background:url(bg.png);
3     background-repeat:no-repeat;
4 }

这样就不重复了。

div可以理解成一个矩形框,它的左上角是顶点,背景图片的顶点也是左上角,div加载背景图时,会把两个顶点重合,顶点的坐标是(0,0)。不理解的看图,很简单的。。。

+1的小图片混杂在大图中,想提取出来,需要用background-position属性,这个属性相当于大图片不动,把div的顶点进行移动,移动到目标小图的顶点位置,如下图:

这样一来,div中显示的就是小图了,但是,显示的还不仅仅是小图,而是图中阴影部分,怎么办呢?设置一下div的宽、高,让它和小图的宽、高一样就可以了呗!!

再来看看background-position属性,它有两个参数,分别是水平方向移动的像素、竖直方向移动的像素,都用负数表示。大图不动,div移动,也只能是向右、向下移动,只要记住这两个方向移动的像素都用负数表示就行了!

因此,只要找到小图相对于大图左上角顶点的水平移动像素、竖直移动像素就可以了。小菜也不用什么专业工具,用截图就很方便,从大图左上角顶点开始截,到小图顶点那停下来,一看像素就差不多了,然后再调试调试,基本就搞定。

在本例中,A小图的位移是:-25px -374px,A小图尺寸是:24px 16px。因此,css样式如下:

1 .btn{
2     background:url(bg.png);
3     background-repeat:no-repeat;
4     background-position:-25px -374px;
5     height:16px;
6     width:24px;
7 }

效果如下:

这样就算是把小图抠出来啦!简单吧!!

先解释个问题,图片上有+1,而我又在超链上写了一个+1,这是因为很多时候文本内容不是写在图片上的,那样灵活性太差,文本就是文本,小菜为了给大家一个完整的演示,因此又写了一个+1,接下来就处理它!

先把+1居中,居中分为水平居中和垂直居中,水平居中超链接,需要在div上设置text-align:center;,这个属性是对子节点而言的;垂直居中div中的超链接,只需要把a标签的line-height属性设成和div的高度一样即可。样式如下:

 1 .btn{2     background:url(bg.png);3     background-repeat:no-repeat;4     background-position:-25px -374px;5     height:16px;6     width:24px;7     text-align:center;8 }9 .btn a{
10     line-height:16px;
11 }

效果如下:

接下来呢,还有问题,我们可以发现,只有当鼠标移到+1文本上时,鼠标才会变成手型,才能响应事件。

这显然不是我们想要的,应该是鼠标移入图片时,确切的说是鼠标移入div时,就可以变成手型,也能响应事件。

这也简单,只需要在a标签(超链接)上加display:block;属性即可。

另外这个下划线比较碍眼,用text-decoration:none;属性去掉,很常见,就不多说了。

样式如下:

 1 .btn{2     background:url(bg.png);3     background-repeat:no-repeat;4     background-position:-25px -374px;5     height:16px;6     width:24px;7     text-align:center;8 }9 .btn a{
10     line-height:16px;
11     display:block;
12     text-decoration:none;
13 }

接下来就剩最后一件事了,那就是鼠标移入的时候切换背景。

本例是div里边套a标签,鼠标移入换背景,当然是指鼠标移入div,而且换背景也是换div的背景,可不是a标签的哦!!

因此要在div标签上调用hover,div的样式是btn,因此写成.btn:hover{}。

换背景还需要找到背景图片,这又需要抠小图了,也就是抠上边指出的B图。

刚刚显示的是A小图,B小图和A小图在同一水平线上,因此竖直方向的移动像素是相同的,水平方向差不就是A小图的水平像素加上A小图的宽度。

经过测试,B小图的位移是:-50px -374px,尺寸大小就不用关心了,肯定和A小图一样,不一样就没法做了。

把B小图的定位background-position:-50px -374px;放在.btn:hover{}里即可。

 样式如下:

 1 .btn{2     background:url(bg.png);3     background-repeat:no-repeat;4     background-position:-25px -374px;5     height:16px;6     width:24px;7     text-align:center;8 }9 .btn a{
10     line-height:16px;
11     display:block;
12     text-decoration:none;
13 }
14 .btn:hover{
15     background-position:-50px -374px;
16 }

  最终效果-鼠标移入之前:

最终效果-鼠标移入之后:

好啦,教程到这就结束了,小菜只是简单的演示了一个完整的制作流程,中间还有很多细节问题,比如浏览器兼容、CSS优化等等,这就需要读者自己探索了。

其实小菜一直在说的CSS抠图,真正的技术名叫CSS Sprite技术,国人习惯叫CSS精灵。

这种技术有好处也有坏处,好处是由于图片都放在一起,请求时只需请求一张图片,减少了与服务器的交互次数,还可以解决hover延迟加载的问题。坏处就是不好控制,扩展性不太好,以后有改动,可谓是牵一发而动全身,而且有时会因为屏幕分辨率不同出现背景断裂现象。

转载于:https://www.cnblogs.com/xhqgogogo/p/3830281.html

CSS从大图中抠取小图完整教程(background-position应用)相关推荐

  1. CSS从大图中抠取小图完整教程(background-position应用) (转)

    自认为把background-position的应用讲得非常通俗易懂的教材.做个记号. 相信很多喜欢研究网页界面的童鞋都遇到过一个奇妙的现象:网页中很多图片素材被合成在一张图片上. 起初小菜模仿网站的 ...

  2. CSS从大图中抠取小图完整教程(background-position应用)【转】

    相信很多喜欢研究网页界面的童鞋都遇到过一个奇妙的现象:网页中很多图片素材被合成在一张图片上. 起初小菜模仿网站的时候,经常遇到这个现象,那时候也不知道这时什么技术,人家的整张图片素材不会利用,只能用p ...

  3. Python 确定大图中是否包含小图

    小图: 大图: 完整代码: # coding: utf-8 import os, sys import cv2 import time import win32api import win32con ...

  4. python初学者爬取数据完整教程

    都说python爬网页数据方便,我们今天就来试试,python爬取数据到底有多方便 简介 爬取数据,基本都是通过网页的URL得到这个网页的源代码,根据源代码筛选出需要的信息 准备 IDE:pyChar ...

  5. 开源题材征集 + MVCEF Core 完整教程小结

    到目前为止,我们的MVC+EF Core 完整教程的理论部分就全部结束了,共20篇,覆盖了核心的主要知识点. 下一阶段是实战部分,我们将会把这些知识点串联起来,用10篇(天)来完成一个开源项目. 现向 ...

  6. 将多张图整合到一张大图中,再用css定位技术

    2019独角兽企业重金招聘Python工程师标准>>> 以前做网站的时候,经常有地方要用小图标.第一次接触bootstrap的时候,下载打开它的源文件的时候只看到了两张图,就是包含很 ...

  7. 用java大图中寻找小图位置

    先说下思路: 因为是大图中寻找小图,所以小图必须是大图的一部分,那么对应的他们具有相同的像素点,所以为了一遍就可以搜出来,从小图中抽取若干个像素点(本次DEMO只选区了5个),从大图中找到像素与第一个 ...

  8. python获取小图在大图中的坐标和相似度

    python获取小图在大图中的坐标和相似度 模块安装:pip install aircv 大小两个图片:big.jpg,small.jpg 模块安装:pip install aircv 大小两个图片: ...

  9. python 从大图中找小图

    #python 从大图中找小图 今天突然想到这样的问题,找了一下,没找到解决方法,自己想试一试就做了一个,但是感觉太白痴,但是运行的时候也不是说要很久. #!/usr/bin/env python3 ...

最新文章

  1. java多线程之消费者生产者模式
  2. javascript async await
  3. 【测试用例】2021年逢面试必考题
  4. Android Butterknife框架 注解攻略
  5. 阿里云云防火墙全新发布,重装上阵!
  6. IMX6DL4.1.15支持EIM总线(上)——实际操作,修改内容。
  7. 前端vue经典面试题78道(重点详细简洁)
  8. 什么是ISP(网络业务提供商)?
  9. Camera 图像处理原理分析- 色彩篇 一
  10. steam无盘服务器,网吧服务器如何安装steam平台和正版游戏?
  11. 1012: 求绝对值 C语言
  12. uni-app: IPv4地址代替localhost当做项目接口请求地址,不同工作环境需要配置不同请求地址
  13. 计算机网络实验IP数据报分片,实验报告三IP数据分片.doc
  14. 计算机考试行高怎么设置,Excel隔行调整行高的四种有效方法
  15. python中frame用法_python:pandas中dataframe的基本用法汇总
  16. 电脑网易我的世界进服务器未响应,我的世界网易版进不去解决方法 MC网易电脑端进不去原因...
  17. js个人博客设计大作业
  18. Python 正则匹配以xx开头以xx结尾的单词
  19. 《SQL必知必会(第五版)》数据库导入
  20. IPTV机顶盒使用MediaPlayer 播放rtsp协议的视频

热门文章

  1. 8皇后以及N皇后算法探究,回溯算法的JAVA实现,非递归,循环控制及其优化
  2. 深度学习在CTR中的应用
  3. JavaScript中的一些细节
  4. 使用sys无法通过sqlplus或者sqldeveloper连接数据库
  5. python科学计算笔记(八)pandas大数据HDF5硬盘操作方式
  6. python学习笔记(十三)标准库heapq
  7. JVM实用参数(六) 吞吐量收集器
  8. Oracle的解惑一二to date 与24小时制表示法及mm分钟的显示
  9. 第02篇:C#星夜拾遗之Windows窗体
  10. [Amaze UI] 如何推进 mobile first 的前端 Web 方案