99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀教你如何用Python處理圖片九宮格,炫酷朋友圈
教你如何用Python處理圖片九宮格,炫酷朋友圈
2019-06-28
收藏
教你如何用Python處理圖片九宮格,炫酷朋友圈

01 前言

在日常的生活中,大家偶爾會看到朋友圈發(fā)的照片由一張被切成九張的效果,有時由一張照片被切成九張照片所帶來的視覺盛宴是不一樣的!

現(xiàn)在許多 P 圖工具里面自帶了這種功能,而微信小程序里也有專門可以切圖的工具。為了熟練鞏固的練習(xí)調(diào)庫操作,今天就來帶大家看看,如何用 Python 實(shí)現(xiàn)這個小功能。

02 成果展示

先來看看成果,原圖為文章開始的圖片,一圖切九圖朋友圈:

教你如何用Python處理圖片九宮格,炫酷朋友圈

九張圖發(fā)朋友圈的時候,還有個比較有意思的事,上傳時是亂序的,還需要你自己像玩拼圖一樣自己擺位置。

03 思路講解

這個小功能的實(shí)現(xiàn)利用了 Python 中的一個圖形處理庫,Pillow。

Pillow是由從著名的Python圖像處理庫PIL發(fā)展出來的一個分支,通過Pillow可以實(shí)現(xiàn)圖像壓縮和圖像處理等各種操作。

1pip install pillow # 安裝 pillow 庫

大體實(shí)現(xiàn)思路以下幾步:

  1. 讀取到原圖片,獲取圖片尺寸后,將寬高對比,生成以白色為背景的大正方形圖
  2. 將大正方形圖按照 3*3 比例進(jìn)行切割,生成9個小正方形圖
  3. 分別生成 9 張小正方形圖片

04 代碼講解

按照上面的思路,寫出代碼:

1. 填充原圖形的背景,生成大正方形圖

1def fill_images(image):

2 """ 填充正方形白色背景圖片 """

3 width, height = image.size # 獲取圖片的寬高

4 side = max(width, height) # 對比寬和高哪個大

6 # 新生成的圖片是正方形的,邊長取大的,背景設(shè)置白色

7 new_image = Image.new(image.mode, (side, side), color='white')

9 # 根據(jù)尺寸不同,將原圖片放入新建的空白圖片中部

10 if width > height:

11 new_image.paste(image, (0, int((side - height) / 2)))

12 else:

13 new_image.paste(image, (int((side - width) / 2), 0))

14 return new_image

代碼中的順序,可以理解為下面幾個圖形,首先在原有的照片基礎(chǔ)上覆蓋上白色背景:

教你如何用Python處理圖片九宮格,炫酷朋友圈

其次,比較寬和高的生成規(guī)則是下面兩個圖,我們可以將背景調(diào)成黑色,便于觀察,當(dāng)寬大于高的像素時,你的照片就是橫著鋪滿正方形的,而背景圖填充上下,黑色背景是不是有股電影大片的氣息:

教你如何用Python處理圖片九宮格,炫酷朋友圈

當(dāng)高大于寬的像素時,你的照片就是豎著鋪滿正方形的,而背景圖填充左右:

教你如何用Python處理圖片九宮格,炫酷朋友圈

第一步到這里就完成了,你得到的就是一張被背景顏色填滿的正方形。

2. 對大正方形進(jìn)行切割

1def cut_images(image):

2 """ 切割大正方形圖 """

3 width, height = image.size

4 one_third_width = int(width / 3) # 三分之一正方形線像素

6 # 保存每一個小切圖的區(qū)域

7 box_list =

9 """

10 切圖區(qū)域是矩形,位置由對角線的兩個點(diǎn)(左上,右下)確定,

11 而 crop 實(shí)際要傳入四個參數(shù)(left, upper, right, lower)

12 """

13 for x in range(3):

14 for y in range(3):

15 left = x * one_third_width # 左像素

16 upper = y * one_third_width # 上像素

17 right = (x + 1) * one_third_width # 右像素

18 lower = (y + 1# 下像素

19 box = (left, upper, right, lower)

20 box_list.append(box)

21 image_list = [image.crop(box) for box in box_list]

22 return image_list

首先定位三分線:

教你如何用Python處理圖片九宮格,炫酷朋友圈

根據(jù)左上,右下兩個像素點(diǎn)的位置,確定新的圖形:

教你如何用Python處理圖片九宮格,炫酷朋友圈

最后將每個小正方形的左上和右下像素點(diǎn)進(jìn)行存儲,以元組的形式寫到list中,在調(diào)用 crop 函數(shù)進(jìn)行圖像復(fù)制。關(guān)于 crop 函數(shù),官方文檔:

教你如何用Python處理圖片九宮格,炫酷朋友圈

3. 存儲切割后的9張圖片(不放代碼了,比較簡單)

05 總結(jié)

Pillow 庫對圖像處理操作支持非常友好,而本次的小工具核心就在于如果進(jìn)行對原有圖片進(jìn)行切割。內(nèi)嵌兩次循環(huán)來逐行遍歷,雙重遍歷的思想會經(jīng)常用到,這塊可以注意下。

當(dāng)然如果要是嫌源代碼運(yùn)行麻煩,可以打成 exe 文件來使用喲。這下又可以在朋友圈秀操作了?。ū热绺母谋尘把?,黑色背景什么的。)

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗(yàn)證碼對象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計(jì)時完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }