百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

标注截图上的文字区域

bigegpt 2025-01-12 11:36 9 浏览

大家好,我是公众号3分钟学堂的郭立员~

前言

为了能够直观看到OCR文字识别的效果,决定在截图上标注文字区域,这样就能知道ocr识别工具的好不好用。

一、基本原理

①、通常OCR识别的返回值中包括识别的文字和文字的范围,利用这两种返回值在截图进行标注

②、使用悬浮窗在屏幕上做标注

每一个识别结果使用两个悬浮窗进行标注,第一个悬浮窗做成半透明的颜色块,用来标注范围,第二个悬浮窗用来显示识别的文字内容。

二、具体效果展示

三、使用的工具

本次使用的是前几天分享的一个本地ocr工具,大家如果想要的话,可以进入我的历史文章列表,找到那篇文章。

四、代码

①、核心显示代码

Function 显示区域(x1,y1,x2,y2,str,n)
    FW.NewFWindow "浮窗名" & n, x1, y1, x2 - x1, y2 - y1
    FW.SetBackColor("浮窗名" & n, "0000FF")
    FW.Opacity("浮窗名" & n, 50)    
    FW.NewFWindow("浮窗名1_"&n, x1, y2, x2-x1+20, y2-y1+10)
    FW.AddTextView "浮窗名1_" & n, "文字" & n, str, 0, 0, x2 - x1+20, y2 - y1+10
    FW.SetTextColor "文字" & n, "0000FF"
    FW.SetTextSize "文字" & n, 10
    FW.Opacity("浮窗名1_" & n, 0)
    FW.Show("浮窗名"&n)
    FW.Show("浮窗名1_"&n)
End Function


每个识别结果使用两个悬浮窗进行显示,由于我们识别的截图可能有多个文字块,那么就需要多组悬浮窗,考虑到不确定数量,这里使用“有序命名”的方法,也就是(悬浮窗+序号),并且每组两个悬浮窗的其中一个也加上了 “1_”的后缀。

此函数有6个参数:

前四个(x1,y1,x2,y2)是文字块范围

str 是识别的文字内容

n 是序号,代表识别到第几个文字块了

②、完整代码

大家都喜欢用现成的代码,这里我结合之前那个ocr,做了个完整的代码,function内容可以不用修改,只要框选屏幕上一个要识别的文字范围即可。

Import "zm.luae"
zm.init 
ocr文字识别(35,81,667,534)
Do
    Delay 1000
Loop
 
Function ocr文字识别(x1,y1,x2,y2)
    Dim 图片路径="/sdcard/pictures/1.png"
    SnapShot 图片路径,x1,y1,x2,y2
    Dim link = "http://192.168.31.7:1224/api/ocr"
    Dim headers = {"Content-Type":"application/json"}
    Dim base64 = zm.FileReadBinaryBase64(图片路径)
    TracePrint base64
    Dim body={"base64":base64}
    Dim res = Url.httpPost({"url":link,"data":Encode.TableToJson(body),"header":headers}) 
    TracePrint res
    // 对返回值进行判断
    If Len(res) > 0 Then 
        Dim tb = encode.JsonToTable(res)
        If tb["code"] = 100 Then 
            TracePrint "识别的文字块数量:",len(tb["data"])
            For i = 1 To Len(tb["data"])
                TracePrint tb["data"][i]["text"]
                TracePrint tb["data"][i]["box"][1][1],tb["data"][i]["box"][1][2],tb["data"][i]["box"][3][1],tb["data"][i]["box"][3][2]
                显示区域(tb["data"][i]["box"][1][1]+x1,tb["data"][i]["box"][1][2]+y1,tb["data"][i]["box"][3][1]+x1,tb["data"][i]["box"][3][2]+y1,tb["data"][i]["text"],i)
            Next
        Else 
            TracePrint "识别失败"
        End If
    Else 
        TracePrint "网络有问题或者搭建不成功"
    End If
End Function


Function 显示区域(x1,y1,x2,y2,str,n)
    FW.NewFWindow "浮窗名" & n, x1, y1, x2 - x1, y2 - y1
    FW.SetBackColor("浮窗名" & n, "0000FF")
    FW.Opacity("浮窗名" & n, 50)    
    FW.NewFWindow("浮窗名1_"&n, x1, y2, x2-x1+20, y2-y1+10)
    FW.AddTextView "浮窗名1_" & n, "文字" & n, str, 0, 0, x2 - x1+20, y2 - y1+10
    FW.SetTextColor "文字" & n, "0000FF"
    FW.SetTextSize "文字" & n, 10
    FW.Opacity("浮窗名1_" & n, 0)
    FW.Show("浮窗名"&n)
    FW.Show("浮窗名1_"&n)
End Function


正文完=

相关推荐

10w qps缓存数据库——Redis(redis缓存调优)

一、Redis数据库介绍:Redis:非关系型缓存数据库nosql:非关系型数据库没有表,没有表与表之间的关系,更不存在外键存储数据的形式为key:values的形式c语言写的服务(监听端口),用来存...

Redis系列专题4--Redis配置参数详解

本文基于windowsX64,3.2.100版本讲解,不同版本默认配置参数不同在Redis中,Redis的根目录中有一个配置文件(redis.conf,windows下为redis.windows....

开源一夏 | 23 张图,4500 字从入门到精通解释 Redis

redis是目前出场率最高的NoSQL数据库,同时也是一个开源的数据结构存储系统,在缓存、数据库、消息处理等场景使用的非常多,本文瑞哥就带着大家用一篇文章入门这个强大的开源数据库——Redis。...

redis的简单与集群搭建(redis建立集群)

Redis是什么?是开源免费用c语言编写的单线程高性能的(key-value形式)内存数据库,基于内存运行并支持持久化的nosql数据库作用主要用来做缓存,单不仅仅是做缓存,比如:redis的计数器生...

推荐几个好用Redis图形化客户端工具

RedisPlushttps://gitee.com/MaxBill/RedisPlusRedisPlus是为Redis可视化管理开发的一款开源免费的桌面客户端软件,支持Windows、Linux...

关于Redis在windows上运行及fork函数问题

Redis在将数据库进行持久化操作时,需要fork一个进程,但是windows并不支持fork,导致在持久化操作期间,Redis必须阻塞所有的客户端直至持久化操作完成。微软的一些工程师花费时间在解决在...

你必须懂的Redis十大应用场景(redis常见应用场景)

Redis作为一款高性能的键值存储数据库,在互联网业务中有着广泛的应用。今天,我们就来详细盘点一下Redis的十大常用业务场景,并附上Golang的示例代码和简图,帮助大家更好地理解和应用Redis。...

极简Redis配置(redis的配置)

一、概述Redis的配置文件位于Redis安装目录下,文件名为redis.conf(Windows名为redis.windows.conf,linux下的是redis.conf)你可以通过C...

什么是redis,怎么启动及如何压测

从今天起咱们一起来学习一下关于“redis监控与调优”的内容。一、Redis介绍Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。...

一款全新Redis UI可视化管理工具,支持WebUI和桌面——P3X Redis UI

介绍P3XRedisUI这是一个非常实用的RedisGUI,提供响应式WebUI访问或作为桌面应用程序使用,桌面端是跨平台的,而且完美支持中文界面。Githubhttps://github....

windows系统的服务器快速部署java项目环境地址

1、mysql:https://dev.mysql.com/downloads/mysql/(msi安装包)2、redis:https://github.com/tporadowski/redis/r...

window11 下 redis 下载与安装(windows安装redis客户端)

#热爱编程是一种怎样的体验#window11下redis下载与安装1)各个版本redis下载(windows)https://github.com/MicrosoftArchive/r...

一款轻量级的Redis客户端工具,贼好用!

使用命令行来操作Redis是一件非常麻烦的事情,我们一般会选用客户端工具来操作Redis。今天给大家分享一款好用的Redis客户端工具TinyRDM,它的界面清新又优雅,希望对大家有所帮助!简介Ti...

一个.NET开发且功能强大的Windows远程控制系统

我们致力于探索、分享和推荐最新的实用技术栈、开源项目、框架和实用工具。每天都有新鲜的开源资讯等待你的发现!项目介绍SiMayRemoteMonitorOS是一个基于Windows的远程控制系统,完...

Redis客户端工具详解(4款主流工具)

大家好,我是mikechen。Redis是大型架构的基石,也是大厂最爱考察内容,今天就给大家重点详解4款Redis工具@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集...