Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
CSDN 技术社区
skill_tree_opencv
提交
c9c8dc62
S
skill_tree_opencv
项目概览
CSDN 技术社区
/
skill_tree_opencv
通知
45
Star
9
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
2
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
skill_tree_opencv
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
2
Issue
2
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
c9c8dc62
编写于
12月 17, 2021
作者:
F
feilong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix png
上级
59823dfe
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
50 addition
and
6 deletion
+50
-6
data/1.OpenCV初阶/2.二值图像处理/4.连通区域分析/connect.md
data/1.OpenCV初阶/2.二值图像处理/4.连通区域分析/connect.md
+2
-2
main.py
main.py
+8
-4
src/img.py
src/img.py
+40
-0
未找到文件。
data/1.OpenCV初阶/2.二值图像处理/4.连通区域分析/connect.md
浏览文件 @
c9c8dc62
...
...
@@ -2,11 +2,11 @@
OpenCV 里的连通区域分析可以将具有相同像素值且位置相邻的前景像素点组成的图像区域识别出来。有两种像素相邻的定义:
![](
.
/pixel_region.jpg
)
![](
data/1.OpenCV初阶/2.二值图像处理/4.连通区域分析
/pixel_region.jpg
)
通过OpenCV的连通区域分析算法,我们可以将下图的水鸭子的外框框出来:
![](
.
/duck_box.png
)
![](
data/1.OpenCV初阶/2.二值图像处理/4.连通区域分析
/duck_box.png
)
框架代码如下:
...
...
main.py
浏览文件 @
c9c8dc62
# -*- coding: utf-8 -*-
from
src.tree
import
TreeWalker
from
src.doc
import
DocWalker
from
src.img
import
ImgWalker
if
__name__
==
'__main__'
:
walker
=
TreeWalker
(
"data"
,
"opencv"
,
"OpenCV"
)
walker
.
walk
()
#
walker = TreeWalker("data", "opencv", "OpenCV")
#
walker.walk()
doc
=
DocWalker
(
'doc'
)
doc
.
walk
()
# doc = DocWalker('doc')
# doc.walk()
img
=
ImgWalker
(
'data'
)
img
.
walk
()
src/img.py
0 → 100644
浏览文件 @
c9c8dc62
import
os
from
sys
import
path
,
version
from
types
import
new_class
from
.tree
import
load_json
,
dump_json
def
simple_list_md_load
(
p
):
with
open
(
p
,
'r'
,
encoding
=
'utf-8'
)
as
f
:
lines
=
f
.
readlines
()
result
=
[]
for
line
in
lines
:
item
=
line
.
strip
(
'
\n
'
)
result
.
append
(
item
)
return
result
def
simple_list_md_dump
(
p
,
lines
):
with
open
(
p
,
'w'
,
encoding
=
'utf-8'
)
as
f
:
f
.
write
(
'
\n
'
.
join
(
lines
))
class
ImgWalker
():
def
__init__
(
self
,
root
)
->
None
:
self
.
root
=
root
def
walk
(
self
):
for
base
,
dirs
,
files
in
os
.
walk
(
self
.
root
):
for
file
in
files
:
if
file
[
-
3
:]
==
'.md'
:
md_file
=
os
.
path
.
join
(
base
,
file
)
md_lines
=
simple_list_md_load
(
md_file
)
md_new
=
[]
for
line
in
md_lines
:
new_line
=
line
.
replace
(
'![](./'
,
f
'![](
{
base
}
/'
)
md_new
.
append
(
new_line
)
md_new
.
append
(
''
)
simple_list_md_dump
(
md_file
,
md_new
)
import
sys
sys
.
exit
(
0
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录