質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.48%

  • Java

    16124questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • Android

    7387questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • Android Studio

    4356questions

    Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Android mask処理でPorterDuff.Mode.XORができない

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 61

sekaikan_ozaki

score 29

PCスペック
Windows10 HOME 64bit
メモリ 32GB
プロセッサ Intel Core i7-8700CPU 3.20GHz
Android Studio 3.4.1(最新ver)
デモ用端末(XPERIA OS:7.0 API 24)

お世話になっております。

1つ前の質問の内容の続きなのですが、
maskをかける側の画像の背景が透明ではないことが原因で、mask処理ができていいませんでした。

そこで、maskをかける側の画像の背景を透明するための方法として、以下を考えました。

方法
手順1:「画像1(手順3でmaskをかける側になる画像)」と「画像2(手順2でmaskをかける側の真っ黒な画像)」を用意する
手順2:手順1の2枚で排他的論理和(PorterDuff.Mode.XOR)のmask処理を行い、2枚の画像の重なる部分だけを透明にすることで、画像1を「ピンクの線のみで残りを透明」という画像に変える
手順3:「変更後の画像1」と「本来用意していた画像」とで、PorterDuff.Mode.DST_INを用いてマスク処理をかけて、重なる部分のみを抽出する

画像1:マスクをかける画像
イメージ説明

画像2:真っ黒な画像
イメージ説明

現在困っていること
手順2が終了した時点でアプリ上では、思い通りピンクの線が表示されて、周りが白く(透明だということ)なっていた。
しかし、手順3が終了して、得られた画像は真っ白な画像になっている。。
↑これが原因不明ということでなんとか解決したいです。

6/13追記
>手順2が終了した時点でアプリ上では、思い通りピンクの線が表示されて、周りが白く(透明だということ)なっていた。
アプリ画面上では、そのようなImageViewとして表示されていたが、実際に「変更後の画像1(maskImage)」をストレージに保存して確認してみると、真っ黒の画像になっていた。

>しかし、手順3が終了して、得られた画像は真っ白な画像になっている。
こちらもアプリ画面上でこのように見えたが、手順3が終了した時点での「最終的な画像(resultImage)」も念のためストレージに保存して確認してみると、真っ黒な画像になっていた。

ソースコードを以下に載せておきます。

        //切り抜いた画像の表示
        Button button4 = findViewById(R.id.button4);
        button4.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v){

                InputStream inputStream0;
                Canvas canvas = new Canvas();
                try{

                    inputStream0 = new FileInputStream(file);//なぞった部分の画像データを読み込む

                    Bitmap nazoruImage = BitmapFactory.decodeStream(inputStream0);//bitmapとして取り出す
                    Bitmap blackImage = BitmapFactory.decodeResource(getResources(), R.drawable.black);//bitmapとして取り出す

//手順1終わり

                    Bitmap maskImage = Bitmap.createBitmap(nazoruImage.getWidth(), nazoruImage.getHeight(), Bitmap.Config.ARGB_8888);

                    canvas.setBitmap(maskImage);
                    Paint blackClearPaint = new Paint();
                    blackClearPaint.setFilterBitmap(false);

                    canvas.drawBitmap(nazoruImage, 0, 0, blackClearPaint);
                    blackClearPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.XOR));
                    canvas.drawBitmap(blackImage, 0, 0, blackClearPaint);
                    blackClearPaint.setXfermode(null);

                    //imageView.setImageBitmap(maskImage);//手順2終わり、ここでは期待通りのXORができている思っていたが、そうではないのかもしれない

                    Bitmap mainImage = MediaStore.Images.Media.getBitmap(getContentResolver(),cameraUri);//カメラで撮った画像を読み込んでbitmapとして取り出す
                    Bitmap resultImage = Bitmap.createBitmap(mainImage.getWidth(), mainImage.getHeight(), Bitmap.Config.ARGB_8888);

                    canvas.setBitmap(resultImage);
                    Paint commonShowPaint = new Paint();
                    commonShowPaint.setFilterBitmap(false);

                    canvas.drawBitmap(mainImage, 0, 0, commonShowPaint);
                    commonShowPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.DST_IN));
                    //commonShowPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.SRC_IN));
                    canvas.drawBitmap(maskImage, 0, 0, commonShowPaint);
                    commonShowPaint.setXfermode(null);

                    imageView.setImageBitmap(resultImage);//表示されたのは、真っ白な画像で???状態、ストレージで確認すると真っ黒な画像になっている


                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        });
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • jimbe

    2019/06/13 18:40

    透明の確認ですが, 「ストレージに保存して確認」は jpeg でされたのでしょうか.
    jpeg は透明度の保存は無かったように思うのですが...
    png での保存では如何でしょう.

    キャンセル

  • sekaikan_ozaki

    2019/06/14 11:21

    保存はすべてjpegでした。

    提案していただきました、pngで保存して確認すると、透明な部分が表示されました!

    色々コードを改良してみましたところ、なぞった部分だけ抽出することができましたので、自己解決の方にまとめさせていただきます。
    jimbe様のおかげで、大きな1歩を進めました。ありがとうございました。

    キャンセル

回答 1

check解決した方法

0

「ストレージに保存して確認」の部分では、jpeg形式で保存していたので、透明度が考慮されていなかったと考えられた。
そこで、透明度の情報を持つことができるpng形式に変えたところう上手くいきました。
なので、なぞった画像(画像1)がすでにpngで用意することができたので、マスク画像としてそのまま、画像3とのPorterDuff.Mode.DST_INを実現することができました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • Java

    16124questions

    Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

  • Android

    7387questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • Android Studio

    4356questions

    Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。