opencv-kmeans-图片颜色量化

牙叔教程 简单易懂

效果展示

录制_2022_02_28_17_40_39_155.gif
1.png
2.png
3.png

KMeans 数据分类

  • KMeans算法的作者是MacQueen, KMeans的算法是对数据进行分类的算法,采用的硬分类方式,是属于非监督学习的算法;
  • 对于给定的样本集,按照样本之间的距离大小,将样本划分为K个簇,让簇内的点尽量紧密的连接在一起,而让簇间的距离尽量的大。

参数控制

  • 聚类的颜色数量, 第一张图片是3个颜色, 其他是10个颜色

技能点

  • 全屏
  • 在autojs中使用kmeans
  • 选择文件
  • 绘制色卡
  • list的使用
  • 浏览和保存mat
  • 颜色rgb三通道分离
  • toolbar修改左上角图标及其颜色

环境

手机: Mi 11 Pro

Android版本: 12

Autojs版本: 9.1.6

代码讲解

1. 色卡是一个View
<View id="colorCard" marginTop="10" h="40dp" visibility="gone" bg="#ff0000"></View>

颜色聚类, 获取到数据以后, 绘制色卡用下面的方法

function drawColor(view, dataList) {
  var drawable = new android.graphics.drawable.Drawable({
    draw: function (canvas) {
      var len = dataList.length;
      let viewWidth = view.getWidth();
      let viewHeight = view.getHeight();
      let lastX = 0;
      let paint = new android.graphics.Paint();
      for (var i = 0; i < len; i++) {
        let color = dataList[i].color;
        let percent = dataList[i].percent;
        let x = lastX;
        let y = 0;
        let width = viewWidth * percent;
        let height = viewHeight;
        lastX = x + width;
        let rect = new android.graphics.Rect(x, y, x + width, y + height);
        paint.setColor(colors.parseColor(color));
        canvas.drawRect(rect, paint);
      }
    },
  });
  view.setBackgroundDrawable(drawable);
}
2. 颜色列表
<list id="list" marginTop="10">
    <horizontal gravity="center" w="*" marginTop="16">
        <card cardCornerRadius="15" w="30" h="30" marginRight="60" bg="#ff00ff">
            <View id="colorDisplayArea" bg="{{this.color}}">
            </View>
        </card>
        <text id="colorValue" w="110dp" marginRight="60" text="{{this.color}}" size="20sp" textColor="#000000">
        </text>
        <text id="colorRatio" w="60dp" text="{{this.percent}}" size="20sp" textColor="#000000">
        </text>
    </horizontal>
</list>

美观一点, 我们把View呈现为圆形, 再显示颜色数值, 和颜色的比例

3. 选择文件
ui.logo.click(function () {
  intent = new Intent(Intent.ACTION_PICK, android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);
  activity.startActivityForResult(intent, imgRequestCode);
});

选择文件之前, 要设置文件选择监听, 然后获取到文件路径

4. 监听文件选择结果
activity.getEventEmitter().on("activity_result", (requestCode, resultCode, data) => {
  if (requestCode == imgRequestCode) {
    if (resultCode == activity.RESULT_OK) {
      let uri = data.getData();
      let path = uri.getPath();
      path = decodeURIComponent(path);
    }
  }
});
5, 模块调试
if (typeof module === "object") {
  module.exports = getColorData;
} else {
  let imgPath = "./small11645897022391.png";
  getColorData(imgPath);
}

有时候要单独调试模块, 不想频繁的切换注释module.exports, 就可以通过判断module是不是object,

如果是就说明是当模块来使用, 如果不是就说明在调试模块,

这样就不用一直切换module.exports的注释了

6. 图片类型
Imgproc.cvtColor(mat, mat2, Imgproc.COLOR_BGRA2RGBA);

保存图片之前, 需要转换图片的颜色类型, 因为opencv是bgr格式的图片, autojs是rgb格式的图片

名人名言

思路是最重要的, 其他的百度, bing, stackoverflow, github, 安卓文档, autojs文档, 最后才是群里问问
--- 牙叔教程

声明

部分内容来自网络
本教程仅用于学习, 禁止用于其他用途

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,376评论 6 491
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,126评论 2 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,966评论 0 347
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,432评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,519评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,792评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,933评论 3 406
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,701评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,143评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,488评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,626评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,292评论 4 329
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,896评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,742评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,977评论 1 265
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,324评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,494评论 2 348

推荐阅读更多精彩内容