mieki256's diary



2024/06/03(月) [n年前の日記]

#1 [nitijyou] 自宅サーバ止めてました

雷が鳴ったので、16:30-18:30の間、自宅サーバ止めてました。申し訳ないです。

夕方、かなりの豪雨になって…。滝のような雨で怖かった…。

#2 [cg_tools] GIMPで透明部分のRGB値を残したい

OpenGLでテクスチャを描画すると、透明部分と不透明部分の境界に ―― アルファチャンネル値が0の部分と、255の部分の境界に、変な線が描画されてしまう。テクスチャのフィルタを GL_LINEAR にしているときに、透明部分のRGB値と不透明部分のRGB値で補間して、妙な色が出現してしまうのだろう。たぶん。

その問題を解決するために、透明部分のRGB値に、不透明部分のRGB値も入ってる状態にしたい。GIMP でそういう作業ができそうなのか調べてた。

環境は、Windows10 x64 22H2 + GIMP 2.10.34 Portable。

透明部分に不透明部分の色を引き延ばす :

まずは以下のような画像があるとして。

gimp_alpha_delete_ss01.png


この画像の透明部分に、不透明部分のRGB値を引き延ばし(?)たい。

元レイヤーは後で重ねたりアルファチャンネルを利用したりするので、まずはレイヤーを複製しておく。レイヤーウインドウで、レイヤーの複製ボタンをクリック。処理したいレイヤーは元レイヤーの下に移動しておく。

gimp_alpha_delete_ss02.png


続いて、不透明部分のRGB値を引き延ばす。複製したレイヤーを選択して、フィルタ → ぼかし → ガウスぼかし。

gimp_alpha_delete_ss03.png


オプション値はデフォルト値でもいいかな…。うっすらと周囲に色が伸びてるのが分かるかと。

gimp_alpha_delete_ss04.png


うっすらとした色に見えるのは、その部分のアルファチャンネルに 0 - 255 の間の値が置かれて半透明になっているからなので、アルファチャンネル値を0か255にしてしまう。レイヤー → 透明部分 → アルファチャンネルのしきい値、を選ぶ。

gimp_alpha_delete_ss05.png


しきい値の値をグンと小さくしてしまう。半透明だった部分が不透明になって、元々の不透明部分が引き延ばされてるような見た目になってくれる。

gimp_alpha_delete_ss06.png

アルファチャンネルを削除する方法 :

前述の手順では、「アルファチャンネルのしきい値」を使ってアルファチャンネルの値を変化させたけれど、そもそもアルファチャンネルを削除して対応する方法もある。

ただ、レイヤー名を右クリックしたときに表示される、「アルファチャンネルの削除」を選んでしまうと、透明部分が背景色で塗り潰されてしまって、元々透明部分に置いてあったRGB値が消滅してしまう…。以下の画像を見れば分かるかと。透明部分のRGB値が背景色のグレーで塗り潰されてしまっている。

gimp_alpha_delete_ss20.png

gimp_alpha_delete_ss21.png


そこで、レイヤーマスクを使って、そのあたりの処理をする。

レイヤーを右クリックして、レイヤーマスクの追加、を選ぶ。

gimp_alpha_delete_ss07.png


レイヤーのアルファチャンネルを移転、を選んでから、「追加」。

gimp_alpha_delete_ss08.png


レイヤーマスクが追加される。レイヤーマスクは 0 - 255 の値を取るグレースケールになってる。

gimp_alpha_delete_ss09.png


ここでおもむろに(?)、レイヤーマスクを削除してしまう。レイヤーを右クリックして、レイヤーマスクの削除、を選ぶ。

gimp_alpha_delete_ss10.png


レイヤーマスクが削除されて ―― つまりは元々あったアルファチャンネル"だけ"が削除された状態になって、透明部分に置かれていたRGB値が目視できるようになる。

gimp_alpha_delete_ss11.png


以下、参考ページ。

_透過png画像のアルファ値だけを消す方法を教えてください! - 題名の通り... - Yahoo!知恵袋

元々の透明部分を反映させる :

元画像が持っていた透明部分を反映させる。レイヤーを複製しておいたので、元画像のレイヤーは残ってるはず。右クリックして、不透明部分を選択範囲に、を選ぶ。

gimp_alpha_delete_ss12.png


この選択範囲でアルファチャンネルを作る。もう一枚のレイヤーを右クリックして、レイヤーマスクの追加、を選ぶ。

gimp_alpha_delete_ss13.png


選択範囲、を選んで、「追加」。

gimp_alpha_delete_ss14.png


元々の透明部分を反映した状態の見た目になった。

gimp_alpha_delete_ss15.png


この段階では、透明部分 = アルファチャンネルの値が0ではあっても、そこにRGB値がちゃんと残ってる。ピクセル情報、のタブを表示して、マウスカーソル位置のRGBA値を確認すれば、Aが0だけど、RGB値はちゃんと値が入ってることが分かる。

gimp_alpha_delete_ss16.png

RGB値を残したままpng画像としてエクスポート :

透明部分のRGB値を残したまま、png画像として保存(エクスポート)する。ファイル → 名前を付けてエクスポート、を選ぶ。

gimp_alpha_delete_ss17.png


保存ファイル名の最後に「.png」をつけておく。GIMPはファイル名の拡張子を見て保存する画像フォーマットを選んでくれるので。

gimp_alpha_delete_ss18.png


PNGエクスポート時のオプションで、「背景色を保存」「透明ピクセルの色の値を保存」にチェックを入れておく。特に後者は重要。ここにチェックを入れておかないと、透明部分のRGB値が変更された状態で保存されてしまう。

gimp_alpha_delete_ss19.png

以上、1 日分です。

過去ログ表示

Prev - 2024/06 - Next
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30

カテゴリで表示

検索機能は Namazu for hns で提供されています。(詳細指定/ヘルプ


注意: 現在使用の日記自動生成システムは Version 2.19.6 です。
公開されている日記自動生成システムは Version 2.19.5 です。

Powered by hns-2.19.6, HyperNikkiSystem Project