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学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!