首先,为什么我会提出这样的方式来进行操作呢?原因还是需求导致:

  在做项目中,有这样一个需求,在进行网页中图片查看的时候,需要对图片的操作有支持旋转和缩放这些操作,看似这样的网上插件有很多,对!但是对于IE8 的支持都不行啊~~~因为虽然很多 插件可以在 IE8进行图片旋转,比如jquery的rotate.js 插件很好用,但是在IE8 下面进行旋转之后,就不能在进行缩放了,因为它会自动生成一个固定大小的object 元素,我们就不能操作这个元素了!要不就是使用canvas, 但是我的需求是在旋转了图片之后,我还能对原生的 img 图片进行大小变化等操作,以上的这些旋转后,都不是原生的对象了.......

  在进行了各种思想斗争之后,没有放弃,继续寻找方法~在网上看到了 IE filter 滤镜的方式来处理旋转,我尝试了一下,发现这样旋转之后,可以保留原生对象,很好~就打算用这样的方式来处理IE8的兼容性问题了~

 <div id="play" style="width:99%;height:99%;">
  <img id="img" src="data:images/bg.jpg" alt="Alternate Text" />
</div>
//**********************   关于IE8 兼容性的处理,使用 IE滤镜与图片旋转  START **********************
function UseIE8()
{
var browser = navigator.appName
var b_version = navigator.appVersion
var version = b_version.split(";");
var trim_Version = version[1].replace(/[ ]/g, "");
if (browser == "Microsoft Internet Explorer" && trim_Version == "MSIE6.0") {
return true;
}
else if (browser == "Microsoft Internet Explorer" && trim_Version == "MSIE7.0") {
return true;
}
else if (browser == "Microsoft Internet Explorer" && trim_Version == "MSIE8.0") {
return true;
}
return false;
}
function ro0() {
$('#img').css({ filter: 'progid:DXImageTransform.Microsoft.BasicImage(rotation=0)' });
}
//90度
function ro1() {
$('#img').css({ filter: 'progid:DXImageTransform.Microsoft.BasicImage(rotation=1)' });
}
//180度
function ro2() {
$('#img').css({ filter: 'progid:DXImageTransform.Microsoft.BasicImage(rotation=2)' });
}
//270度
function ro3() {
$('#img').css({ filter: 'progid:DXImageTransform.Microsoft.BasicImage(rotation=3)' });
}
//IE8 旋转参数
var rotate_IE8 = 0;
//********************** 关于IE8 兼容性的处理,使用 IE滤镜与图片旋转 END ********************** var imgWidth = "auto";
var imgHeight = "auto";
var rotate = 0;
var index = 0;
var imgArry;
//照片旋转
function rotateImg(size) {
//如果使用的是 IE8
if (UseIE8()) {
var res;
if (size > 0) {
rotate_IE8++;
} else {
rotate_IE8--;
}
res = rotate_IE8 % 4;//因为旋转参数都是 0,1,2,3 的值,所以需要%
if (res < 0)
{
res += 4;
}
switch (res) {
case 0:
ro0();
break;
case 1:
ro1();
break;
case 2:
ro2();
break;
case 3:
ro3();
break;
}
} else {//其他浏览器正常使用 rotate.js 进行处理
rotate += size;
var img = $("#img");
img.rotate(rotate);
}
//还原大小
$("#img").width(imgWidth);
$("#img").height(imgHeight);
}
 //放大缩小图片
function imgToSize(size) {
var img = $("#img");
var oWidth = img.width(); //取得当前图片的实际宽度
var oHeight = img.height(); //取得当前图片的实际高度
if (size < && (oWidth <= || oHeight <= )) {
return;
}
//IE8 特殊处理
if (UseIE8()) {
if (rotate_IE8 % % == ) {
//对于IE8 ,旋转次数奇数的时候 宽高互换
var t = oWidth;
oWidth = oHeight;
oHeight = oWidth;
}
}
img.width(oWidth + size);
img.height(oHeight + size / oWidth * oHeight);
}

  

IE8 下面通过滤镜的方式进行图片旋转的更多相关文章

  1. 兼容ie8 rgba()用法 滤镜filter的用法

    原文  http://blog.csdn.net/westernranger/article/details/40836861 今天遇到了一个问题,要在一个页面中设置一个半透明的白色div.这个貌似不 ...

  2. Android:通过滤镜实现点击图片变暗效果

    实现点击图片(ImageView)变暗效果,有一个较简单的方法,就是讲目标图片设置为背景图片(setBackground),再创建一个selector.xml文件,里面放置一张普通状态时的透明图片,一 ...

  3. 极验反爬虫防护分析之slide验证方式下图片的处理及滑动轨迹的生成思路

    本文要分享的内容是去年为了抢鞋而分析 极验(GeeTest)反爬虫防护的笔记,由于篇幅较长(为了多混点CB)我会按照我的分析顺序,分成如下四个主题与大家分享: 极验反爬虫防护分析之交互流程分析 极验反 ...

  4. 基于Emgucv,C#的图片旋转方式

    /// <summary> /// 图片旋转 --百度 旋转仿射 /// </summary> /// <param name="modelImage" ...

  5. PHPThumb处理图片,生成缩略图,图片尺寸调整,图片截取,图片加水印,图片旋转

    [强烈推荐]下载地址(github.com/masterexploder/PHPThumb). 注意这个类库有一个重名的叫phpThumb,只是大小写的差别,所以查找文档的时候千万注意. 在网站建设过 ...

  6. js无刷新上传图片,服务端有生成缩略图,剪切图片,iphone图片旋转判断功能

    html: <form action="<{:AppLink('circle/uploadimg')}>" id="imageform" me ...

  7. 【js】js 让图片旋转

     转http://www.cnblogs.com/ustcyc/p/3760116.html 核心: canvas.style.filter = "progid:DXImageTransfo ...

  8. flex 图片旋转(解决公转和自转问题)

    在Flex中图片的旋转是既有公转和自转的.这样在图片旋转的时候就有一定小麻烦: 为了更好地说明问题,先引入两个概念:“自转”和“公转”.想象一下,地球在绕着太阳公转的同时,它自己也在自转.Flash应 ...

  9. js实现图片旋转

    1.以下代码适用ie9版本 js代码如下: function rotate(o,p){ var img = document.getElementById(o); if(!img || !p) ret ...

随机推荐

  1. java操作特殊字符需要注意的点

    在使用字符串替换,分离时 我们如果想替换一个字符串中的问号,我们就不能直接写问号,而要写[?] 实例如下 str = str.replaceAll("\""," ...

  2. redis源码学习-dict

    1.字典相关的几个结构体 dict由hash table存储key-value, hash table数组每一个元素存放dictEntry链接的链表头结点,dictEntry节点存放key-value ...

  3. Vue + Element UI 实现权限管理系统 前端篇(九):接口格式定义

    接口请求格式定义 前台显示需要后台数据,我们这里先把前后端交互接口定义好,没有后台的时候,也方便用mock模拟. 接口定义遵循几个规范: 1. 接口按功能模块划分. 系统登录:登录相关接口 用户管理: ...

  4. JSONPath解析

    访问我的博客 前言 在工作中,经常会遇到从一串 JSON 中提取一个或多个字段的情况,常用的做法就是将其反序列化为 JSONObject 对象,然后从对象中获取,如果是 JSONArray 就进行迭代 ...

  5. SpringBoot入门 (八) Cache使用

    本文记录学习在SpringBoot中使用Cache. 一 为什么要使用缓存 缓存是一个数据交换的缓冲区,在一些条件下可以替代数据库.举个例子:我们有一个查询的业务,访问数据的频率特别高,且每次访问时的 ...

  6. rsync实现文件同步

    rsync是类unix系统下的数据镜像备份工工具,一般linux系统都自带了 [可以确认一下:shell>rpm -qa|grep rsync] 服务端:192.168.1.2  同步目录:/h ...

  7. centos7之使用最新版的kubeadm体验k8s1.12.0

    1.环境准备 centos7 .docker-ce18.06.1-ce.kubeadm.kubelet.kubectl 2.安装 yum安装,准备repo文件 docker: [docker-ce-s ...

  8. 详解lastindex,正则test()与全局匹配g偶遇,带来一会true一会false的坑

    一.简单的需求与奇怪的问题 周一接到需求文档,产品分类页的输入框,需要加一个智能下拉提醒的功能,大概就是用户输入啥,找到符合输入字段的产品名,进行下拉推荐,同时将此字段标红,有点类似于百度搜索的智能提 ...

  9. nginx权限问题failed(13:Permission denied)

    nginx权限问题failed(13:Permission denied) 环境配置  nginx Permission denied 问题: 使用nginx代理uwsgi,出现500错误,查看ngi ...

  10. 深入出不来nodejs源码-流程总览

    花了差不多两周时间过了下primer C++5th,完成了<C++从入门到精通>.(手动滑稽) 这两天看了下node源码的一些入口方法,其实还是比较懵逼的,语法倒不是难点,主要是大量的宏造 ...