div內(nèi)部實現(xiàn)圖片旋轉(zhuǎn)、放大呵萨、縮小奏属、拖拽

在開發(fā)中這樣一個場景,web應(yīng)用程序某處功能會接收來自各個戶上傳的圖片潮峦,后臺有個圖片查看功能囱皿,實際生產(chǎn)過程中的結(jié)果出現(xiàn)了用戶上傳的圖片是倒轉(zhuǎn)的或者圖片因為遠(yuǎn)距離拍攝上傳的比較模糊的情況勇婴。

1、解決圖片角度的問題

大概原理很簡單嘱腥,切換HTML元素對象(圖片)的class耕渴。如下CSS代碼:

.rot1{transform:rotate(90deg); filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=1);}
.rot2{transform:rotate(180deg); filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);}
.rot3{transform:rotate(270deg); filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=3);}

再添加簡單的JavaScript代碼——根據(jù)是向左轉(zhuǎn)還是向右轉(zhuǎn)動態(tài)改變class的名稱就行了。再次提示下齿兔,IE8瀏覽器是使用的是-ms-filter直接filter沒有效果橱脸。
這里使用的是CSS3+filter濾鏡的方法,所以低版本的Firefox以目前版本的Opera瀏覽器下式?jīng)]有效果的分苇。但絕對適用于90%以上的互聯(lián)網(wǎng)用戶了添诉。

2、圖片放大縮小

即為調(diào)整圖片的寬和高医寿。如下核心代碼

//放大縮小圖片
        function imgToSize(size) {
            var img = $("#rotImg");
            var oWidth = img.width(); //取得圖片的實際寬度
            var oHeight = img.height(); //取得圖片的實際高度

            img.width(oWidth + size);
            img.height(oHeight + size / oWidth * oHeight);
        }

3栏赴、區(qū)域內(nèi)拖動圖片

圖片放大超過父級容器時,支持圖片在容器內(nèi)拖動靖秩,在mousedown的條件下綁定mousemove须眷,計算拖拽區(qū)域大小,核心代碼如下:

$(document).bind('mousemove.imgview', function (event) {
                if ($img.data('mousedown')) {
                    var dx = event.pageX - settings['pageX'];
                    var dy = event.pageY - settings['pageY'];
                    if ((dx == 0) && (dy == 0)) {
                        return false;
                    }

                    var newX = parseInt($img.css('left')) + dx;
                    if (newX > 0) newX = 0;
                    if (newX < settings['width'] - $img.width())
                        newX = settings['width'] - $img.width() + 1;
                    var newY = parseInt($img.css('top')) + dy;
                    if (newY > 0) newY = 0;
                    if (newY < settings['height'] - $img.height())
                        newY = settings['height'] - $img.height() + 1;

                    if (settings['width'] >= $img.width()) {
                        newX = settings['width'] / 2 - $img.width() / 2;
                    }
                    if (settings['height'] >= $img.height()) {
                        newY = settings['height'] / 2 - $img.height() / 2;
                    }

                    $img.css('left', newX + 'px');
                    $img.css('top', newY + 'px');

                    settings['pageX'] = event.pageX;
                    settings['pageY'] = event.pageY;
                    $img.data('cannot_minimize', true);
                }
                return false;
            });

4盆偿、綜合功能實現(xiàn)代碼如下柒爸,運行請底部下載demo

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style type="text/css">
        .rot1 {
            -moz-transform: rotate(90deg);
            -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
            filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);
            -ms-filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);
        }

        .rot2 {
            -moz-transform: rotate(180deg);
            -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
            filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);
            -ms-filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);
        }

        .rot3 {
            -moz-transform: rotate(270deg);
            -webkit-transform: rotate(270deg);
            transform: rotate(270deg);
            filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);
            -ms-filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);
        }

        #imageView_container{
            border: 2px solid #000000;
        }
    </style>

    <script src="js/jquery-1.10.2.js"></script>
    <script src="js/jquery-browser.js"></script>
    <script src="js/jquery.imageView.js"></script>
</head>
<body>
<div id="imageView_container" style="overflow: hidden; position: relative; width: 800px; height: 500px; ">
    ![](images/1.jpg)
</div>
<div style="padding-top:5px;">
    <input type="button" value="放大" onclick="imgToSize(100)">
    <input type="button" value="縮小" onclick="imgToSize(-100);">
    <input type="button" value="向右旋轉(zhuǎn)" id="rotRight">
    <input type="button" value="向左旋轉(zhuǎn)" id="rotLeft">
</div>

<script type="text/javascript">
    $(function () {
    var param = {
        right: document.getElementById("rotRight"),
        left: document.getElementById("rotLeft"),
        img: document.getElementById("rotImg"),
        rot: 0
    };

    var fun = {
        right: function () {
            param.rot += 1;
            param.img.className = "rot" + param.rot;
            if (param.rot === 3) {
                param.rot = -1;
            }
        },
        left: function () {
            param.rot -= 1;
            if (param.rot === -1) {
                param.rot = 3;
            }
            param.img.className = "rot" + param.rot;
        }
    };
    param.right.onclick = function () {
        fun.right();
        return false;
    };
    param.left.onclick = function () {
        fun.left();
        return false;
    };

    $('#imageView_container').imageView({ width: 800, height: 500 });

    });

    var size = 0;


    //放大縮小圖片
    function imgToSize(size) {
        var img = $("#rotImg");
        var oWidth = img.width(); //取得圖片的實際寬度
        var oHeight = img.height(); //取得圖片的實際高度

        img.width(oWidth + size);
        img.height(oHeight + size / oWidth * oHeight);
    }
</script>
</body>
</html>

5、最終效果如下圖所示:

Paste_Image.png

學(xué)習(xí)前端的同學(xué)注意了J屡ぁI又伞!
學(xué)習(xí)過程中遇到什么問題或者想獲取學(xué)習(xí)資源的話求橄,歡迎加入前端學(xué)習(xí)交流群461593224今野,我們一起學(xué)前端!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末罐农,一起剝皮案震驚了整個濱河市条霜,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌涵亏,老刑警劉巖宰睡,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異气筋,居然都是意外死亡拆内,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門宠默,熙熙樓的掌柜王于貴愁眉苦臉地迎上來麸恍,“玉大人,你說我怎么就攤上這事∧ɑΓ” “怎么了刻肄?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長融欧。 經(jīng)常有香客問我敏弃,道長,這世上最難降的妖魔是什么噪馏? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任权她,我火速辦了婚禮,結(jié)果婚禮上逝薪,老公的妹妹穿的比我還像新娘。我一直安慰自己蝴罪,他們只是感情好董济,可當(dāng)我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著要门,像睡著了一般虏肾。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上欢搜,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天封豪,我揣著相機與錄音,去河邊找鬼炒瘟。 笑死吹埠,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的疮装。 我是一名探鬼主播缘琅,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼廓推!你這毒婦竟也來了刷袍?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤樊展,失蹤者是張志新(化名)和其女友劉穎呻纹,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體专缠,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡雷酪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了藤肢。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片太闺。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖嘁圈,靈堂內(nèi)的尸體忽然破棺而出省骂,到底是詐尸還是另有隱情蟀淮,我是刑警寧澤,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布钞澳,位于F島的核電站怠惶,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏轧粟。R本人自食惡果不足惜策治,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望兰吟。 院中可真熱鬧通惫,春花似錦、人聲如沸混蔼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽惭嚣。三九已至遵湖,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間晚吞,已是汗流浹背延旧。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留槽地,地道東北人迁沫。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像捌蚊,于是被迫代替她去往敵國和親弯洗。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容