首页 > 其他 > 详细

浮雕效果函数

时间:2014-07-14 10:15:44      阅读:419      评论:0      收藏:0      [点我收藏+]

这篇将讲到图片特效处理的浮雕效果。跟前面一样是对像素点进行处理,算法是通用的。

算法原理:用前一个像素点的RGB值分别减去当前像素点的RGB值并加上127作为当前像素点的RGB值。

例:

ABC

求B点的浮雕效果如下:

B.r = C.r - B.r + 127;

B.g = C.g - B.g + 127;

B.b = C.b - B.b + 127;

注意RGB值在0~255之间。

效果图:

bubuko.com,布布扣bubuko.com,布布扣

 

                     原图                                                                              效果图

 

 

 

[java] view plaincopy
 
    1. package com.color;  
    2.   
    3. import android.content.Context;  
    4. import android.graphics.Bitmap;  
    5. import android.graphics.BitmapFactory;  
    6. import android.graphics.Canvas;  
    7. import android.graphics.Color;  
    8. import android.graphics.Paint;  
    9. import android.util.AttributeSet;  
    10. import android.widget.ImageView;  
    11.   
    12. public class ColorView extends ImageView {  
    13.   
    14.     private Paint myPaint = null;  
    15.     private Bitmap bitmap = null;  
    16.     private int width,height;  
    17.     private int[] oldPixels;    
    18.     private int[] newPixels;    
    19.     private int color,color2;  
    20.     private int pixelsR,pixelsG,pixelsB,pixelsA,pixelsR2,pixelsG2,pixelsB2;  
    21.       
    22.     public ColorView(Context context, AttributeSet attrs)  
    23.     {  
    24.         super(context, attrs);  
    25.         bitmap = BitmapFactory.decodeResource(context.getResources(),R.drawable.ww);   
    26.         width = bitmap.getWidth();    
    27.         height = bitmap.getHeight();  
    28.         oldPixels = new int[width*height];   
    29.         newPixels = new int[width*height];  
    30.         invalidate();  
    31.     }  
    32.     @Override  
    33.     protected void onDraw(Canvas canvas) {  
    34.         super.onDraw(canvas);   
    35.         //获取像素  
    36.         bitmap.getPixels(oldPixels, 0, width, 0, 0, width, height);  
    37.           
    38.         for(int i = 1;i < height*width; i++){  
    39.                 color = oldPixels[i-1];  
    40.                 //前一个像素  
    41.                 pixelsR = Color.red(color);  
    42.                 pixelsG = Color.green(color);  
    43.                 pixelsB = Color.blue(color);  
    44.                 //当前像素  
    45.                 color2 = oldPixels[i];  
    46.                 pixelsR2 = Color.red(color2);  
    47.                 pixelsG2 = Color.green(color2);  
    48.                 pixelsB2 = Color.blue(color2);  
    49.                   
    50.                 pixelsR = (pixelsR - pixelsR2 + 127);  
    51.                 pixelsG = (pixelsG - pixelsG2 + 127);  
    52.                 pixelsB = (pixelsB - pixelsB2 + 127);  
    53.                 //均小于等于255  
    54.                 if(pixelsR > 255){  
    55.                     pixelsR = 255;  
    56.                 }  
    57.                   
    58.                 if(pixelsG > 255){  
    59.                     pixelsG = 255;  
    60.                 }  
    61.                   
    62.                 if(pixelsB > 255){  
    63.                     pixelsB = 255;  
    64.                 }  
    65.                   
    66.                 newPixels[i] = Color.argb(pixelsA, pixelsR, pixelsG, pixelsB);  
    67.                   
    68.         }  
    69.         bitmap.setPixels(newPixels, 0, width, 0, 0, width, height);  
    70.         canvas.drawBitmap(bitmap,0,0,myPaint);  
    71.     }  
    72. }  

浮雕效果函数,布布扣,bubuko.com

浮雕效果函数

原文:http://www.cnblogs.com/clarence/p/3837484.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!