/**

* 素描效果

*

* @param bmp

* @return

*/

public static Bitmap convertToSketch(Bitmap bmp) {

int pos, row, col, clr;

int width = bmp.getWidth();

int height = bmp.getHeight();

int[] pixSrc = new int[width * height];

int[] pixNvt = new int[width * height];

// 先对图象的像素处理成灰度颜色后再取反

bmp.getPixels(pixSrc, 0, width, 0, 0, width, height);

for (row = 0; row < height; row++) {

for (col = 0; col < width; col++) {

pos = row * width + col;

pixSrc[pos] = (Color.red(pixSrc[pos])

+ Color.green(pixSrc[pos]) + Color.blue(pixSrc[pos])) / 3;

pixNvt[pos] = 255 - pixSrc[pos];

}

}

// 对取反的像素进行高斯模糊, 强度可以设置,暂定为5.0

gaussGray(pixNvt, 5.0, 5.0, width, height);

// 灰度颜色和模糊后像素进行差值运算

for (row = 0; row < height; row++) {

for (col = 0; col < width; col++) {

pos = row * width + col;

clr = pixSrc[pos] << 8;

clr /= 256 - pixNvt[pos];

clr = Math.min(clr, 255);

pixSrc[pos] = Color.rgb(clr, clr, clr);

}

}

bmp.setPixels(pixSrc, 0, width, 0, 0, width, height);

return bmp;

}

private static int gaussGray(int[] psrc, double horz, double vert,

int width, int height) {

int[] dst, src;

double[] n_p, n_m, d_p, d_m, bd_p, bd_m;

double[] val_p, val_m;

int i, j, t, k, row, col, terms;

int[] initial_p, initial_m;

double std_dev;

int row_stride = width;

int max_len = Math.max(width, height);

int sp_p_idx, sp_m_idx, vp_idx, vm_idx;

val_p = new double[max_len];

val_m = new double[max_len];

n_p = new double[5];

n_m = new double[5];

d_p = new double[5];

d_m = new double[5];

bd_p = new double[5];

bd_m = new double[5];

src = new int[max_len];

dst = new int[max_len];

initial_p = new int[4];

initial_m = new int[4];

// 垂直方向

if (vert > 0.0) {

vert = Math.abs(vert) + 1.0;

std_dev = Math.sqrt(-(vert * vert) / (2 * Math.log(1.0 / 255.0)));

// 初试化常量

findConstants(n_p, n_m, d_p, d_m, bd_p, bd_m, std_dev);

for (col = 0; col < width; col++) {

for (k = 0; k < max_len; k++) {

val_m[k] = val_p[k] = 0;

}

for (t = 0; t < height; t++) {

src[t] = psrc[t * row_stride + col];

}

sp_p_idx = 0;

sp_m_idx = height - 1;

vp_idx = 0;

vm_idx = height - 1;

initial_p[0] = src[0];

initial_m[0] = src[height - 1];

for (row = 0; row < height; row++) {

terms = (row < 4) ? row : 4;

for (i = 0; i <= terms; i++) {

val_p[vp_idx] += n_p[i] * src[sp_p_idx - i] - d_p[i]

* val_p[vp_idx - i];

val_m[vm_idx] += n_m[i] * src[sp_m_idx + i] - d_m[i]

* val_m[vm_idx + i];

}

for (j = i; j <= 4; j++) {

val_p[vp_idx] += (n_p[j] - bd_p[j]) * initial_p[0];

val_m[vm_idx] += (n_m[j] - bd_m[j]) * initial_m[0];

}

sp_p_idx++;

sp_m_idx--;

vp_idx++;

vm_idx--;

}

transferGaussPixels(val_p, val_m, dst, 1, height);

for (t = 0; t < height; t++) {

psrc[t * row_stride + col] = dst[t];

}

}

}

// 水平方向

if (horz > 0.0) {

horz = Math.abs(horz) + 1.0;

if (horz != vert) {

std_dev = Math.sqrt(-(horz * horz)

/ (2 * Math.log(1.0 / 255.0)));

// 初试化常量

findConstants(n_p, n_m, d_p, d_m, bd_p, bd_m, std_dev);

}

for (row = 0; row < height; row++) {

for (k = 0; k < max_len; k++) {

val_m[k] = val_p[k] = 0;

}

for (t = 0; t < width; t++) {

src[t] = psrc[row * row_stride + t];

}

sp_p_idx = 0;

sp_m_idx = width - 1;

vp_idx = 0;

vm_idx = width - 1;

initial_p[0] = src[0];

initial_m[0] = src[width - 1];

for (col = 0; col < width; col++) {

terms = (col < 4) ? col : 4;

for (i = 0; i <= terms; i++) {

val_p[vp_idx] += n_p[i] * src[sp_p_idx - i] - d_p[i]

* val_p[vp_idx - i];

val_m[vm_idx] += n_m[i] * src[sp_m_idx + i] - d_m[i]

* val_m[vm_idx + i];

}

for (j = i; j <= 4; j++) {

val_p[vp_idx] += (n_p[j] - bd_p[j]) * initial_p[0];

val_m[vm_idx] += (n_m[j] - bd_m[j]) * initial_m[0];

}

sp_p_idx++;

sp_m_idx--;

vp_idx++;

vm_idx--;

}

transferGaussPixels(val_p, val_m, dst, 1, width);

for (t = 0; t < width; t++) {

psrc[row * row_stride + t] = dst[t];

}

}

}

return 0;

}

private static void transferGaussPixels(double[] src1, double[] src2,

int[] dest, int bytes, int width) {

int i, j, k, b;

int bend = bytes * width;

double sum;

i = j = k = 0;

for (b = 0; b < bend; b++) {

sum = src1[i++] + src2[j++];

if (sum > 255)

sum = 255;

else if (sum < 0)

sum = 0;

dest[k++] = (int) sum;

}

}

private static void findConstants(double[] n_p, double[] n_m, double[] d_p,

double[] d_m, double[] bd_p, double[] bd_m, double std_dev) {

double div = Math.sqrt(2 * 3.141593) * std_dev;

double x0 = -1.783 / std_dev;

double x1 = -1.723 / std_dev;

double x2 = 0.6318 / std_dev;

double x3 = 1.997 / std_dev;

double x4 = 1.6803 / div;

double x5 = 3.735 / div;

double x6 = -0.6803 / div;

double x7 = -0.2598 / div;

int i;

n_p[0] = x4 + x6;

n_p[1] = (Math.exp(x1)

* (x7 * Math.sin(x3) - (x6 + 2 * x4) * Math.cos(x3)) + Math

.exp(x0) * (x5 * Math.sin(x2) - (2 * x6 + x4) * Math.cos(x2)));

n_p[2] = (2

* Math.exp(x0 + x1)

* ((x4 + x6) * Math.cos(x3) * Math.cos(x2) - x5 * Math.cos(x3)

* Math.sin(x2) - x7 * Math.cos(x2) * Math.sin(x3)) + x6

* Math.exp(2 * x0) + x4 * Math.exp(2 * x1));

n_p[3] = (Math.exp(x1 + 2 * x0)

* (x7 * Math.sin(x3) - x6 * Math.cos(x3)) + Math.exp(x0 + 2

* x1)

* (x5 * Math.sin(x2) - x4 * Math.cos(x2)));

n_p[4] = 0.0;

d_p[0] = 0.0;

d_p[1] = -2 * Math.exp(x1) * Math.cos(x3) - 2 * Math.exp(x0)

* Math.cos(x2);

d_p[2] = 4 * Math.cos(x3) * Math.cos(x2) * Math.exp(x0 + x1)

+ Math.exp(2 * x1) + Math.exp(2 * x0);

d_p[3] = -2 * Math.cos(x2) * Math.exp(x0 + 2 * x1) - 2 * Math.cos(x3)

* Math.exp(x1 + 2 * x0);

d_p[4] = Math.exp(2 * x0 + 2 * x1);

for (i = 0; i <= 4; i++) {

d_m[i] = d_p[i];

}

n_m[0] = 0.0;

for (i = 1; i <= 4; i++) {

n_m[i] = n_p[i] - d_p[i] * n_p[0];

}

double sum_n_p, sum_n_m, sum_d;

double a, b;

sum_n_p = 0.0;

sum_n_m = 0.0;

sum_d = 0.0;

for (i = 0; i <= 4; i++) {

sum_n_p += n_p[i];

sum_n_m += n_m[i];

sum_d += d_p[i];

}

a = sum_n_p / (1.0 + sum_d);

b = sum_n_m / (1.0 + sum_d);

for (i = 0; i <= 4; i++) {

bd_p[i] = d_p[i] * a;

bd_m[i] = d_m[i] * b;

}

}

android图片管理实例,Android图片处理实例介绍(图)相关推荐

  1. 图片管理之获取图片列表数据

    图片管理 在图片表中我们需要对图片数据进行增删改查操作,这时候我们可以借助于视图集中的ModelViewset来完成相应的操作 获取图片列表数据 接口分析 请求方式: GET /meiduo_admi ...

  2. android fragment 管理器,Android Fragment 與 Fragment管理器

    Android Fragment 與 Fragment管理器 首先談談Fragement的需求 過去開發人員認為界面之間的跳轉只需要使用多個activity組成就行了: 例如下圖中,在Activity ...

  3. android studio管理依赖,Android Studio 中的 Gradle 依赖统一管理

    在我们的实际项目开发中,通常在一个 Project 项目中会存在多个 Module 的情况,在这些 Module 中会存在一些相同的版本依赖配置,针对进行版本升级的时候需要逐个修改,显得特别麻烦,所以 ...

  4. android电池管理软件,Android实现电池管理系统

    一.Android 电池服务 Android电池服务,用来监听内核上报的电池事件,并将最新的电池数据上报给系统,系统收到新数据后会去更新电池显示状态.剩余电量等信息.如果收到过温报警和低电报警,系统会 ...

  5. 运行android sdk管理器,Android SDK 安装配置

    Android SDK 可以通过 Android Command line tools(叫命令行工具或 SDK 工具)手动安装,也可以让 Android Studio 自动帮你下载安装,这里详细描述手 ...

  6. android 进程管理机制,Android的进程管理机制

    Linux系统对进程的管理方式是一旦进程活动停止,系统就会结束该进程.Android系统虽基于Linux,但在进程管理上,采取了另外一种机制.当当前进程活动停止时,系统并不会立即结束当前进程,而是会将 ...

  7. Android壁纸管理(Android N)

    初识Android壁纸 本章将对壁纸的实现原理进行讨论.在Android中,壁纸分为静态与动态两种.静态壁纸是一张图片,而动态壁纸则以动画为表现形式,或者可以对用户的操作作出反应.这两种形式看似差异很 ...

  8. Android进程管理,Android开发者跳槽指南面试必备

    雪上加霜 本人一名Android程序员,今年29岁了.大厂小厂都呆过,现在在腾讯工作!明明工作顺利,家庭和睦儿女成全,但是总是会感觉到,一股无形的压力,推着我走!作为一名程序员我最怕的不是996,也是 ...

  9. android 屏幕管理软件,Android Screencast下载

    Android Screencast旨在将您的Android手机或平板电脑的屏幕活动记录到视频中.创建教程,将你的游戏记录到高清视频中,准备在网络上共享.屏幕录像机使用方便,输出设置为比特率,视频大小 ...

  10. android 内存管理 ion,Android学习之ION memory manager

    ION是google在Android4.0 ICS为了解决内存碎片管理而引入的通用内存管理器,它会更加融合kernel.目前QCOM MSM, NVDIA Tegra, TI OMAP, MRVL P ...

最新文章

  1. nginx limit_rate突然限速失败
  2. var_export()函数的使用举例(后续添加其他的php输出函数)
  3. ASP.NET Core amp; Docker 实战经验分享
  4. java在线找错_平台配置及测试错误提示及解决方案
  5. qlineedit限制输入数字_Excel单元格限制录入,实用小技巧
  6. ipv6 ospf配置方法_【思唯网络学院】网络故障大全及处理原理和方法
  7. 关于SWT中的Combo类和List类
  8. python装饰器函数执行后日志_python使用装饰器作日志处理的方法
  9. WinMerge只显示差异部分的设置方法
  10. MPMoviePlayerViewController 改良版播放器
  11. fortran调用MKL函数库中的gemm的fortran95接口计算矩阵相乘
  12. python身份证号真假验证_【趣味案例】用python制作全国身份证号验证及查询系统...
  13. reflections歌词翻译_Reflections中文歌词
  14. 信息技术测试计算机疑难问题处理,江苏省中小学信息技术等级考试常见问题处理.doc...
  15. 撩妹代码html,Web前端
  16. 数商云B2B商城系统订货功能为新能源汽车行业赋能,打造高质量发展生态圈
  17. 关于 OpenSSL“心脏出血”漏洞的分析
  18. E Enigmatic Partition 2020牛客暑期多校训练营(第八场)
  19. mysql 查看slow query_MySQL慢查询日志(slow log)
  20. 大学Python编程试卷真题!用python循环,输出1+11+111+1111+11111的值

热门文章

  1. 2021全国研究生数学建模竞赛B题思路
  2. 【三维路径规划】基于matlab狼群算法无人机三维路径规划【含Matlab源码 167期】
  3. 华为计算机充电指示灯,数码产品:华为p40充电指示灯不亮在哪里设置 有指示灯吗...
  4. python快乐数,快乐数 - SegmentFault 思否
  5. excel表格怎么调整行高和列宽_excel表格怎么调整高度和宽度
  6. mac ant编译android,mac 下Android及ant的环境变量配置
  7. php遍历path树,php 递归遍历文件树代码_PHP教程
  8. mysql union limit_mysql中的union和order by、limit
  9. CNN(卷积神经网络)、RNN(循环神经网络)、DNN(深度神经网络)概念区分理解
  10. vivi开发笔记【专辑】