Android OpenCV(三十六):轮廓面积与周长

public static double arcLength(MatOfPoint2f curve, boolean closed)

  • 参数一:curve,轮廓的像素点。
  • 参数二:closed,轮廓是否闭合的标志位,true表示闭合,false表示不闭合。例如,计算三个点A,B,C的距离,若closed=true,则周长=AB+BC+CA,若closed=false,则周长=AB+BC。

操作

结合上篇《轮廓发现与绘制》示例,计算各轮廓的面积和周长。

/**

  • 轮廓发现、绘制、面积、周长
  • author: yidong
  • 2020/9/19
    */
    class FindContoursActivity : AppCompatActivity() {
    private lateinit var mBinding: ActivityFindContoursBinding
    private lateinit var mSource: Mat
    private var level = 1
    set(value) {
    field = value
    find()
    mBinding.level.text = level.toString()
    }

private var mFlag = Imgproc.RETR_TREE
set(value) {
field = value
find()
}

private var ignoreLevel = true
set(value) {
field = value
find()
}

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
mBinding = DataBindingUtil.setContentView(this, R.layout.activity_find_contours)
mBinding.ignoreLevel.setOnCheckedChangeListener { _, isChecked ->
ignoreLevel = isChecked
}
val bgr = Utils.loadResource(this, R.drawable.hierarchy)
mSource = Mat()
Imgproc.cvtColor(bgr, mSource, Imgproc.COLOR_BGR2RGB)
mBinding.ivLena.showMat(mSource)
title = “RETR_TREE”
}

override fun onCreateOptionsMenu(menu: Menu?): Boolean {
menuInflater.inflate(R.menu.menu_contours, menu)
return true
}

override fun onOptionsItemSelected(item: MenuItem): Boolean {
title = item.title
mFlag = when (item.itemId) {
R.id.retr_external -> Imgproc.RETR_EXTERNAL
R.id.retr_list -> Imgproc.RETR_LIST
R.id.retr_ccomp -> Imgproc.RETR_CCOMP
else -> Imgproc.RETR_TREE
}
return true
}

private fun find() {
val tmp = mSource.clone()
val gray = Mat()
Imgproc.cvtColor(mSource, gray, Imgproc.COLOR_BGR2GRAY)
Imgproc.GaussianBlur(gray, gray, Size(13.0, 13.0), 4.0, 4.0)
val binary = Mat()
Imgproc.threshold(gray, binary, 170.0, 255.0, Imgproc.THRESH_BINARY and Imgproc.THRESH_OTSU)

val contours = mutableListOf()
val hierarchy = Mat()
Imgproc.findContours(
binary,
contours,
hierarchy,
mFlag,
Imgproc.CHAIN_APPROX_SIMPLE
)

for (i in 0 until contours.size) {
val area = Imgproc.contourArea(contours[i])
val source = MatOfPoint2f()
source.fromList(contours[i].toList())
val length = Imgproc.arcLength(source, true)
Log.d(App.TAG, “轮廓 i 面积: {i}面积: i面积:{area}; 周长:${length}”)
}

if (ignoreLevel) {
Imgproc.drawContours(
tmp,
contours,
-1,
Scalar(255.0, 0.0, 0.0),
2,
Imgproc.LINE_AA
)
} else {
Imgproc.drawContours(
tmp,
contours,
-1,
Scalar(255.0, 0.0, 0.0),
2,
Imgproc.LINE_AA,
hierarchy,
level
)
}
mBinding.ivResult.showMat(tmp)
Log.d(App.TAG, “hierarchy: ${hierarchy.dump()}”)
gray.release()
binary.release()
hierarchy.release()

最后

简历首选内推方式,速度快,效率高啊!然后可以在拉钩,boss,脉脉,大街上看看。简历上写道熟悉什么技术就一定要去熟悉它,不然被问到不会很尴尬!做过什么项目,即使项目体量不大,但也一定要熟悉实现原理!不是你负责的部分,也可以看看同事是怎么实现的,换你来做你会怎么做?做过什么,会什么是广度问题,取决于项目内容。但做过什么,达到怎样一个境界,这是深度问题,和个人学习能力和解决问题的态度有关了。大公司看深度,小公司看广度。大公司面试你会的,小公司面试他们用到的你会不会,也就是岗位匹配度。

选定你想去的几家公司后,先去一些小的公司练练,学习下面试技巧,总结下,也算是熟悉下面试氛围,平时和同事或者产品PK时可以讲得头头是道,思路清晰至极,到了现场真的不一样,怎么描述你所做的一切,这绝对是个学术性问题!

面试过程一定要有礼貌!即使你觉得面试官不尊重你,经常打断你的讲解,或者你觉得他不如你,问的问题缺乏专业水平,你也一定要尊重他,谁叫现在是他选择你,等你拿到offer后就是你选择他了。

金九银十面试季,跳槽季,整理面试题已经成了我多年的习惯!在这里我和身边一些朋友特意整理了一份快速进阶为Android高级工程师的系统且全面的学习资料。涵盖了Android初级——Android高级架构师进阶必备的一些学习技能。

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)


《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
[外链图片转存中…(img-lrf5J1hM-1714550353211)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 9
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值