關於croptool無法裁剪分辯率過低的圖片

来源:https://www.cnblogs.com/wfkfytmy/archive/2022/04/04/16100445.html
-Advertisement-
Play Games

web前端開發規範 規範概述 一個人走的更快,一群人可以走的更遠,前提是統一的策略,還要不斷地反省和優化。不管有多少人共同參與同一項目,儘可能確保每一行代碼都像是同一個人編寫的 開發目錄規範 開發環境規範 開發編碼規範 一、目錄及文件命名規範 (一)、例靜態專題頁目錄 - src / html 源代 ...


  YofFawn的cropTool;

在使用croptool.js時,如果圖片的解析度過低,則無法裁剪超過解析度的大小。比如說

function chooseImg(event){
  var files = event.files || event.dataTransfer.files,
  file = files[0] || files;
  event.value = '';
  window.clip = new Clip({
    dragBoxClass: 'block', //裁剪框類名
    clipRadio: 1 / 1, //裁剪比例 寬/高 傳0或空或不傳等於不設置比例
    //單位px 僅為裁剪框的寬高 不等同裁剪後最終圖片寬高
    initialHeight: 100, //裁剪框初始高度
    initialWidth: 100, //裁剪框初始寬度
    minHeight: 100, //裁剪框最小高度
    minWidth: 100, //裁剪框最小寬度
    maxWidth: 450, //裁剪框最大寬度 不會大於裁剪區域寬度 取值需大於最小寬高
    maxHeight: 450, //裁剪框最大高度 不會大於裁剪區域高度
    cornerColor: '#39f', //裁剪框顏色
    encode: 'base64', //文件類型
    type: 'png', //保存圖片類型
    name: 'img', //文件名字
    quality: 1, //壓縮質量
    //裁剪完成
    onDone: function (e) {
      console.log(e);
      //return false;
      document.getElementById('previewImg').src = e;
    },
    onCancel: function(){
 
    }
  });
  clip.setSize(file);
}

  

在上面這個函數中,明確說明裁剪框最大的高度和寬度為450,但是如果選擇圖片文件的解析度為180*180,那麼裁剪框的最大裁剪範圍也會變成180*180。

註意css樣式。此時裁剪框最大是180*180;

  解決方法:打開croptool.js做以下修改 找到以下兩個三元運算
_this.opt.maxWidth=parseInt(_this.opt.maxWidth>w?w:_this.opt.maxWidth);
_this.opt.maxHeight=parseInt(_this.opt.maxHeight>h?h:_this.opt.maxHeight);

 

修改為
_this.opt.maxWidth=parseInt(_this.opt.maxWidth>w?_this.opt.maxWidth:_this.opt.maxWidth);
_this.opt.maxHeight=parseInt(_this.opt.maxHeight>h?_this.opt.maxHeight:_this.opt.maxHeight);

 

修改後效果:

因為使用開發者工具所以裁剪區域變形,不使用開發者工具時是正常的。重點是css樣式。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MySQL8.0.x 安裝 一、下載 MySQL官網下載鏈接:https://downloads.mysql.com/archives/community/ 選擇版本後下載zip文件 博主選擇的是8.0.13 二、安裝 1 解壓 把下載好的zip包在你想要的路徑下直接解壓。 解壓完成後得到這個界面: ...
  • cluster概念澄清 postgresql中沒有聚集索引的概念,表都是以堆(heap)的方式存在,可以認為數據在物理存儲上是無序的。cluster:這裡的cluster不是指多個機器的組成的集群,而是指表中數據行按照某種方式物理排序存儲。是一種改變postgresql表的物理存儲的一種方案。適應場 ...
  • 在鴻蒙開發中tab切換功能(如下圖所示)是非常常見一個功能,今天描述如下功能怎麼實現?開發中需要準備哪些資料? 今天我們從“資料準備”,“Tabs功能實現”,“底部按鈕功能實現”,“運行效果”四個方面進行描述 1. 開發準備 1.1 資料準備 想要實現如上圖功能的話,需要學習“Tabs”,“TabC ...
  • 背景 開發者在應用中集成HMS Core部分服務時,android sdk 以及flutter等跨平臺sdk,會出現編譯打包後,運行報6003錯誤碼的情況。根據查詢可以得知,錯誤代碼 6003 表示證書指紋配置不一致,主要是生成的包(例如安卓apk)的簽名,與華為開發者平臺上應用設置裡面配置的不一致 ...
  • 即時通訊(Instant Messaging)是一種基於互聯網的即時交流消息的業務。 實時聊天交互功能是市面上主流APP的重要功能之一,人們所熟悉的就是微信,QQ的聊天消息系統,IM看似簡單,技術開發絕非易事,海量併發,超低延時,消息必達等高實時性需求需要眾多技術的應用合體; IM結合RTC可以... ...
  • pinia是一個vue的狀態存儲庫,你可以使用它來存儲、共用一些跨組件或者頁面的數據,使用起來和vuex非常類似。pina相對Vuex來說,更好的ts支持和代碼自動補全功能。本篇隨筆介紹pinia的基礎用法以及持久化存儲的一些用法,供參考學習。 pinia在2019年11月開始時候是一個實驗項目,目... ...
  • element組件的change方法預設獲取的只有選擇的id,如果同時我們想要獲得選中的name或其他數據則是不行的 這時候組件本身給我們提供了方法 下麵是使用方法 HTML <el-form-item label="排查地點" class="requireds-label"> <el-cascad ...
  • 寫過前端代碼大概率聽說過amd cmd umd commonjs esm這些名詞, 想當初我第一次看到這些的時候, 人都麻了, 都是些啥啊. 後來我知道了, 這些都是js的模塊規範. amd - 瀏覽器中的js模塊化解決方案 AMD全稱是Async Module Definition非同步模塊定義 R ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...