
TextFinder 是一款基于 Android 的实时文字识别与定位应用。只需将摄像头对准任何包含文字的场景,输入你想查找的关键词,应用会实时高亮显示所有匹配的文字区域。
这个项目诞生于一个实际需求:帮助集运仓库工作人员快速找到快递包裹。
在繁忙的集运仓库中,工作人员经常需要在一堆包裹中找到特定客户的快递。传统方式是逐个翻看面单上的收件人信息,效率低下且容易遗漏。TextFinder 的出现彻底改变了这一工作流程:
对准包裹堆 → 输入客户姓名/单号 → 瞬间定位目标包裹
| 特性 | 描述 |
|---|---|
| 实时高亮 | 匹配的文字区域以红色边框实时标注,一目了然 |
| 中英文支持 | 基于 Google ML Kit 中文识别引擎,完美支持中文、英文及混合文本 |
| 极速响应 | 采用帧级处理优化,搜索结果即时呈现 |
| 简洁界面 | 极简设计,打开即用,零学习成本 |
| 本地处理 | 所有文字识别在设备端完成,无需联网,保护隐私 |
┌─────────────────────────────────────────────────────────────┐ │ TextFinder 架构 │ ├─────────────────────────────────────────────────────────────┤ │ │ │ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │ │ │ CameraX │───│ ML Kit │───│ OverlayView │ │ │ │ (预览流) │ │ (OCR 识别) │ │ (结果渲染) │ │ │ └─────────────┘ └─────────────┘ └─────────────┘ │ │ │ │ │ │ │ │ │ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │ │ │ PreviewView │ │ TextRecognizer│ │ Canvas 绘制 │ │ │ │ (显示画面) │ │ (中文模型) │ │ (红色边框) │ │ │ └─────────────┘ └─────────────┘ └─────────────┘ │ │ │ └─────────────────────────────────────────────────────────────┘ | 组件 | 技术方案 | 选择理由 |
|---|---|---|
| 相机框架 | CameraX | Jetpack 官方相机库,生命周期感知,兼容性强 |
| OCR 引擎 | ML Kit Text Recognition (Chinese) | Google 端侧 OCR ,中文识别精准,离线可用 |
| UI 框架 | Kotlin + ViewBinding | 原生性能,类型安全,开发效率高 |
| 异步处理 | ExecutorService + Callback | 避免阻塞主线程,保证 UI 流畅 |
摄像头帧 → 图像预处理 → ML Kit OCR → 文字块解析 → 关键词匹配 → 坐标映射 → 界面渲染 │ │ │ │ │ │ │ ImageProxy 旋转校正 TextRecognizer TextBlock contains() 坐标变换 drawRect() // 使用 AtomicBoolean 避免重复处理,跳过积压帧 private val isProcessing = AtomicBoolean(false) if (!isProcessing.compareAndSet(false, true)) { imageProxy.close() // 跳过,正在处理中 return } PreviewView 使用 fillCenter (CENTER_CROP) 模式,需要精确映射 OCR 坐标到视图坐标:
// 复刻 CENTER_CROP 变换逻辑 val scale = maxOf(viewWidth / imageWidth, viewHeight / imageHeight) val offsetX = (viewWidth - imageWidth * scale) / 2f val offsetY = (viewHeight - imageHeight * scale) / 2f // 映射坐标 mappedRect.set( box.left * scale + offsetX, box.top * scale + offsetY, box.right * scale + offsetX, box.bottom * scale + offsetY ) 应用在 Block → Line → Element 三个层级进行匹配,确保无论目标文字是整段、一行还是单个词,都能被准确捕获。
# 克隆项目 git clone https://github.com/xiaolan66/TextFinder.git # 打开 Android Studio ,导入项目 # 等待 Gradle 同步完成 # 连接 Android 设备或启动模拟器 # 点击 Run 按钮即可 应用仅需 摄像头权限,首次启动时会自动请求。所有数据处理均在本地完成,不收集任何用户信息。
app/src/main/java/com/example/textfinder/ ├── MainActivity.kt # 主界面逻辑:相机启动、OCR 调用、搜索匹配 └── OverlayView.kt # 自定义视图:坐标映射、边框绘制 app/src/main/res/layout/ └── activity_main.xml # 界面布局:搜索栏、相机预览、叠加层 ┌─────────────────────────────────┐ │ 输入要查找的文字... [×] │ ← 搜索栏 ├─────────────────────────────────┤ │ │ │ ┌─────────────┐ │ │ │ 客户: 张三 │ │ ← 匹配项 │ │ ┌───────┐ │ │ 红色边框高亮 │ │ │李四 │ │ │ │ │ └───────┘ │ │ │ │ 客户: 张三 │ │ │ └─────────────┘ │ │ │ │ 找到 2 处匹配 │ ← 状态提示 └─────────────────────────────────┘ 本项目采用 MIT License 开源协议。
如果你对 TextFinder 感兴趣,欢迎在商业层面进行探索与合作:
微信:URlake
可能的合作方向:
如果这个项目对你有帮助,请给一个 Star 支持!
Made with by xiaolan66