enzoyang 最近的时间轴更新
enzoyang

enzoyang

V2EX 第 171831 号会员,加入于 2016-05-05 16:47:08 +08:00
enzoyang 最近回复了
2021-04-25 10:04:34 +08:00
回复了 enzoyang 创建的主题 问与答 怎样判断横屏视频是中间包含完整竖屏,两边模糊的视频?
应该是 detect_vertical_edges,代码里弄混了
2021-04-24 16:37:52 +08:00
回复了 enzoyang 创建的主题 问与答 怎样判断横屏视频是中间包含完整竖屏,两边模糊的视频?
谢谢大家的提示,我试验了一下,边缘检测加判断图中竖直的边缘应该够用了

```
def detect_horizontal_edges(cv_img) -> list:
"""找出图片中的竖线边界"""

if isinstance(cv_img, str):
cv_img = cv2.imread(cv_img)

# 转成灰度
gray_img = cv2.cvtColor(cv_img, cv2.COLOR_BGR2GRAY)
# 边缘检测
canny = cv2.Canny(gray_img, 20, 100)
# 加粗边缘
kernal = cv2.getStructuringElement(cv2.MORPH_RECT, (2, 2))
dilated = cv2.dilate(canny, kernal)

# 判断竖线
h, w = dilated.shape[0], dilated.shape[1]
threshold = int(h * 0.75)
edge_positions = []
for x in range(w):
white_dots = 0
for y in range(h):
if dilated[y, x] == 255:
white_dots += 1
if white_dots > threshold:
edge_positions.append(x)

return edge_positions
```
关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1736 人在线   最高记录 6543   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 13ms · UTC 16:43 · PVG 00:43 · LAX 09:43 · JFK 12:43
Developed with CodeLauncher
♥ Do have faith in what you're doing.