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

熱線電話:13121318867

登錄
首頁精彩閱讀吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里
吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里
2021-09-14
收藏

作者:豆豆

來源:Python 技術(shù)

我們都知道當(dāng)把圖片無限放大時,就會看到一個個的小方格,而這每一個小方格就是組成圖片的最小單位,我們稱之為像素,換言之,對于單獨的一個像素來說,它只有一個固定的色值,是不可再分的。

大膽一點,如果我們在這每一個像素塊中填充上不同的字以組成你想說的話,然后再發(fā)給你心中的那個她,會不會有意外的驚喜呢。

先從原理上來講講此方案為啥可行,拋開整張圖片不談,先單獨看下這一個像素塊。

一個像素點其大小是 1 x 1 像素,但要想把一個這么大的字裝進這么小的像色塊里面,即使能裝進去,放大之后也是很難看清楚的,更別說后面的驚喜了。

因此,我們需要將像素塊放大,放大到足夠看清字體為止,經(jīng)過派森醬多次測試發(fā)現(xiàn) 15 倍足矣,再小的話字體就非常模糊了。

同時因為每個像素塊都是有自己的色值的,所以當(dāng)我們把像素放大到 15 x 15 時,要填充上對應(yīng)顏色的文字才行。

處理好這一個像素點,再對其余所有像素點都采取同樣的操作即可,這樣最后得到的圖片會是原來的 15 倍大,但從宏觀來看圖片的色值并不會有任何改變。

模塊安裝

由于要對圖片進行操作,我們用到的庫是 Pillow,可直接通過 pip 進行安裝。

pip install Pillow

初步使用

為了故事的順利發(fā)展,需要先熟悉幾個 Pillow 的常規(guī)操作。

1、新建圖片并保存

from PIL import Image

img = Image.new("RGB", (512, 512), (0, 100, 200)) # 創(chuàng)建一張新的圖片 Image.new(mode, size, color=0)  img.save("img.png")

效果如下所示:

吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里

2、重新繪制圖片

我們可以在上面剛生成的圖片中繪制一些線條,此處是勾畫出兩條對角線。

from PIL import Image

img = Image.open("img.png") # 打開圖片 draw = ImageDraw.Draw(img) # 取得繪圖對象,用于繪制對角線 draw.line((0, 0, img.size[0], img.size[1]), fill=128, width=2)
draw.line((0, img.size[1], img.size[0], 0), fill=128, width=2)
img.save("img-line.png")

效果如下所示:

吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里

3、圖片合并

我們還可以將一張圖片合并到另一張圖片之上,看起來就像是粘上去的一樣。

from PIL import Image

img = Image.open("img.png") # 打開圖片 img_small = Image.new("RGB", (32, 32), 'red') # 創(chuàng)建圖片 img.paste(img_small, (20, 20)) # 將 img_small 粘貼到 img 的 (20,20) 位置處 img.save("img-paste.png")

效果如下所示:

吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里

放大招

有了以上的基礎(chǔ),接下來就直接上手開干了。

首先我們找了一張月亮的圖片,然后準備把「今晚的月色真美」填充到圖片中。當(dāng)然此處對內(nèi)容做了簡化,你完全可以將任何自己想告訴對方的話寫進去。

吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里

首先定義好要用到的基本變量,像素放大尺寸 img_child_size、內(nèi)容、字體設(shè)置、圖片路徑等。

from PIL import Image, ImageDraw, ImageFont

img_child_size = 15 text = "今晚的月色真美" font = ImageFont.truetype('AliPuHui-Bold.ttf', img_child_size) 
img_path = './moon.png' 

其次創(chuàng)建一個大小為 img_child_size 的小圖 img_child 用于填充字體,一個原始圖片擴大 img_child_size 倍的新圖 img_ans 用于裝載前面填充好字體的小圖。

img = Image.open(img_path)
img_w, img_h = img.size
img_child = Image.new("RGB", (img_child_size, img_child_size))
img_ans = Image.new("RGB", (img_child_size * img_w, img_child_size * img_h))

最后,就是循環(huán)遍歷原圖的每一個像素點,針對每個像素點(x,y)都要用繪制好文字的小圖 img_child 粘貼到新圖 img_ans 的對應(yīng)位置上去。當(dāng)然其中為了讓字體居中還做了一些處理。

text_w, text_h = font.getsize("中") # 獲取單個文字的寬、高 offset_x = (img_child_size - text_w) >> 1 # 文字水平居中 offset_y = (img_child_size - text_h) >> 1 # 文字垂直居中 char_index = 0 draw = ImageDraw.Draw(img_child) # 小圖的繪圖對象,用于繪制文字 for x in range(img_w): # 寬在外 高在內(nèi),因此文字的方向是從左到右,從上到下排列的 for y in range(img_h): draw.rectangle((0, 0, img_child_size, img_child_size), fill='lightgray') # 繪制背景,看起來會好一些 draw.text((offset_x, offset_y), text[char_index], font=font, fill=img.getpixel((x, y))) # 用(x,y)處像素點的色值繪制字體 img_ans.paste(img_child, (x * img_child_size, y * img_child_size)) char_index = (char_index + 1) % len(text) img_ans.save('moon-text.png') 

來看看最終結(jié)果。

吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里

看不是很清楚對不對,咱放大看。

吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里

有點意思了對不對,繼續(xù)放大。

吊炸天!十行代碼我把情書藏進了小姐姐的微信頭像里

哈哈哈,驚不驚喜,意不意外。

總結(jié)

今天派森醬帶大家一起搞了個好玩的,用文字來填充圖片,只要理解了圖片、像素、文字之間的關(guān)系代碼就很容易寫出來了。

數(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(), // 加隨機數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗證碼對象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務(wù)器是否宕機 new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機 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){ //倒計時完成 $(".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); }