在IE中使用CSS3的旋转效果是不能实现的,,但是我又想把IE旋转效果跟其他浏览使用CSS3 rotate(deg)一样。在百度找了一下,发现IE里面有一款滤镜,可以实现旋转角度。

代码如下:

filter: progid:DXImageTransform.Microsoft.Matrix(sizingMethod='auto expand', M11=0.70710678, M12=-0.70710678, M21=0.70710678, M22=0.70710678);  

假如红色的矩形是我们需要旋转的元素,蓝色矩形是旋转之后的位置,也就是说(0,1)和(1,0)这两个坐标旋转a角之后变成了(x,y)和(m,-n),我们只要知道他们的变换关系就好。那么(x,y)和(m,-n)可以用简单的三角函数算出得到(sin(a),cos(a))和(cos(a),-sin(a))。把这个结果代入单位矩阵中得到

{    m    -n    }  
 x    y  
也就是  
{    cos(a)    -sin(a)    }  
 sin(a)    cos(a)  
假如a是45°就可以得到如下值。  
{    0.707    -0.707    }  
 0.707    0.707  

sin()  cos()  可在自己电脑上打开计算器进行计算。如下图计算了一个45度后的sin值。  

其实旋转完了还是有些问题的存在。问题就是元素旋转了IE和FF的中心点不一样了。IE偏离了中心点,为了解决这个问题还是要计算一下。我们先要计算出它旋转后的大小,然后就能知道它旋转后大小的增量,偏移量就是这个增量的一半。公式:

W=|sin(a)\*h|+|cos(a)\*w|,H=|sin(a)\*w|+|cos(a)\*h|  

我这个元素的宽高都是200px…那么旋转后282这样。增量就是82.。。偏移量就是增量的一半那就是41.。。所以加这个属性margin:-41px;….不这个属性只是针对IE。。
所以Ie8:

margin:-41px\\0;        ie7  : *margin:-41px;        ie6:margin:-41px;  

有些在IE中不能实现CSS3样式效果,可以使用IE的滤镜来实现

IE滤镜

Alpha:设置透明层次.   
blur:创建高速度移动效果,即模糊效果.   
Chroma:制作专用颜色透明.   
DropShadow:创建对象的固定影子.   
FlipH:创建水平镜像图片.   
FlipV:创建垂直镜像图片.   
glow:加光辉在附近对象的边外.   
gray:把图片灰度化.   
invert:反色.   
light:创建光源在对象上.   
mask:创建透明掩膜在对象上.   
shadow:创建偏移固定影子.   
wave:波纹效果.   
Xray:使对象变的像被x光照射一样.  

W3C滤镜

grayscale 灰度  
sepia 褐色  
saturate 饱和度  
hue-rotate 色相旋转  
invert 反色  
opacity 透明度  
brightness 亮度  
contrast 对比度  
blur 模糊  
drop-shadow 阴影  

滤镜:透明效果

语法:
filter:Alpha(Opacity=opacity,FinishOpacity=finishopacity,Style=style,StartX=startX,StartY=startY,FinishX=finishX,FinishY=finishY)
说明:
Opacity:起始值,取值为0~100, 0为透明,100为原图。
FinishOpacity:目标值。
Style:1或2或3
StartX:任意值
StartY:任意值
FinishX:任意值
FinishY:任意值

一般透明效果:filter:alpha(opacity=30);  

W3C代码:-webkit-filter:opacity(0.3); 或 opacity:0.3;  

线型透明:filter: alpha(Opacity=0, FinishOpacity=100, Style=1, StartX=0, StartY=0, FinishX=200, FinishY=180);  

放射透明:filter: Alpha(Opacity=0, FinishOpacity=100, Style=2);  

柔光效果filter:alpha(opacity=100, finishOpacity=0,style=3);  

滤镜:投影效果

语法:
filter:DropShadow(Color=color, OffX=offX, OffY=offY, Positive=positive)
说明:
Color:#rrggbb格式,任意。
Offx:X轴偏离值。
Offy:Y轴偏离值。
Positive:如果为”True”为任何的非透明像素建立可见的投影.如果为”False”,为透明的像素部分建立可见的投影。

投影效果:filter:progid:dXImageTransform.Microsoft.DropShadow(color=#000000,offX=5,offY=5,positives=true);  

W3C代码:-webkit-filter:drop-shadow(5px 5px 0 #000000); 或 box-shadow:5px 5px 0 #000;  

阴影效果:progid:DXImageTransform.Microsoft.Shadow(color=#000000,direction=135,strength=10);  

虑色效果:progid:DXImageTransform.Microsoft.Chroma(color=#59A074);  

马赛克:filter:progid:dXImageTransform.Microsoft.Pixelate(maxsquare=3);  

发光效果:filter:progid:dXImageTransform.Microsoft.Glow(color=#000000,Strength=5);  

水平翻转:filter: fliph;  

W3C代码:-webkit-transform:rotateY(180deg);  

垂直翻转:filter: flipv;  

W3C代码:-webkit-transform:rotateX(180deg);  

反色效果:filter: invert;  

W3C代码:-webkit-filter:invert(1);  

黑白效果:filter:gray;  

W3C代码:-webkit-filter:grayscale(1);  

X光照片:filter:xray;  

W3C代码:-webkit-filter:grayscale(1) invert(1);  

滤镜:模糊效果

语法:
filter:Blur(Add = add, Direction = direction, Strength = strength)
说明:
Add:指定图片是否被改变成印象派的模糊效果.1为真,0为假。
Direction:角度,0~315度,步长为45度。
Strength:有多少像素的宽度受到模糊影响,默认是5个像素。

风动模糊(有角度):filter: blur(add=true,direction=45,strength=30);  

一般模糊:filter:progid:DXImageTransform.Microsoft.Blur(pixelradius=7);  

W3C代码:-webkit-filter:blur(3px);  

滤镜:波纹效果

语法:
filter: Wave(Add=add,Freq=freq,LightStrength=strength,Phase=phase, Strength=strength)
说明:
Add:是否打乱,默认是”True”。
Freq:产生多少个完整的波纹。
LightStrength:增强光影,0-100的整数值。
Phase:正弦波的偏移量,通常值为0,范围是0-100的整数值。
Strength:代表振幅大小。

正弦波纹:filter: Wave(Add=0, Freq=60, LightStrength=1, Phase=0, Strength=3);  

渐变效果:filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=0, StartColorStr="#000000", EndColorStr="#ffffff");  

W3C代码:background:-webkit-linear-gradient(#000000 0, #ffffff 100%);