日期:2014-05-17  浏览次数:20713 次

CSS背景图坐标定位详解,为什么会有负数?
背景图像定位中我们要明确的几点:
   
  1、两个值前面一个是横向的定位,我们称为x轴方向定位。后面一个值是纵向的定位,我们称为y轴方向定位。如果只有一个值,那默认的就是x轴方向,这时y轴方向就默认的是上下居中对齐,也就是center。
  2、坐标轴的原点就是对应容器的左顶点。

  3、这个坐标的y轴箭头朝下,也就是右下方(容器内部)x y的值才都为正。

  4、x y值分别表示背景图片的左顶点相对于坐标原点(也就是容器的左顶点)的值。

  5、x y的值可以用百分比或者px来表示。

  6、x y也可以用“left、right、top、bottom、center”这五个对齐方式来表示,但注意:用“left、right、top、bottom、center”来表示的时候,应用的是对齐规则,而不是坐标规则。x为left是表示图片的左边和容器的左边对齐,为right的时候表示图片的右边和容器的右边对其,y为top的时候表示图片的顶部和容器的顶部对齐,为bottom时表示图片的底部和容器的底部对齐,x y等于center的时候表示居中对齐。

  7、x y用百分比或者px表示的时候,其值可以为负数。我们应用坐标规则就很容易理解负数表示的意义,x为负数时候表示图片左顶点在容器左顶点的左侧,y为负数时表示图片的左顶点在容器的左定点的上方。也就是向左和向上超出容器的范围。
   
  下面我用几个图示来说明一下几种情况,蓝色块表示图片,虚线框表示容器(可以div,td,或者直接就是body),注意只有背景图片在容器内我们才能看见,我用白色表示可见部分,而且超出容器范围的是看不见的,我用灰色表示。容器的左定点的坐标就是(0,0)。
   
  第一张,背景图片和容的左上对齐,0px 0px 也可以写成left top
 
  第二张,背景图在容器中间,定点坐标为正值
   
  第三张,背景图部分在容器左上,定点坐标为负值
 
   
  到此我们可能就明白了如何用background里的定位值来准确定位一个背景图片,返回去我们看一下开始的时候介绍的两个图片,我们就是可以用:背景定位和容器内才可见这两个性质来随意的调用整张图片的某一部分。
   
  但是我们为了调用方便,在排列这些小图片的时候要讲究一点规则,比如:小图之间的距离通常是调用小图的容器的大小,或者距离更大一点,这样就可以避免在容器内显示出我们不愿意显示的图片!
   
  补充一点,如果定位用的是百分比话,算法比较特殊。我举个例子:
   
  代码:
  
  background:#FFF url(image) no-repeat fixed 50% -30%;
   
  这个时候图片应该在容器的什么位置呢,算法公式如下:
   
  图片左顶点距容器左顶点的坐标位置为 

  x:(容器的宽度-图片的宽度)x50% 

  y:(容器的高度-图片的高度)x(-30%) 

  得到的结果应用坐标法则,差值如果为负数,百分比为正那么运算结果是负值。如果差值为负数,百分比也为负数,那么运算结果就是正数。总而言之就是这里的运算符合运算法则。把运算的结果带入坐标法则就能得到图片的位置。 
   
  比如:容器是width:600px;height:600px;而图片是width:200px;height:200px; 

  我们用上面的样式,可以得到图片位置为: 

  x:(600px-200px)*50% 

  y:(600px-200px)*(-30%) 

  如下图:
 
 

------解决方案--------------------
没人理你,把分给我吧!