项目需求:

在web端实现图片浏览,具有放大、缩小、滚轴放大缩小、移动、旋转以及范围控制。

成果图:

核心代码:

1、放大:此处放大是点击按钮,按1.5倍高宽进行放大。

                img.width = img.width *1.5;
                img.height = img.height *1.5;

2、缩小:此处缩小是点击按钮,按0.5倍高宽进行缩小。
                img.width = img.width *0.5;
                img.height = img.height *0.5;

3、旋转:此处旋转是按顺时针旋转90度。
                img.rotation = img.rotation - 90;

4、滚轴放大缩小:

--先添加滚轴监听

systemManager.addEventListener(MouseEvent.MOUSE_WHEEL, doMouseWheel);

--判断当滚轴向前或向后移动时,作出相应反应
            private function doMouseWheel(evt:MouseEvent):void
            {

                //滚轴向前,放大图片
                if(evt.delta > 0)
                {
                    img.width = img.width *1.5;
                    img.height = img.height *1.5;
                }
                else
                {
                    img.width = img.width * 0.5;
                    img.height = img.height * 0.5;                    
                }
            }

5、移动:图片查看最难的在于移动时的范围控制(不让图片超过图片查看窗口)

--首先添加鼠标按下、弹起的监听事件
            private function pan():void
            {
                img.addEventListener(MouseEvent.MOUSE_DOWN,onMouseDowns);
                img.addEventListener(MouseEvent.MOUSE_UP,onMouseUps);        
            }   

--鼠标按下、弹起响应事件(并设定范围)
            private function onMouseDowns(evt:MouseEvent):void
            {                

                //拖拽事件,在600*400的矩形范围内拖拽
                evt.currentTarget.startDrag(false,new Rectangle(0,0,600-img.width,400-img.height));
                evt.currentTarget.addEventListener(MouseEvent.MOUSE_UP,onMouseUps);
            }
            private function onMouseUps(evt:MouseEvent):void

            { 
                evt.currentTarget.stopDrag();
                evt.currentTarget.removeEventListener(MouseEvent.MOUSE_UP,onMouseUps);
            }    

--在施行这样的方法时,会出现一个bug,即鼠标按下拖拽的时候,当鼠标超出窗体时(可能是失去焦点了),即使鼠标弹起也不会触发MouseUp事件

--所以,添加一个监听,超出窗体则不执行拖拽了
            protected function bdImg_mouseOutHandler(event:MouseEvent):void
            {
                this.stopDrag();
            }

PS:需要在装image的容器外添加上Scroller ,目的是切割图片,防止图片显示超过容器部分。

<s:Scroller id="sc">
                <s:Group id="gp" height="100%" width="100%">
                    <s:Image id="img"
                                  horizontalCenter="0"
                                  verticalCenter="0"/>                
                </s:Group>            
            </s:Scroller>

Flex实现web版图片查看器的更多相关文章

  1. IIS事件查看器_WebServer事件查看器_帮助查看IIS-Web服务器事件执行日志

    IIS服务器是我们常用的Web站点部署工具,而我们有时可能遇到IIS服务器的应用程序池莫名其妙的关闭了,或者是其他未知原因等等,我们这是可以通过微软提供的WebServer(Web服务事件查看器),来 ...

  2. Win10默认图片查看器更改

    Win10自带的图片查看器不是很习惯,其背景乌漆嘛黑,宽扁的额头让人想起了黑边火腿肠手机,无法直视.怀念Win7和Win8.1的图片查看器,一个鼠标滚轮缩放自如的酸爽感觉.但却遗憾地发现,并不能直观地 ...

  3. Asp.Net Core写个共享磁盘文件Web查看器

    本篇和大家分享的是一个磁盘文件查看系统,严格来说是使用NetCore写的一个Web系统应用,由于NetCore跨平台特性,我生成了exe的运行包,只需要配置运行电脑ip+端口,即可在浏览器中通过IP+ ...

  4. 在web项目中集成pdf.js的默认查看器

    pdf.jsMozilla开源的一项用于在HTML5平台上显示pdf文档的技术,Mozilla自己的Firefox浏览器也用了pdf.js来预览pdf,可见应该是一个比较成熟稳定的方案(btw,chr ...

  5. OLE/COM 对象查看器 & OLE常用术语

    "OLE/COM Object Viewer"(OLE/COM 对象查看器)查看你系统上安装的所有 COM 对象时,是一个非常便利的工具. 它是 Windows 2000 资源套件 ...

  6. 用Qt写软件系列一:QCacheViewer(浏览器缓存查看器)

    介绍 Cache技术广泛应用于计算机行业的软硬件领域.该技术既是人们对新技术探讨的结果,也是对当前软硬件计算能力的一种妥协.在浏览器中使用cache技术,可以大幅度提高web页面的响应速度,降低数据传 ...

  7. python实现web分页日志查看

    当我们维护一个网站时,无论前台还是后台,经常会出现各种个样的问题.有时候问题很难直观的发现,这个时候只能查看各种日志来跟踪问题.但是查看日志有各种个样的问题.首先,要用各种工具登陆到服务器,这个有时候 ...

  8. 使用chrome控制台作为日志查看器

    很多时候,我们需要查看日志的实时输出,这个时候往往只能选择控制台.我这里的日志框架是serilog,它有一个好处是控制台输出时可以高亮的形式显示其参数结构信息,如下图所示 但也存在许多不方便的地方: ...

  9. Java Log Viewer日志查看器

    工欲善其事必先利其器 在投奔怒海--一个Domino老程序猿眼里的Java开发我提到眼下所做的Java开发中遇到的大量日志之问题. server控制台刷屏似地滚动,日志文件飞快地增长,debug的时候 ...

随机推荐

  1. 多种方式实现AOP

    一.使用代理工厂完成声明式增强 1.创建业务接口 public interface IdoSomeService { public void doSomething(); } 2.创建接口实现类 pu ...

  2. MySQL GROUP_CONCAT()函数 -- 字段合并查询

    在做查询的时候遇到一个问题,今天分享一下解决方法. 先看一下我想要什么效果. 清单名称类型要点,后面两列为清单步骤(外键表) 但我并不想让主表的内容重复那么多遍,于是 distinct去重.子查询.左 ...

  3. OptimalSolution(1)--递归和动态规划(2)矩阵的最小路径和与换钱的最少货币数问题

    一.矩阵的最小路径和 1 3 5 9 1 4 9 18 1 4 9 18 8 1 3 4 9 9 5 8 12 5 0 6 1 14 14 5 11 12 8 8 4 0 22 22 13 15 12 ...

  4. StackView在Android的应用

    StackView是AdapterViewAnimator的子类,它用于显示Adapter提供的一系列View.StackView将会以“堆叠”的方式来显示多个列表项.为了控制StackView现实的 ...

  5. Android H5混合开发(1):构建Cordova 项目

    Cordova是什么 Apache Cordova是一个开源的移动开发框架.允许你用标准的web技术-HTML5,CSS3和JavaScript做跨平台开发. 以移动平台为例,安卓.IOS平台设备的常 ...

  6. js如何展示上传的图片

    前言:本文章主要讲的是上传的图片如何展示在页面上. 一般来说,我们会先将本地图片上传到服务器,上传成功后,由后台返回图片的网络地址再在前端显示.但是,我今天讲的是不通过前面说的过程,而是直接使用js将 ...

  7. ABAP中将Unicode字符串转换成中文的方法

    以下为示例代码: DATA: LV_UNICODE TYPE STRING,           "Unicode字符串       LV_CHINESE TYPE STRING.      ...

  8. 前端技术之:JSON.stringfy详细说明

    JSON.stringify() 语法JSON.stringify(value[, replacer[, space]]) value 被序列化为字符串的对象 replacer 根据类型不同,其行为也 ...

  9. Scrapy爬虫day1——环境配置

    安装 Scrapy pip install scrapy 配置虚拟环境 mkvirtualenv Spider 创建项目 在Spider的虚拟环境中运行 scrapy startproject Boo ...

  10. CSPS模拟 55

    没睡醒就考试,蓝绶 考试前我在擦眼镜 好像总也擦不干净? 就像石乐志一样一直地在擦 cbx捅了我几下,好像想说什么? 没睡醒,不理 终于擦完了! 雾草要考试? T1 联 先离散化,再正面上线段树 em ...