av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

javascript - 如何使用Canvas改變素材的顏色?

瀏覽:118日期:2022-11-05 09:28:33

問題描述

我在知乎中看到一則提問是關于使用色盤來改變人物顏色的,這里是鏈接引用該提問的一張圖片javascript - 如何使用Canvas改變素材的顏色?

里面的人物僅僅是著裝不同,但膚色是相同的,原文提到是使用了色盤來實現的,但太專業看得不是很懂,請問如何使用Canvas實現色盤來改變素材的局部顏色呢?非常感謝~

補充:這張圖片是用GameMaker處理過的,Canvas有方法處理這樣的圖片嗎?javascript - 如何使用Canvas改變素材的顏色?

問題解答

回答1:

因為早期卡帶內存有限,所以,如果直接存圖片的話,一張卡帶光角色圖片就能塞滿了。由于位圖是有點陣組成的,每個點(也就是每個像素)都有它自己的顏色。在早期卡帶機上,能用到的顏色其實并不多,所以才有了色盤。(經常用PS的應該知道色盤這個東西)也就是,將一幅圖上所有用到的顏色編號,存儲成一個控制了容量大小的色盤(比如一張傳統的二維碼圖,其實只要存兩種顏色就可以了)。然后在存儲圖片的時候,原本對應點陣的存儲需要記錄紅綠藍通道的值,而用色盤之后,直接用色盤中的序號代替對應的顏色,這樣因為序號存儲空間比紅綠藍數據占用空間少,而且色盤可以復用(只要對應顏色在色盤里存在,就可以用序號替代顏色),所以就間接節省了卡帶的空間。

而由于存儲的時候,是只存儲了色盤里的序號,所以只要改變色盤里對應序號的顏色,就可以使圖片中對應序號的顏色發生變化。

由于Canvas中,都是真彩色,而且因為計算機存儲的迅速發展,現在的電腦存儲空間也遠沒有之前卡帶中那么拮據了,所以,在Canvas里,是不存在色盤的。但是,知道了色盤的原理之后,其實你也很好想到模擬色盤的處理方案。由于色盤用編號替代顏色,也就是說,替換了色盤里的一種顏色就替換了圖片里所有顏色值等于該顏色的區域。所以根據這個思路,你要做的就是把圖片里所有顏色值等于某個值的顏色都替換掉,代碼我就不具體寫了,這里給個鏈接,希望可以得到啟發:http://www.deanhan.cn/canvas-...

另外,畫盤替換方案,針對之前卡帶游戲8位的圖像比較容易,因為顏色區分度大;但是對于現有的真彩色位圖而言,這個難度就大了很多,因為現在的位圖里很可能出現區分度很小的如#dedede和#dededd的顏色梯度,這種就不太適合用畫盤的思路去做了。

Update

再說下對于現在真彩色的圖,進行顏色變換,一般是將RGB值轉成HSL/HSV值,然后通過調整H值改變色調。

最后再轉換回RGB值,這個和上面的區別在于,這種不能單獨改變一類顏色,它的變化是針對于全圖的(除非你限定變換應用區域),膚色可能會因為H值的變化有所改變。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: av手机免费在线观看 | 欧美一区二区久久 | 一级片av | 欧美日韩福利视频 | 日本久久网 | 亚洲精品一区二区 | 一区二区三区亚洲 | 欧美日韩在线播放 | 午夜黄色影院 | 欧美日韩久久 | 日韩亚洲视频 | 国产不卡视频 | 国产精品区二区三区日本 | 精品欧美一区二区三区久久久 | 日韩一区不卡 | 自拍偷拍小视频 | 91在线电影 | 日韩在线一区二区 | 久久久精品高清 | 亚洲高清在线观看 | 日韩电影免费观看中文字幕 | 久在线观看 | 亚洲视频二区 | 亚洲欧美日韩一区二区 | 日韩在线观看精品 | 久久精品国产v日韩v亚洲 | 国产乱码精品一区二区三区忘忧草 | www.蜜桃av| 日本网站免费在线观看 | 日韩欧美一区二区三区免费观看 | av黄色在线| 精品国产一区二区三区免费 | 国产高清精品一区二区三区 | 国产精品永久免费视频 | 午夜影院在线观看免费 | 丝袜久久 | 亚洲在线一区 | 拍拍无遮挡人做人爱视频免费观看 | 亚洲视频一区在线观看 | 草久久久 | 国产在线精品一区二区三区 |