一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

JavaScript 圖片切割效果(放大鏡)第1/4頁

上一個版本由于是初次接觸這類效果,而且是三個大功能一起開發,能力所限,所以僅僅是實現了效果就完成了。
近來我把其中的 拖放效果 和 縮放效果 單獨出來研究,經過整理和完善,再套進切割效果,個人感覺效果已經不錯了。
要說明的是這個只是一個效果,并不是真正的切割圖片,要獲取真正的切割圖片請參考 圖片切割系統 。
效果預覽請看這里
完整實例下載
代碼太多貼不出來,只好給個效果圖:

程序說明

這個效果主要分三個部分:層的拖放、層的縮放、圖片切割(包括預覽)。
其中 層的拖放 和 層的縮放 我已經在其他兩篇文章中有詳細說明,這里就說說圖片切割這部分吧。

圖片切割

關于圖片切割的設計,有三個方法:

把圖片設為背景圖,通過設置背景圖的位置來實現,但這樣的缺點是只能按圖片的正常比例實現,不夠靈活;
把圖片放到切割對象里面,通過設置圖片的top和left實現,這個方法是可行,但下面有更簡單的方法實現;
通過設置圖片的clip來實現。
這里介紹方法3的實現方法,這個方法是從當年“珍藏”的代碼中看到的,先說說clip:
clip的作用是“檢索或設置對象的可視區域。可視區域外的部分是透明的。”
依據上-右-下-左的順序提供自對象左上角為(0,0)坐標計算的四個偏移數值來剪切。
例如:
復制代碼 代碼如下:
div { position:absolute; width:60px; height:60px; clip:rect(0 20 50 10); }

注意position:absolute的設置是必須的(詳細看手冊)。
下面說說具體實現原理:

首先需要一個容器(_Container),容器里面會插入三個層:

底圖層(_layBase):那個半透明的圖片;
切割層(_layCropper):正常顯示的那個部分;
控制層(_layHandle):就是控制顯示的那個部分。
其中為了底圖層和切割層是程序自動創建的圖片,控制層是自己定義的層(程序中是一個div)。
底圖層和切割層必須完全重合,程序中把這兩個層都絕對定位到了左上角:
復制代碼 代碼如下:
this._layBase.style.top = this._layBase.style.left = this._layCropper.style.top = this._layCropper.style.left = 0;

層疊順序也要設置一下保證各層順序。

JavaScript技術JavaScript 圖片切割效果(放大鏡)第1/4頁,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产高清自拍一区 | 亚洲天堂一区二区在线观看 | 国产午夜成人无码免费看 | 国产小视频在线高清播放 | 久久久国产精品va麻豆 | 免费91最新地址永久入口 | 伊人第四色 | 色精品一区二区三区 | 青青草久热精品视频在线观看 | 一区二区三区鲁丝不卡麻豆 | 99国产精品欧美久久久久久影院 | 伊人热热久久原色播放www | 精品日韩在线 | 欧美性一交激情视频在线 | 日本韩国一区二区三区 | 中文字幕日韩三级 | 亚洲精品国产成人 | 亚洲国产精品久久久久网站 | 玖玖玖视频在线观看视频6 玖玖免费 | 色婷婷精品 | 涩视频永久免费 | 国产高清国产专区国产精品 | 精品久久看 | 国产成人宗合 | 91天堂素人精品系列网站 | 久久有码中文字幕 | 好爽毛片一区二区三区四 | 91麻豆精品国产片在线观看 | 人人添人人澡人人澡人人人人 | 久久这里一区二区精品 | 午夜激情免费视频 | 怡红院视频在线观看最新 | 欧美日韩看看2015永久免费 | 亚洲视频黄色 | 大尺度福利视频 | 青草碰人人澡人人澡 | 中文字幕在线有码 | 在线观看91 | 中文字幕一视频97色伦 | 久久精品久 | 国产欧美精品一区二区三区四区 |