web-dev-qa-db-ja.com

ビットマップの周りにグロー効果を作成するにはどうすればよいですか?

次のコードは私がこれまでに得たものです。ただし、2つの問題があります。

  1. Photoshopのブレンドオプションに似た、内側と外側の両方のグロー効果が必要です。しかし、私はなんとか外側を輝かせることができました。BlurMaskFilter.Blur.INNERまたは他の値を設定すると、エッジだけでなく、画像全体がブロックされます。

  2. [〜#〜] ff [〜#〜]」をアルファ値として設定したにもかかわらず、グローの色はまだ非常に暗いです。

    Bitmap alpha = Origin.extractAlpha();
    BlurMaskFilter blurMaskFilter = new BlurMaskFilter(5, BlurMaskFilter.Blur.OUTER);
    
    Paint paint = new Paint();
    Paint.setMaskFilter(blurMaskFilter);
    Paint.setColor(0xffffffff);
    
    Canvas canvas = new Canvas(Origin);
    canvas.drawBitmap(alpha, 0, 0, Paint);
    
    return Origin;
    

alt text

25
Hongbo

XGouchetの回答 に基づいてこれを試してください。

private void setBackgroundGlow(ImageView imgview, int imageicon,int r,int g,int b)
{
    // An added margin to the initial image
    int margin = 24;
    int halfMargin = margin / 2;
    // the glow radius
    int glowRadius = 40;

    // the glow color
    int glowColor = Color.rgb(r, g, b);

    // The original image to use
    Bitmap src = BitmapFactory.decodeResource(getResources(),imageicon);

    // extract the alpha from the source image
    Bitmap alpha = src.extractAlpha();

    // The output bitmap (with the icon + glow)
    Bitmap bmp =  Bitmap.createBitmap(src.getWidth() + margin, src.getHeight() + margin, Bitmap.Config.ARGB_8888);

    // The canvas to Paint on the image
    Canvas canvas = new Canvas(bmp);

    Paint paint = new Paint();
    Paint.setColor(glowColor);

    // outer glow
    Paint.setMaskFilter(new BlurMaskFilter(glowRadius, Blur.OUTER));//For Inner glow set Blur.INNER
    canvas.drawBitmap(alpha, halfMargin, halfMargin, Paint);

    // original icon
    canvas.drawBitmap(src, halfMargin, halfMargin, null);

    imgview.setImageBitmap(bmp);


}
5
Nik

これが解決策です:

http://www.shaikhhamadali.blogspot.ro/2013/06/highlightfocusshadow-image-in-imageview.html

 public Bitmap highlightImage(Bitmap src) {
        // create new bitmap, which will be painted and becomes result image
        Bitmap bmOut = Bitmap.createBitmap(src.getWidth() + 96, src.getHeight() + 96, Bitmap.Config.ARGB_8888);
        // setup canvas for painting
        Canvas canvas = new Canvas(bmOut);
        // setup default color
        canvas.drawColor(0, PorterDuff.Mode.CLEAR);
        // create a blur Paint for capturing alpha
        Paint ptBlur = new Paint();
        ptBlur.setMaskFilter(new BlurMaskFilter(15, Blur.NORMAL));
        int[] offsetXY = new int[2];
        // capture alpha into a bitmap
        Bitmap bmAlpha = src.extractAlpha(ptBlur, offsetXY);
        // create a color Paint
        Paint ptAlphaColor = new Paint();
        ptAlphaColor.setColor(0xFFFFFFFF);
        // Paint color for captured alpha region (bitmap)
        canvas.drawBitmap(bmAlpha, offsetXY[0], offsetXY[1], ptAlphaColor);
        // free memory
        bmAlpha.recycle();

        // Paint the image source
        canvas.drawBitmap(src, 0, 0, null);

        // return out final image
        return bmOut;
    }

これにより、画像ビットマップ効果の詳細について質問が飛び交います。ブログの次のリンクにアクセスしてください。

www.shaikhhamadali.blogspot.com

Highlight/focus/shadow the image in ImageView
Invert the Image in ImageView
Gray Scale the Image in ImageView (Android)
set Gamma of image in ImageView
Saturation Filter Effect on image in ImageView
Hue Filter Effect on image in ImageView
Engraving Effect on image in ImageView
Emboss Effect on image in ImageView
Smooth Effect on image in ImageView
Mean Removal Effect on image in ImageView
Set sharpness of the image in ImageView
Gaussian Blur the image(Bitmap) in ImageView
Convolution Matrix for image processing
Color Boost the image(Bitmap) in ImageView
Set brightness of the image(increase,decrease) in ImageView
B/W Contrast and Color Contrast the image in ImageView 
Reducing color depth of image in ImageView
Sepia-toning Effect (Photography) of image in ImageView
filter color channels/ set color channels of image in ImageView
Change/Replacement/Remove pixel colors in ImageView
Water Mark the Image in ImageView
4
Hamad

これを行う方法は、カラーフィルターの輪郭を作成し、それをぼかすことです。この例が役立つ場合があります: Androidビットマップの輪郭

1
Lumis
BlurMaskFilter.Blur.NORMAL maybe fit your necessary.

Comments from official:
NORMAL(0),  //!< blur inside and outside of the original border
SOLID(1),   //!< include the original mask, blur outside
OUTER(2),   //!< just blur outside the original border
INNER(3);   //!< just blur inside the original border
1
marine8888

Androidにはグロー効果を作成する方法はないと思います。最初から作成するか、これをサポートするJavaライブラリを見つける必要があります。

私が使用するのが好きな最も簡単なことは、画像のレイヤーを作成することです。基本的に、相対レイアウトを定義し、2つのimageViewを上下に配置します。独自のレイヤーでフォトショップ効果を作成し、そのレイヤーをラスタライズし、pngに保存して、画像の上に配置するだけです。ただし、大きな画像でこの方法を使用している場合は、VM例外を超えています。ビューサイズに応じてビットマップをリサンプリングすることは、この問題のかなり良い解決策です。

私の頭に浮かぶもう1つの方法は、画像にグラデーションを描画することです(例:中央が透明で、エッジが白く放射状のグラデーション-白い輝きを得る)が、この方法では、正確に調整するのに時間がかかります。私の意見では、あなたが必要としているものは努力する価値がありません)。

また、ここにJava画像フィルターを作成するサイトへのリンクがあります。多分あなたはあなたのために仕事をする何かを見つけることができます。

http://www.jhlabs.com/ip/filters/index.html

1
DArkO