1、下载美图秀秀apk,使用反编译软件“Android逆向助手”提取里面的jni.java文件到我们的工程里
package com.mt.mtxx.image;
public class JNI
{
public native void AutoColor(byte[] paramArrayOfByte, int paramInt1, int paramInt2, int paramInt3, int paramInt4);
public native void AutoColorLevel(byte[] paramArrayOfByte, int paramInt1, int paramInt2, boolean paramBoolean);
.............................
}
2、包名称不能变package com.mt.mtxx.image
3、解压美图秀秀的apk把,lib目录下的libmtimage-jni.so拷贝到工程里的armeabi目录下
4、创建页面,加载so文件System.loadLibrary(“mtimage-jni”);
/**
* @描述 美图秀秀
* @项目名称 App_imooc
* @包名 com.android.imooc.jni
* @类名 ArrayActivity
* @author chenlin
* @date 2014年6月7日 下午10:26:02
* @version 1.0
*/
public class XiuXiuActivity extends Activity{
private ImageView iv;
private Bitmap mBitmap;
static{
//加载类库
System.loadLibrary("mtimage-jni");
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_jni_xiuxiu);
mBitmap = BitmapFactory.decodeFile("sdcard/girl.jpg");
iv = (ImageView) findViewById(R.id.imageView1);
iv.setImageBitmap(mBitmap);
}
public void canvas(View view){
}
}
5、实现方法:
public void canvas(View view){
JNI jni = new JNI();
int width = mBitmap.getWidth();
int height =mBitmap.getHeight();
int[] pixels = new int[width * height];
mBitmap.getPixels(pixels, 0, width, 0, 0, width, height);
//int[] paramArrayOfInt 表示像素;
//int paramInt1; 宽
//int paramInt2; 高
jni.StyleLomoB(pixels, width, height);
Bitmap createBitmap = Bitmap.createBitmap(pixels, width, height, mBitmap.getConfig());
mImageView.setImageBitmap(createBitmap);
}
6、bitmap.getPixels方法说明:
public void getPixels (int[] pixels, int offset, int stride, int x, int y, int width, int height)
把位图的数据拷贝到pixels[]中。每一个都由一个表示颜色值的int值来表示。幅度参数表明调用者允许的像素数组行间距。对通常的填充结果,只要传递宽度值给幅度参数。
参数
pixels 接收位图颜色值的数组
offset 写入到pixels[]中的第一个像素索引值
stride pixels[]中的行间距个数值(必须大于等于位图宽度)。可以为负数
x 从位图中读取的第一个像素的x坐标值。
y 从位图中读取的第一个像素的y坐标值
width 从每一行中读取的像素宽度
height 读取的行数
7、布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="canvas"
android:text="美颜" />
<ImageView
android:id="@+id/imageView1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:src="@drawable/pic_6" />
LinearLayout>
8、下载
http://pan.baidu.com/s/1skLTfT7