百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

计算IE的旋转角度与滤镜详解(计算ie的旋转角度与滤镜详解的关系)

zhezhongyun 2025-03-14 22:25 29 浏览

在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);

这个效果在IE中如下所示:



假如红色的矩形是我们需要旋转的元素,蓝色矩形是旋转之后的位置,也就是说(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

{

M11

M12

}

M21

M22

  也就是

{

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%);

相关推荐

十字军之王3作弊码有哪些 王国风云3全控制台代码分享

王国风云3作弊码有什么?王国风云3游戏里我们可以使用作弊码来进行游戏,一些特别的玩法是不会少了这方面的内容的。不过具体的作弊码是很多的玩家不清楚的,为了让大家都能用游戏里的作弊码,这里就一起来看看小编...

SpringBoot的Restful的请求路径参数@PathVariable注解的使用

1.介绍1.1介绍大家都知道RESTFul风格的接口的URI路径和普通的接口是不一样的,根据RESTFul的规范请求的URI路径里需要指向一个具体的资源(Resource),这个URI路径里面可以...

Nacos源码—2.Nacos服务注册发现分析四

大纲5.服务发现—服务之间的调用请求链路分析6.服务端如何维护不健康的微服务实例7.服务下线时涉及的处理8.服务注册发现总结7.服务下线时涉及的处理(1)Nacos客户端服务下线的源码(2)Nacos...

JavaScript矩阵快速计算方法(如何用java计算矩阵相乘)

有很多方法可以在JS中表示矩阵数学。有些方法可读性强,有些方法速度快。我想探索一下这些差异。某些技术实际上能为我节省多少时间?为此,我将只研究一个操作:逐元素加法以减少总案例数,但差异操作可能会稍...

如何在前端通过JavaScript创建修改CAD图形

背景在之前的博文CAD图DWG解析WebGIS可视化技术分析总结、CAD_DWG图Web可视化一站式解决方案-唯杰地图-vjmap中讲解了如何把CAD的DWG格式的图纸Web可视化的方案,那在Web前...

如何写一个webpack插件(一)(webpack插件怎么写)

前言最近由于用着html-webpack-plugin觉得很不爽,于是乎想自己动手写一个插件。原以为像gulp插件一样半天上手一天写完,但令人郁闷的是完全找不到相关的文章。一进官方文档却是被吓傻了。首...

如何用Go写一个benchmark 解析器及Web UI 数据可视化?

简介用Go编写的benchmark输出解析器,功能如下读取gotest-bench=.-benchmem的输出文件(如benchmark.txt)解析出每行数据写入成CSV文件...

k8s实践(八):ConfigMap and Secret

一、概述1.ConfigMap在实际的应用部署中,经常需要为各种应用/中间件配置各种参数,如数据库地址、用户名、密码等,而且大多数生产环境中的应用程序配置较为复杂,可能是多个Con...

前端最常用的25个正则表达式,代码效率提高 80%

在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。在日常开发中,了解一些常用的正则表达式,能大大提高你的工作效率,例如字符串的匹配表单项的格式校...

游戏《重返德军总部》秘籍代码大全完全版简要分享

重返德军总部这款游戏当中为玩家们带来了很多非常经典熟悉的秘籍作弊码,玩家们可以通过在游戏当中使用这些秘籍作弊码更好的体验到游戏当中的精彩内容,感兴趣的小伙伴就和小编在下面一起来看看吧。重返德军总部秘籍...

32个手写JS,巩固你的JS基础(面试高频)

01.数组扁平化数组扁平化是指将一个多维数组变为一个一维数组constarr=[1,[2,[3,[4,5]]],6];//=>[1,2,3,4,5,6]复制代码...

golang常用数据结构之map详细讲解

概述map是常见的一种数据结构,大部分编程语言都有,用于存储一系列无序的键值对,map也被称为字典或关联数组,顾名思义,键相当于索引,通过键与值形成映射关系,达到快速查找数据的目的。声明和初始化var...

MapStruct 常用的重要注解和方法(mapstruct详解)

MapStruct是一个Java代码生成器,用于简化Java对象之间的映射操作。它通过注解和方法来定义映射规则。以下是MapStruct中常用的重要注解和方法:注解1.@Mapper:用于标记一个接...

Java对象中非空属性一键转Map,让你的代码飞起来

哈喽,大家好,我是木头左!引言在日常开发中,经常会遇到需要将一个Java对象中的非空属性提取出来,放到一个Map中的情况。这样的做法有很多好处,比如方便进行属性的查找、修改等操作,同时也能够提升代码的...

在Kubernetes中使用ConfigMap(kubectl set env)

在《为Kubernetes安装Dashboard》中,我们已经使用VirtualBox安装了CentOS7.9,并在其上安装了Docker20.10.11、Kubernetes1.23.3和ku...