项目要求需要用js实现同时放大多张图片相对位置不变,就和同事去一家国外网站的js文件中跟踪扒取了这一算法,

庆幸的是算法抠出来了并整理了出来,但遗憾的只知计算过程却弄不明白算法原理:

大体上是核心运算将图片的中心点和画布(外层div)中心点的差和放大倍数针对矩阵[1.0000000000000002,-0,-0,1.0000000000000002]

(这个矩阵是由[1,0,01]经过一系列计算得出的一个固定矩阵)做了两次运算:(如果大家懂得其中计算原理,希望能分享一下)

/// <reference path="Scripts/jquery-1.4.1.min.js" />

//参数:canvas画布的id,img图片外层div的class值)

function ZoomBig(canvasId,imgDivClass) {

Canvas.zoom(canvasId,imgDivClass,1.25);

}

function ZoomSmall(canvasId, imgDivClass) {

Canvas.zoom(canvasId,imgDivClass,0.8);

}

//--

function Canvas() {

}

//--入口函数:

Canvas.zoom = function (canvasId,imgDivClass,c) {

//初始化

//canvas

cvW = TranNum($("#" + canvasId).css("width"));

cvH = TranNum($("#"+ canvasId).css("height"));

//Canvas

_items = $("#" + canvasId).find("[class='"+imgDivClass+"']");

//计算

if (c == 1) {

return

}

var b = this.getCanvasSize();

var a = new Point(b.w / 2, b.h / 2);

var d = new Point(c, c);

$.each(_items, function (f) {

//pro

proW = TranNum($(this).css("width"));

proH = TranNum($(this).css("height"));

proT = TranNum($(this).css("top"));

proL = TranNum($(this).css("left"));

//pro中心点到pro四条边的距离left,bottom,right,top

x1 = -1 * proW / 2;

x2 = proW / 2;

y1 = -1 * proH / 2;

y2 = proH / 2;

//中心点到画布的top.left值:

translation = new Point(x2 + proL, y2 + proT);

//

setScale(d, a)//放大倍数坐标,画布中间点

$(this).css({ "left": round(x1 + translation.x, 0.001).toString() + "px", "top": round(y1 + translation.y, 0.001).toString() + "px" });

$(this).css({ "width": Math.abs((x1 * 2)).toString() + "px", "height": Math.abs((y1 * 2)).toString() + "px" });

$(this).find("img").css({ "width": Math.abs((x1 * 2)).toString() + "px", "height": Math.abs((y1 * 2)).toString() + "px" });

});

};

//--Tool

function TranNum(a) {

return parseFloat(a.replace("px", ""));

}

//

function Point(a, b) {

this.x = a;

this.y = b

}

//

Canvas.getCanvasSize = function () {

return new Dim(parseInt(cvW, 10), parseInt(cvH, 10))

};

//

function Dim(a, b) {

this.w = Math.abs(a);

this.h = Math.abs(b);

this.aspect = b / a

}

//--

setScale = function (c, a) {//,倍数, 画布中心点

beginResize();

scale(c, a); //,倍数.画布中心点

// return endResize()

};

//

beginResize = function () {

this.rectStart = clone();

this.translationStart = new Point(translation.x, translation.y);

};

//

clone = function () {

return new Rect(x1,y1,x2,y2)

};

//

function Rect(b, d, a, c) {

this.x1 = b || 0;

this.y1 = d || 0;

this.x2 = a || 0;

this.y2 = c || 0

}

//

scale = function (c, a, d, b) {

this._scale(c, a, b);

};

//

_scale = function (c, a, f) {////,倍数,画布中心点

if (f === undefined) {

f = true;

}

this.rect = clone();

x1 *= c.x;

y1 *= c.y;

x2 *= c.x;

y2 *= c.y;

if (a) {

_values=[1.0000000000000002,-0,-0,1.0000000000000002];//对[1,0,0,1]做了些计算得出的;

var b = transform(a.x -translationStart.x, a.y -translationStart.y);

var d =transform(c.x * -b.x, c.y * -b.y);

translation.x = d.x + a.x;

translation.y = d.y + a.y

} else {

translation.x = translationStart.x * c.x;

translation.y = translationStart.y * c.y

}

};

//

transform = function (b, d, a) {//两中心x差,两中心y差

if (a) {

b -= a.x;

d -= a.y;

}

var c = new Point(_values[0] * b + _values[1] * d, _values[2] * b + _values[3] * d);

if (a) {

c.x += a.x;

c.y += a.y

}

return c

};

function round(b, a) {

a = a || 1;

if (a > 1) {

return Math.round(b / a) * a

} else {

a = 1 / a;

return Math.round(b * a) / a

}

}

js实现多张图片同时放大缩小相对位置不变的更多相关文章

  1. JS的className,字体放大缩小

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  2. java:JQuery(声明,JQ和JS对象的区别,prop,attr,addClass,offset,trigger,dblclick和change事件,hide,show,toggle,slideUp,slideDown,slideToggle,三种选择器,标签的获取,三张图片的放大与缩小)

    1.JQuery: jQuery是一个快速.简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架).jQuery设计 的宗旨是“ ...

  3. scrollview里面多张图片,每张都能放大缩小

    http://blog.sina.com.cn/s/blog_5d68044001018s1n.html scrollview里面多张图片,每张都能放大缩小 - (void)viewDidLoad{  ...

  4. js判断页面放大缩小

    项目中,经常会碰到页面被放大或者缩小,导致页面显示错误,js可以判断页面放大缩小. // 若返回100则为默认无缩放,如果大于100则是放大,否则缩小 function detectZoom (){ ...

  5. JS中图片的放大缩小没反应

    这段代码无反应: 代码如下: <script type="text/javascript"> onload = function () { document.getEl ...

  6. js监听页面放大缩小

    <!DOCTYPE html><html> <head> <meta charset="utf-8"> <title>d ...

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

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

  8. JS微信网页使用图片预览(放大缩小)

    前言 需求在微信网页中客户点击图片可进行预览放大缩小功能,网上找了各种js方式实现, 唯一的麻烦就是不兼容或者和项目框架不兼容 次函数只只用于部分客户端,否则会出现 WeixinJSBridge is ...

  9. JS控制图片拖动 放大 缩小 旋转 支持滚轮放大缩小 IE有效

    <html> <head>     <title>图片拖动,放大,缩小,转向</title> <script type="text/ja ...

随机推荐

  1. win8 iis7/iis8 安装、卸载、设置方法

    原文:win8 iis7/iis8 安装.卸载.设置方法 一.安装 自从升级到Win8之后,之前使用已经趋于熟悉的iis7.0被取而代之的是iis8.0,那么安装和获取方法也就产生的略微的变化,为了避 ...

  2. Visual FoxPro 6.0~9.0解决方案和实例文档和CD写入原件下载

    自从微软宣布开发冻结Visual FoxPro之后,这样的图书出版已经成为一个问题,但仍有不少VFP小贴士.处处留心此8历史书.在此提供写作的原稿.它看起来非常舒服比扫描版淘宝.下载链接:http:/ ...

  3. Ohloh研究报告

    1.底       由于近期接合ospaf同样是一个开源项目的成熟度分析工具,由于该项目现在Ohloh我们有共同的东西,这么ohloh我们进行了调查.       简单的说,初始ohloh是一个代码搜 ...

  4. or1200乘法除法指令解释

    以下摘录<步骤吓得核心--软-core处理器的室内设计与分析>一本书 OR1200中乘法除法类指令共同拥有9条,表8.3给出了全部的乘法除法类指令的作用及说明. 说明:表8.3是ORBIS ...

  5. ASP.NET MVC5 插件机制中插件的简单实现

    Autofac 依赖注入 ASP.NET MVC5 插件机制中插件的简单实现 一.前言 由于项目业务复杂,创建了多个插件并把他们放在了不同的项目中,项目使用AutoFac做的IOC:但是主项目可以注入 ...

  6. python基础课程_学习笔记21:文件和材料

    文件和材料 打开文件 open功能是用来打开文件,语法例如,下面的: open([name[,mode[,buffering]]) open函数使用一个文件名称作为唯一的强制參数,然后返回一个文件对象 ...

  7. HDU 1203 I NEED A OFFER!(dp)

    Problem Description Speakless很长时间,我想出国.现在,他已经完成了所有需要的检查.准备好所有要准备的材料,于是,便须要去申请学校了.要申请国外的不论什么大学.你都要交纳一 ...

  8. [Python 2.7] Hello World CGI HTTP Server

    # CGI HTTP server ## Getting Started Python 2.x is preferred to this simple demo. I'm using Python 2 ...

  9. 经典算法题每日演练——第七题 KMP算法

    原文:经典算法题每日演练--第七题 KMP算法 在大学的时候,应该在数据结构里面都看过kmp算法吧,不知道有多少老师对该算法是一笔带过的,至少我们以前是的, 确实kmp算法还是有点饶人的,如果说红黑树 ...

  10. 宽客的人&amp;&amp;事件映射

    看完<宽客>这本书,叙事介绍20世纪华尔街对冲基金.股票.投资者依赖股市从直觉交易数学家的早期演化.物理学家用数学模型开发过程中的交易,这些进入金融数学家.物理学家依靠大数据分析.稍纵即逝 ...