javascript - 如何使用Canvas改變素材的顏色?
問題描述
我在知乎中看到一則提問是關于使用色盤來改變人物顏色的,這里是鏈接引用該提問的一張圖片
里面的人物僅僅是著裝不同,但膚色是相同的,原文提到是使用了色盤來實現(xiàn)的,但太專業(yè)看得不是很懂,請問如何使用Canvas實現(xiàn)色盤來改變素材的局部顏色呢?非常感謝~
補充:這張圖片是用GameMaker處理過的,Canvas有方法處理這樣的圖片嗎?
問題解答
回答1:因為早期卡帶內存有限,所以,如果直接存圖片的話,一張卡帶光角色圖片就能塞滿了。由于位圖是有點陣組成的,每個點(也就是每個像素)都有它自己的顏色。在早期卡帶機上,能用到的顏色其實并不多,所以才有了色盤。(經常用PS的應該知道色盤這個東西)也就是,將一幅圖上所有用到的顏色編號,存儲成一個控制了容量大小的色盤(比如一張傳統(tǒng)的二維碼圖,其實只要存兩種顏色就可以了)。然后在存儲圖片的時候,原本對應點陣的存儲需要記錄紅綠藍通道的值,而用色盤之后,直接用色盤中的序號代替對應的顏色,這樣因為序號存儲空間比紅綠藍數(shù)據(jù)占用空間少,而且色盤可以復用(只要對應顏色在色盤里存在,就可以用序號替代顏色),所以就間接節(jié)省了卡帶的空間。
而由于存儲的時候,是只存儲了色盤里的序號,所以只要改變色盤里對應序號的顏色,就可以使圖片中對應序號的顏色發(fā)生變化。
由于Canvas中,都是真彩色,而且因為計算機存儲的迅速發(fā)展,現(xiàn)在的電腦存儲空間也遠沒有之前卡帶中那么拮據(jù)了,所以,在Canvas里,是不存在色盤的。但是,知道了色盤的原理之后,其實你也很好想到模擬色盤的處理方案。由于色盤用編號替代顏色,也就是說,替換了色盤里的一種顏色就替換了圖片里所有顏色值等于該顏色的區(qū)域。所以根據(jù)這個思路,你要做的就是把圖片里所有顏色值等于某個值的顏色都替換掉,代碼我就不具體寫了,這里給個鏈接,希望可以得到啟發(fā):http://www.deanhan.cn/canvas-...
另外,畫盤替換方案,針對之前卡帶游戲8位的圖像比較容易,因為顏色區(qū)分度大;但是對于現(xiàn)有的真彩色位圖而言,這個難度就大了很多,因為現(xiàn)在的位圖里很可能出現(xiàn)區(qū)分度很小的如#dedede和#dededd的顏色梯度,這種就不太適合用畫盤的思路去做了。
Update再說下對于現(xiàn)在真彩色的圖,進行顏色變換,一般是將RGB值轉成HSL/HSV值,然后通過調整H值改變色調。
最后再轉換回RGB值,這個和上面的區(qū)別在于,這種不能單獨改變一類顏色,它的變化是針對于全圖的(除非你限定變換應用區(qū)域),膚色可能會因為H值的變化有所改變。
相關文章:
1. javascript - 下面的這段算法代碼求解釋2. javascript - 在top.jsp點擊退出按鈕后,right.jsp進行頁面跳轉,跳轉到login.jsp3. javascript - js 有什么優(yōu)雅的辦法實現(xiàn)在同時打開的兩個標簽頁間相互通信?4. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點5. css3 - 在sublime text里, 如何讓emmet生成的帶前綴css屬性垂直對齊?6. mac連接阿里云docker集群,已經卡了2天了,求問?7. javascript - 回調函數(shù)和閉包的關系8. java - spring-data Jpa 不需要執(zhí)行save 語句,Set字段就可以自動執(zhí)行保存的方法?求解9. [前端求職必看]前端開發(fā)面試題與答案精選_擴展問題10. 想找個php大神仿個網(wǎng)站。
