小程序drawImage剪切圖片

1、var imgsW = [];

? ? ? ?var imgsH = [];

????????Page({

? ? ? ? ? ? ? ? ..........

????????????})

2、需要下載圖片的地方調(diào)用,獲取用戶寬高,并賦值,數(shù)組添加使用push

var _this = this;

wx.downloadFile({?

????url: 圖片地址,

? ? ? success: function (res) {

? ? ? ? if (res.statusCode === 200) {

//獲取圖片信息,主要獲取寬高

? ? ? ? ? wx.getImageInfo({

? ? ? ? ? ? src: res.tempFilePath,

? ? ? ? ? ? success: function (rest) {

? ? ? ? ? ? ? imgsW.push(rest.width);//賦值

? ? ? ? ? ? ? imgsH.push(rest.height);

? ? ? ? ? ? ? let url = _this.data.downloadImg;

? ? ? ? ? ? ? url.push(res.tempFilePath)

? ? ? ? ? ? ? _this.setData({

? ? ? ? ? ? ? ? downloadImg: url,

? ? ? ? ? ? ? })

? ? ? ? ? ? ????_this.drawView(); ? // 所需圖片的下載完成后,才可開始draw界面

? ? ? ? ? ? ? ? return;

? ? ? ? ? ? ? }

? ? ? ? ? ? }

?? ? ? ? ?})

?? ? ? ?}

? ? ? }

? ? })

3、圖片下載完成,開始畫圖,

drawView() {

????var context = wx.createCanvasContext('shareHomePage', this);

? ? context.setFillStyle('#ffffff');

? ? context.fillRect(0, 0, 500, 600);

? ? var?img_top = 10;

? ? var img_left = 10;

? ? var spaceX = 6;

? ? var?img_w_h = (500 - (spaceX + img_left)?* 2 ) / 3.0;

????for (var i in this.data.downloadImg) {

? ? ????? if (i >= 3) {

? ? ? ? ????break;

?? ? ? ? ?}

? ? ? var url = this.data.downloadImg[i];

? ? ? var minx = (imgsW[i] - imgsH[i]) / 2.0;

? ? ? var miny = (imgsH[i] - imgsW[i]) / 2.0;

? ? ? if(imgsW[i] > imgsH[i]) {

? ? ? ? context.drawImage(url, minx, 0, imgsH[i], imgsH[i], img_left, img_top, img_w_h, img_w_h);

? ? ? } else {

? ? ? ? context.drawImage(url, 0, miny, imgsW[i], imgsW[i], img_left, img_top, img_w_h, img_w_h);

? ? ? }

? ? ? img_left += spaceX + img_w_h

? ? }

}

/**

?context.drawImage(url, 0, miny, imgsW[i], imgsW[i], img_left, img_top, img_w_h, img_w_h);

括號內(nèi)對應參數(shù)內(nèi)容:

(圖片地址, 起始x, ?起始y, 截取寬度, 截取長度, 圖片放置位置x, 圖片放置位置y, 圖片放置寬,圖片放置高)

**/

完結(jié)

ps:

調(diào)用wx.switchTab時候,發(fā)覺沒有調(diào)用對應tab界面的onLoad: function () /?onShow: function (),需要自己手動調(diào)用,調(diào)用方法如下:

? ? ? wx.switchTab({

? ? ? ? ? ? ? url: '../news/news',

? ? ? ? ? ? ? success: function (e) {

? ? ? ? ? ? ? ? var page = getCurrentPages().pop();

? ? ? ? ? ? ? ? if (page == undefined || page == null) return;

? ? ? ? ? ? ? ? page.onLoad(); // ?page.onShow();

? ? ? ? ? ? ? }

? ? ? ? ?});


真的完結(jié)了,開心??......??????????

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些閱讀 2,157評論 0 2
  • 北京2018年4月1日上午,NBA常規(guī)賽勇士客戰(zhàn)國王的比賽中,發(fā)生了令人痛心不已的一幕。比賽進行到第三節(jié)還有41...
    Curry_宇閱讀 1,372評論 1 1
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標準。 注意:講述HT...
    kismetajun閱讀 28,890評論 1 45
  • NO.1 東東呢?上哪兒去了? 記得多年前,面對一年級的孩子,讓他們用“情”組詞,不得不佩服現(xiàn)在的孩子們,雖然只有...
    陽光Sunflower閱讀 387評論 0 1
  • 不得不說自己有點敏感每天總有一段不合群的時間此刻 它如期到來受蠱的思緒翩躚 我曾試著改變自己就在最近幾年總感覺生活...
    墨成閱讀 617評論 12 5

友情鏈接更多精彩內(nèi)容