问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

通过图像识别技术监控屏幕画面卡死问题

创作时间:
作者:
@小白创作中心

通过图像识别技术监控屏幕画面卡死问题

引用
1
来源
1.
https://www.cnblogs.com/skyflask/p/8280922.html

本文介绍了一种通过图像识别技术(OpenCV)来监控屏幕画面卡死问题的解决方案。文章详细描述了问题的背景、需求分析、解决方案以及具体实现步骤,具有较高的技术价值和实用性。

一、背景需求

某公司视频组在录制游戏PVP视频时,遇到了录制程序卡死的问题:虽然录制程序仍在运行,但后台渲染引擎出现异常,导致游戏画面停滞。为了解决这一问题,需要开发一种监控机制,能够在画面卡死时及时发出警报。

二、需求分析

针对这一需求,可以从以下几个层面进行分析:

  1. 数据层面:分析在渲染引擎工作异常时,数据包或网络流量是否会出现突变。
  2. 系统层面:监控录制程序的资源占用情况(CPU/内存/IO),查看画面卡住时是否有异常。
  3. 代码层面:检查录制程序的日志输出,看是否能发现错误信息。

经过分析发现:

  • 数据层面:渲染引擎工作异常时,数据包大小没有变化。
  • 系统层面:录制程序的资源占用情况在引擎异常时基本不变。
  • 代码层面:虽然有错误日志产生,但重启渲染引擎并不能完全解决问题,有时仍需要重启整个录制程序。

因此,需要开发一种能够自动检测画面卡死情况的监控机制。

三、解决方案

最初尝试了一些简单的方法,如使用按键精灵截取屏幕并比较图片大小,或者通过MD5值比较截图文件,但这些方法都无法有效解决问题。最终,决定采用机器学习和图像识别技术来实现监控。

四、OpenCV实现

OpenCV简介

OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习软件库,提供了丰富的图像处理和计算机视觉算法,广泛应用于商业产品中。

图片识别原理

OpenCV通过识别图像的特征并计算相似度来判断两张图片是否相同。具体实现步骤如下:

  1. 抓取当前屏幕并保存为图片文件。
  2. 获取当前目录下所有PNG文件。
  3. 获取最新的两张图片。
  4. 计算两张图片的相似度并写入文件。

以下是具体的Python代码实现:

#!/usr/bin/env python
# coding:utf-8
from PIL import ImageGrab
import time
import os
import cv2
import numpy as np
from matplotlib import pyplot as plt

# 抓取当前屏幕
cur_dir = os.path.dirname(__file__)
im = ImageGrab.grab()
im.save(os.path.join(cur_dir,"%s.png" %time.time()))

# 获取当前目录下所有png文件
def all_path(dirname):
    result = []
    for maindir, subdir, file_name_list in os.walk(dirname):
        for filename in file_name_list:
            if filename.endswith('.png'):
                apath = os.path.join(maindir, filename)
                result.append(apath)
    return result

# 获取最新的两个文件
def get_max_two(file_list):
    rt = []
    for f in file_list:
        rt.append((f,os.path.getctime(f)))
    rt = sorted(rt,key=lambda x:x[1],reverse=True)
    return rt[0][0],rt[1][0]

# 计算单通道的直方图的相似值
def calculate(image1, image2):
    hist1 = cv2.calcHist([image1], [0], None, [256], [0.0, 255.0])
    hist2 = cv2.calcHist([image2], [0], None, [256], [0.0, 255.0])
    # 计算直方图的重合度
    degree = 0
    for i in range(len(hist1)):
        if hist1[i] != hist2[i]:
            degree = degree + (1 - abs(hist1[i] - hist2[i]) / max(hist1[i], hist2[i]))
        else:
            degree = degree + 1
    degree = degree / len(hist1)
    return degree

# 通过得到每个通道的直方图来计算相似度
def classify_hist_with_split(image1, image2, size=(256, 256)):
    # 将图像resize后,分离为三个通道,再计算每个通道的相似值
    image1 = cv2.resize(image1, size)
    image2 = cv2.resize(image2, size)
    sub_image1 = cv2.split(image1)
    sub_image2 = cv2.split(image2)
    sub_data = 0
    for im1, im2 in zip(sub_image1, sub_image2):
        sub_data += calculate(im1, im2)
    sub_data = sub_data / 3
    return sub_data

if __name__ == '__main__':
    # 获取2张图片的相似度
    cur_dir = os.path.dirname(__file__)
    file_list = all_path(cur_dir)
    img1, img2 = get_max_two(file_list)
    img1 = cv2.imread(img1)
    img2 = cv2.imread(img2)
    degree = classify_hist_with_split(img1, img2)
    if isinstance(degree, int):
        with open(os.path.join(cur_dir, "a.txt"), 'w+') as f:
            f.write(str(degree))
    else:
        with open(os.path.join(cur_dir,"a.txt"),'w+') as f:
            f.write(str(degree[0]))

实现步骤

  1. 设置计划任务:将上述脚本添加到系统的计划任务中定期运行。
  2. 通过Zabbix进行监控
  • 自定义监控项UserParameter=get_degree,type d:\pych\a.txt
  • 获取监控值[root@localhost ~]# zabbix_get -s 10.20.122.18 -kget_degree
  • 设置触发器:当相似度达到99%以上时触发警报。

通过这种方式,可以有效地监控屏幕画面卡死的问题,并及时发出警报。

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号