javascript仿新浪微博图片放大缩小及旋转效果

经常看到新浪微博里有图片放大缩小旋转效果,感觉效果还不错,所以就想试着做一个类似的demo出来,至于旋转对于IE可以用滤镜来解决,标准的浏览器可以用html5中的canvas画布来解决。

思路:1.点击小图后,小图隐藏掉,在小图父级元素后增加一张大图且显示出来。

2.点击往左转,往右转触发旋转方法。

3. 点击收起按钮,把1的步骤反过来 隐藏大图 显示小图。

4. 点击查看原图功能 目前没有做成js灯箱效果,直接打开一个新连接。但是如果想做成灯箱效果的话,可以看我这篇博客,灯箱效果演示

我们可以先来看看JSFiddler效果吧!

嘿嘿,看效果请点击我!

实现思路:

1. 对于第一点 小图隐藏 大图显示这个可以不用说的。

2. 对于旋转:IE用滤镜解决,如:img.style.filter = 'progid:DXImageTransform.Microsoft.BasicImage(rotation=' + s + ')'; 标准浏览器可以用canvas+旋转

代码中用了一个图片预加载,想要了解图片预加载的话 可以看这篇文章  "图片预加载"  还用了一个图片等比例缩放 想了解等比例缩放的话 可以查看 "等比例缩放图片"

下面是所有的JS源码,大家有空可以看看,如果有更好的思路的话,可以提意见,一起交流下。

/**
* 缩略图
*/
function ArtZoom(options,callback){
var self = this;
self.options = $.extend({},defaults,options || {});
self._init();
self.callback = callback;
this.cache = {
minStep : 0,
maxStep : 3
};
};
$.extend(ArtZoom.prototype,{ // 初始化
_init: function(){
var self = this,
cfg = self.options; if($(cfg.targetCls).length <= 0) {
return;
}
$(cfg.targetCls).each(function(){
$(this).unbind('click').bind('click',function(e){
e.preventDefault();
var maxImage = $(this).attr('href');
self._imgTool($(this),maxImage);
});
});
},
/*
* 点击小图变大图 先隐藏小图 再生成大图显示
* @param {$this,maxImage} 当前点击的元素 当前大图
*/
_imgTool: function($this,maxImage) {
var self = this,
cfg = self.options;
var width = 0,
height = 0,
maxWidth = $this.closest(cfg.parentCls).outerWidth(); // 图片预先加载
var loadImg = function (url, fn) {
var img = new Image();
img.src = url;
if (img.complete) {
fn.call(img);
} else {
img.onload = function () {
fn.call(img);
};
};
};
loadImg(maxImage, function () {
width = this.width;
height = this.height;
tool();
});
function tool(){ var $thisParent = $($this).closest(cfg.parentCls);
// 当前图片隐藏掉
$this.hide();
if($('.artZoomBox',$thisParent).length > 0 && $('.artZoomBox',$thisParent).css('display') == "none"){
$('.artZoomBox',$thisParent).show();
}
// 图片等比例缩放
if (width > maxWidth) {
height = maxWidth / width * height;
width = maxWidth;
};
// 页面只创建一次
if($('.artZoomBox',$thisParent).length <= 0) {
var html = '<div class="artZoomBox">'+
'<div class="tool">'+
'<a class="hideImg" href="#" title="收起">收起</a>'+
'<a class="imgRight" href="#" title="向右转">向右转</a>'+
'<a class="imgLeft" href="#" title="向左转">向左转</a>'+
'<a class="viewImg" href="' + maxImage + '" title="查看原图">查看原图</a>'+
'</div>'+
'<a href="'+maxImage+'" class="maxImgLink">'+
'<img class="maxImg" width="'+width+'" height="'+height+'" src="'+maxImage+'"/>'+
'</a>'+
'</div>';
$($thisParent).append(html);
} $('.artZoomBox',$thisParent).find('a').unbind('click').bind('click',function(e){
e.preventDefault();
var $this = $(this),
$parent = $(this).closest(cfg.parentCls);
var box = $('.artZoomBox',$parent);
// 收起
if($($this).hasClass('hideImg') || $($this).hasClass('maxImgLink')) {
box.hide();
box.prev().show();
self.destory($this);
};
// 左旋转
if($($this).hasClass('imgLeft')) {
var target = box.find('.maxImg');
self._rotate(target,'left', width)
};
// 右旋转
if($($this).hasClass('imgRight')) {
var target = box.find('.maxImg');
self._rotate(target,'right', width);
};
// 新窗口打开
if($this.hasClass('viewImg')){
window.open(maxImage);
}
}); }
},
/*
* 图片旋转
* @param {target,direction,width} 要旋转的元素,方向, 旋转元素的宽度
*/
_rotate: function(target,direction,width){
var self = this,
cache = self.cache; var img = $(target)[0],
step = img.getAttribute('step');
if(img.length <= 0) {
return;
}
if (step == null) {
step = cache.minStep;
}
var width = img.width,
height = img.height;
if(direction == 'left') {
step--;
if(step < cache.minStep) {
step = cache.maxStep;
}
}else if(direction == 'right') {
step++;
if(step > cache.maxStep) {
step = cache.minStep;
}
}
img.setAttribute('step', step);
// IE
if(navigator.userAgent.indexOf('MSIE') >= 0) {
var s = $(img).attr('step');
img.style.filter = 'progid:DXImageTransform.Microsoft.BasicImage(rotation=' + s + ')';
img.width = width;
img.height = height;
}else { // 对于现代浏览器 使用canvas
var canvas = $(img).next('canvas')[0];
if ($(img).next('canvas').length == 0) {
img.style.display = 'none';
canvas = document.createElement('canvas');
canvas.setAttribute('class', 'canvas');
img.parentNode.appendChild(canvas);
}
//旋转角度以弧度值为参数
var degree = step * 90 * Math.PI / 180;
var ctx = canvas.getContext('2d');
switch (step) {
case 0:
canvas.width = width;
canvas.height = height;
ctx.drawImage(img, 0, 0);
break;
case 1:
canvas.width = height;
canvas.height = width;
ctx.rotate(degree);
ctx.drawImage(img, 0, -height);
break;
case 2:
canvas.width = width;
canvas.height = height;
ctx.rotate(degree);
ctx.drawImage(img, -width, -height);
break;
case 3:
canvas.width = height;
canvas.height = width;
ctx.rotate(degree);
ctx.drawImage(img, -width, 0);
break;
}
}
$(target).attr("step",cache.step);
self.callback && $.isFunction(self.callback) && self.callback(cache.step);
},
/*
* 销毁
*/
destory: function($this){
var self = this,
cfg = self.options;
var curParent = $this.closest(cfg.parentCls),
canvas = $('.canvas',curParent),
maxImg = $('.maxImg',curParent); if(navigator.userAgent.indexOf('MSIE') >= 0) {
// IE
$(maxImg)[0].style.filter = 'progid:DXImageTransform.Microsoft.BasicImage(rotation=0)';
$(maxImg).attr('step',0);
}else{
if(canvas.length > 0) {
canvas.remove();
maxImg.show();
$(maxImg).attr("step",0);
}
}
}
});
var defaults = {
targetCls : '.artZoom',
parentCls : '.parentCls' // 当前元素最近的父元素的class
};

demo下载

HTML代码如下:

<li class="parentCls">
<a class="artZoom" href="http://m1.img.srcdd.com/farm5/d/2014/0718/21/EDEF32A674C1217FB6F80851514C124E_B250_400_250_278.jpeg">
<img src="http://m1.img.srcdd.com/farm4/d/2014/0718/21/31789C10D628913054C9B7F3A11D3519_B250_400_150_108.jpeg" /></a> </li>

其中父类 增加配置元素 parentCls ,当前大图链接写在href属性里面。

javascript仿新浪微博图片放大缩小及旋转效果的更多相关文章

  1. 鼠标滚轮图片放大缩小功能,使用layer弹框后不起作用

    今天在项目中遇到的一个问题:点击按钮使用layer弹框弹出一张图片,需要加一个鼠标滚轮放大缩小,图片也跟着放大缩小的功能.于是在网上找了一个demo. DEMO: <!DOCTYPE html ...

  2. hammer使用: 代码:捏合、捏开、图片放大 的一个手机图片“放大缩小可拖动”的小效果

    hammer.js 的使用. (手机手势插件) 捏合.捏开.图片放大 的一个手机图片“放大缩小可拖动”的小效果. 相关js 到 http://www.bootcdn.cn/  查找和下载. hamme ...

  3. jQuery练手:仿新浪微博图片文字列表淡进淡出上下滚动效果

    1.效果及功能说明 仿新浪微博图片文字列表上下淡进淡出间歇上下滚动 2.实现原理 首先要设定div内只能显示4个图片那么多出来的图片会自动隐藏然后在给图片添加一个动画的事件让他们可以滚动的播放出来上下 ...

  4. vue项目 一行js代码搞定点击图片放大缩小

    一行js代码搞定xue项目需要点击图片放大缩小,其实主要用的是用到了vue:class的动态切换,内容比较简单.一开始我把维护的需求想得太复杂了,和测试小姐姐聊了一下才反应过来. 两个月不到跟了四个项 ...

  5. 自定义mousewheel事件,实现图片放大缩小功能实现

    本文是承接 上一篇的<自定义鼠标滚动事件>  的基础上实现的,建议大家先看一下上一篇的mousewheel的实现,再浏览下文: 上篇中我们介绍到: $element.mousewheel( ...

  6. imageView图片放大缩小及旋转

    imageView图片放大缩小及旋转 一.简介 二.方法 1)设置图片放大缩小效果 第一步:将<ImageView>标签中的android:scaleType设置为"fitCen ...

  7. wpf下的图片放大缩小

    WPF下实现图片的放大缩小移动   在windows 7里面有自带的图片查看器,这个软件可以打开一张图片然后以鼠标在图片中的焦点为原点来进行缩放,并且放大后可以随意拖动.下面我们在WPF中实现这个功能 ...

  8. Canvas实现图片放大缩小移动操作

    对于HTML5相信大家都不陌生,很早就出来了,但是貌似都没有真正的使用过.最近做项目时要实现这样一个需求:一个图片,大小不固定,要求能实现类似地图一样放大.缩小.移动功能.这里就很合适使用html5的 ...

  9. 41.Android之图片放大缩小学习

    生活中经常会用到图片放大和缩小,今天简单学习下. 思路:1.添加一个操作图片放大和缩小类;  2. 布局文件中引用这个自定义控件;  3. 主Activity一些修改. 代码如下: 增加图片操作类: ...

随机推荐

  1. mysql建表以及列属性

    一.整型( int, tinyint, smallint 等 ) ------------------------------------------------------------------- ...

  2. python学习之老男孩python全栈第九期_day004知识点总结

    1. 列表list: 列表转换成字符串: s = 'kidd' s1 = '_'.join(s) # 用_连接 字符串转换成列表: split() range(头,尾,步长): [0,1,2,3,4, ...

  3. python中read()、readline()、readlines()函数

    python文件读read().readline().readlines()对比   目录 一.read方法 二.readline方法 三.readlines方法 正文 读取文件的三个方法:read( ...

  4. SQLServer 学习笔记之超详细基础SQL语句 Part 2

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 1------------------- 建立如下数据表 CREATE ...

  5. JSTL、JSTL核心标签库——流程处理标签

    JSTL环境 JSTL是另一个标准规范,并非在JSP的规范中,所以必须另外下载JSTL实现. 要使用JSTL标签库,必须在JSP网页上使用taglib指示元素定义前置名称与uri参考.例如,引入JST ...

  6. python编写脚本

    #!/usr/bin/env python #-*- coding:utf-8 -*- import sys import os from subprocess import Popen,PIPE c ...

  7. python的类基础

    python类的基础: 1,面向对象的基本概念 类(Class): 用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例. 类变量:类变量在整个实例化的 ...

  8. windows7环境下使用pip安装MySQLdb for python3.7

    1.首先,需要确定你已经安装了pip.在Python2.7的安装包中,easy_install.py和pip都是默认安装的.可以在Python的安装目录先确认,如果\Python37\Scripts里 ...

  9. [Spark Core] Spark Client Job 提交三级调度框架

    0. 说明  官方文档  Job Scheduling Spark 调度核心组件: DagScheduler TaskScheduler BackendScheduler 1. DagSchedule ...

  10. MySQL面试题36道

    MySQL数据库是在免费的数据库中最受欢迎的一款,尤其是在一些小型项目以及项目资金有限的情况下,选择MySQL来作为数据存储的工具,那些不差钱并且数据吞吐量非常大的互联网公司一般都是会用付费的Orac ...