diff --git a/PPOCRLabel/README.md b/PPOCRLabel/README.md index c7598817ba6b52804ca4301dad206b46475f0fcc..b7a359d473ab13246288bd520e1d5df1be3c9397 100644 --- a/PPOCRLabel/README.md +++ b/PPOCRLabel/README.md @@ -2,7 +2,7 @@ English | [简体中文](README_ch.md) # PPOCRLabel -PPOCRLabel is a semi-automatic graphic annotation tool suitable for OCR field. It is written in python3 and pyqt5, supporting rectangular box annotation and four-point annotation modes. Annotations can be directly used for the training of PPOCR detection and recognition models. +PPOCRLabel is a semi-automatic graphic annotation tool suitable for OCR field, with built-in PPOCR model to automatically detect and re-recognize data. It is written in python3 and pyqt5, supporting rectangular box annotation and four-point annotation modes. Annotations can be directly used for the training of PPOCR detection and recognition models. @@ -10,11 +10,15 @@ PPOCRLabel is a semi-automatic graphic annotation tool suitable for OCR field. I - 2020.12.18: Support re-recognition of a single label box (by [ninetailskim](https://github.com/ninetailskim) ), perfect shortcut keys. +### TODO: +- Lock box mode: For the same scene data, the size and position of the locked detection box can be transferred between different pictures. +- Experience optimization: Add undo, batch operation include move, copy, delete and so on, optimize the annotation process. + ## Installation ### 1. Install PaddleOCR -Refer to [PaddleOCR installation document](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/installation.md) to prepare PaddleOCR +PaddleOCR models has been built in PPOCRLabel, please refer to [PaddleOCR installation document](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/installation.md) to prepare PaddleOCR and make sure it works. ### 2. Install PPOCRLabel diff --git a/PPOCRLabel/README_ch.md b/PPOCRLabel/README_ch.md index bc60c4eee560d58ec6d1f3028921f29d9d20878b..4200a21429565924b53bc731586d22d6ea26b0a4 100644 --- a/PPOCRLabel/README_ch.md +++ b/PPOCRLabel/README_ch.md @@ -2,18 +2,26 @@ # PPOCRLabel -PPOCRLabel是一款适用于OCR领域的半自动化图形标注工具,使用python3和pyqt5编写,支持矩形框标注和四点标注模式,导出格式可直接用于PPOCR检测和识别模型的训练。 +PPOCRLabel是一款适用于OCR领域的半自动化图形标注工具,内置PPOCR模型对数据自动标注和重新识别。使用python3和pyqt5编写,支持矩形框标注和四点标注模式,导出格式可直接用于PPOCR检测和识别模型的训练。 #### 近期更新 -- 2020.12.18: 支持对单个标记框进行重新识别(by [ninetailskim](https://github.com/ninetailskim) ),完善快捷键。 +- 2020.12.18: 支持对单个标记框进行重新识别(by [ninetailskim](https://github.com/ninetailskim)),完善快捷键。 + +#### 尽请期待 + +- 锁定框模式:针对同一场景数据,被锁定的检测框的大小与位置能在不同图片之间传递。 +- 体验优化:增加撤销操作,批量移动、复制、删除等功能。优化标注流程。 + +如果您对以上内容感兴趣或对完善工具有不一样的想法,欢迎加入我们的队伍与我们共同开发 + ## 安装 ### 1. 安装PaddleOCR -参考[PaddleOCR安装文档](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/installation.md)准备好PaddleOCR +PPOCRLabel内置PaddleOCR模型,故请参考[PaddleOCR安装文档](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/installation.md)准备好PaddleOCR,并确保PaddleOCR安装成功。 ### 2. 安装PPOCRLabel #### Windows + Anaconda @@ -115,7 +123,7 @@ python3 PPOCRLabel.py --lang ch - PPOCRLabel**不支持对中文文件名**的图片进行自动标注。 -- 针对Linux用户::如果您在打开软件过程中出现**objc[XXXXX]**开头的错误,证明您的opencv版本太高,建议安装4.2版本: +- 针对Linux用户:如果您在打开软件过程中出现**objc[XXXXX]**开头的错误,证明您的opencv版本太高,建议安装4.2版本: ``` pip install opencv-python==4.2.0.32 ``` @@ -129,6 +137,10 @@ python3 PPOCRLabel.py --lang ch ``` pip install opencv-contrib-python-headless ``` +### 成为特殊兴趣小组的一员 + +PPOCRSIG(Paddle Paddle OCR Special Interest Group,飞桨OCR特殊兴趣小组)致力于,我们希望拥有各种背景的,以开源的精神将OCR应用于各行各业。小组 + ### 参考资料 1.[Tzutalin. LabelImg. Git code (2015)](https://github.com/tzutalin/labelImg) diff --git a/PPOCRLabel/libs/editinlist.py b/PPOCRLabel/libs/editinlist.py new file mode 100644 index 0000000000000000000000000000000000000000..f01f513cd5a0196196921684ed9f483e51e18a65 --- /dev/null +++ b/PPOCRLabel/libs/editinlist.py @@ -0,0 +1,29 @@ +import sys +from PyQt5 import QtWidgets +from PyQt5.QtGui import * +from PyQt5.QtCore import * +from PyQt5.QtWidgets import * + +class EditInList(QListWidget): + def __init__(self): + super(EditInList,self).__init__() + # click to edit + self.clicked.connect(self.item_clicked) + + def item_clicked(self, modelindex: QModelIndex) -> None: + self.edited_item = self.currentItem() + self.closePersistentEditor(self.edited_item) + item = self.item(modelindex.row()) + self.edited_item = item + self.openPersistentEditor(item) + self.editItem(item) + + def mouseDoubleClickEvent(self, event): + # close edit + for i in range(self.count()): + self.closePersistentEditor(self.item(i)) + + def leaveEvent(self, event): + # close edit + for i in range(self.count()): + self.closePersistentEditor(self.item(i)) \ No newline at end of file