README.md 3.7 KB
Newer Older
K
Kentaro Wada 已提交
1 2
<img src="https://github.com/wkentaro/labelme/blob/master/labelme/icons/icon.png?raw=true" align="right" />

K
Kentaro Wada 已提交
3
# labelme: Image Polygonal Annotation with Python
K
Kentaro Wada 已提交
4

K
Kentaro Wada 已提交
5
[![PyPI Version](https://img.shields.io/pypi/v/labelme.svg)](https://pypi.python.org/pypi/labelme)
K
Kentaro Wada 已提交
6
[![Travis Build Status](https://travis-ci.org/wkentaro/labelme.svg?branch=master)](https://travis-ci.org/wkentaro/labelme)
K
Kentaro Wada 已提交
7
[![Docker Build Status](https://img.shields.io/docker/build/wkentaro/labelme.svg)](https://hub.docker.com/r/wkentaro/labelme)
K
Kentaro Wada 已提交
8 9


K
Kentaro Wada 已提交
10
Labelme is a graphical image annotation tool inspired by <http://labelme.csail.mit.edu>.  
K
Kentaro Wada 已提交
11 12
It is written in Python and uses Qt for its graphical interface,  
and supports annotations for semantic and instance segmentation.
K
Kentaro Wada 已提交
13

K
Kentaro Wada 已提交
14
<img src="examples/single_image/.readme/screenshot.jpg" width="80%" />
K
Kentaro Wada 已提交
15

K
Kentaro Wada 已提交
16

K
Kentaro Wada 已提交
17
## Requirements
K
Kentaro Wada 已提交
18

K
Kentaro Wada 已提交
19 20
- Ubuntu / macOS / Windows
- Python2 / Python3
K
Kentaro Wada 已提交
21
- [PyQt4 / PyQt5](http://www.riverbankcomputing.co.uk/software/pyqt/intro)
K
Kentaro Wada 已提交
22 23


K
Kentaro Wada 已提交
24
## Installation
K
Kentaro Wada 已提交
25

K
Kentaro Wada 已提交
26 27 28 29 30
There are options:

- Platform agonistic installation: Anaconda, Docker
- Platform specific installation: Ubuntu, macOS

K
Kentaro Wada 已提交
31
### Anaconda
K
Kentaro Wada 已提交
32 33 34 35

You need install [Anaconda](https://www.continuum.io/downloads), then run below:

```bash
K
Kentaro Wada 已提交
36
# python2
K
Kentaro Wada 已提交
37 38 39 40
conda create --name=labelme python=2.7
source activate labelme
conda install pyqt
pip install labelme
K
Kentaro Wada 已提交
41 42
# if you'd like to use the latest version. run below:
# pip install git+https://github.com/wkentaro/labelme.git
K
Kentaro Wada 已提交
43 44 45 46 47

# python3
conda create --name=labelme python=3.6
source activate labelme
# conda install pyqt
K
Kentaro Wada 已提交
48
pip install pyqt5  # pyqt5 can be installed via pip on python3
K
Kentaro Wada 已提交
49
pip install labelme
K
Kentaro Wada 已提交
50 51
```

K
Kentaro Wada 已提交
52
### Docker
K
Kentaro Wada 已提交
53

K
Kentaro Wada 已提交
54
You need install [docker](https://www.docker.com), then run below:
K
Kentaro Wada 已提交
55 56 57 58 59 60

```bash
wget https://raw.githubusercontent.com/wkentaro/labelme/master/scripts/labelme_on_docker
chmod u+x labelme_on_docker

# Maybe you need http://sourabhbajaj.com/blog/2017/02/07/gui-applications-docker-mac/ on macOS
K
Kentaro Wada 已提交
61 62
labelme_on_docker examples/single_image/apc2016_obj3.jpg -O examples/single_image/apc2016_obj3.json
labelme_on_docker examples/semantic_segmentation/data_annotated
K
Kentaro Wada 已提交
63
```
K
Kentaro Wada 已提交
64

K
Kentaro Wada 已提交
65
### Ubuntu
K
Kentaro Wada 已提交
66 67

```bash
K
Kentaro Wada 已提交
68
# Ubuntu 14.04 / Ubuntu 16.04
K
Kentaro Wada 已提交
69
# Python2
K
Kentaro Wada 已提交
70 71
# sudo apt-get install python-qt4 pyqt4-dev-tools  # PyQt4
sudo apt-get install python-pyqt5 pyqt5-dev-tools  # PyQt5
K
Kentaro Wada 已提交
72
sudo pip install labelme
K
Kentaro Wada 已提交
73
# Python3
K
Kentaro Wada 已提交
74
sudo apt-get install python3-pyqt5 pyqt5-dev-tools  # PyQt5
K
Kentaro Wada 已提交
75
sudo pip3 install labelme
K
Kentaro Wada 已提交
76 77
```

K
Kentaro Wada 已提交
78
### macOS
K
Kentaro Wada 已提交
79 80

```bash
K
Kentaro Wada 已提交
81
# macOS Sierra
K
Kentaro Wada 已提交
82 83
brew install pyqt  # maybe pyqt5
pip install labelme  # both python2/3 should work
K
Kentaro Wada 已提交
84 85
```

K
Kentaro Wada 已提交
86

K
Kentaro Wada 已提交
87
## Usage
K
Kentaro Wada 已提交
88

K
Kentaro Wada 已提交
89 90
Run `labelme --help` for detail.  
The annotations are saved as a [JSON](http://www.json.org/) file.
K
Kentaro Wada 已提交
91 92

```bash
K
Kentaro Wada 已提交
93 94 95 96 97 98 99 100 101 102 103 104 105 106
labelme  # just open gui

# single image example
cd examples/single_image
labelme apc2016_obj3.jpg  # specify image file
labelme apc2016_obj3.jpg -O apc2016_obj3.json  # close window after the save
labelme apc2016_obj3.jpg --nodata  # not include image data but relative image path in JSON file
labelme apc2016_obj3.jpg \
  --labels highland_6539_self_stick_notes,mead_index_cards,kong_air_dog_squeakair_tennis_ball  # specify label list

# semantic segmentation example
cd examples/semantic_segmentation
labelme data_annotated/  # Open directory to annotate all images in it
labelme data_annotated/ --labels labels.txt  # specify label list with a file
K
Kentaro Wada 已提交
107 108
```

K
Kentaro Wada 已提交
109
For more advanced usage, please refer to the examples:
K
Kentaro Wada 已提交
110

K
Kentaro Wada 已提交
111 112 113
* [Single Image Example](examples/single_image)
* [Semantic Segmentation Example](examples/semantic_segmentation)
* [Instance Segmentation Example](examples/instance_segmentation)
K
Kentaro Wada 已提交
114 115


K
Kentaro Wada 已提交
116
## Screencast
K
Kentaro Wada 已提交
117

K
Kentaro Wada 已提交
118
<img src=".readme/screencast.gif" width="70%"/>
K
Kentaro Wada 已提交
119 120


K
Kentaro Wada 已提交
121
## Testing
K
Kentaro Wada 已提交
122 123 124 125 126 127 128 129

```bash
pip install hacking pytest pytest-qt
flake8 .
pytest -v tests
```


K
Kentaro Wada 已提交
130
## Acknowledgement
K
Kentaro Wada 已提交
131

K
Kentaro Wada 已提交
132 133
This repo is the fork of [mpitid/pylabelme](https://github.com/mpitid/pylabelme),
whose development has already stopped.