Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cheind/inpaint
:pencil2: Inpaint is a C++ library providing image inpainting algorithms
https://github.com/cheind/inpaint
image-processing inpainting seamless-copy
Last synced: about 13 hours ago
JSON representation
:pencil2: Inpaint is a C++ library providing image inpainting algorithms
- Host: GitHub
- URL: https://github.com/cheind/inpaint
- Owner: cheind
- License: other
- Created: 2014-11-25T12:31:09.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2023-12-20T07:23:02.000Z (about 1 year ago)
- Last Synced: 2025-01-02T09:11:49.772Z (8 days ago)
- Topics: image-processing, inpainting, seamless-copy
- Language: C++
- Homepage:
- Size: 993 KB
- Stars: 161
- Watchers: 20
- Forks: 51
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
README
# Inpaint
**Inpaint** is a C++ library providing implementations of image inpainting and image completion methods. Image inpainting is the process of recovering or restoring image regions in a way that is non-detectable for an observer who does not know the original image.
While inpainting refers to restoring rather small regions such as scratches and other video artefacts, image completion deals with removal / restoring of large image parts.
**Inpaint** focuses on the task of object removal and is therefore optimized to work with large areas of reconstruction. Below is a side-by-side view of two images. On the left the original image, on the right the modified image as produced by **Inpaint**, after the user selected the rope to be removed.
| Original | Inpainted |
| :-------------: |:-------------:|
| ![Original Image](/photos/bungee.jpg?raw=true) | ![Inpainted image](/photos/bungee_criminisi.png?raw=true) |## Building from source
To build **Inpaint** from source you need the following prerequisites
- [CMake](www.cmake.org) - for generating cross plattform build files
- [OpenCV](www.opencv.org) - for image processing related functions
Although **Inpaint** should build accross multiple platforms and architectures, tests are carried out on these systems
- Windows 7/8/10 MSVC10/MSVC14 x86/x64 OpenCV 2.x/3.xIf the build should fail for a specific platform, don't hestitate to create an issue. I'm also happy to accept any pull requests.
## Inpainting images
After building you might want to try out `inpaint_image_criminisi`
1. Launch `inpaint_image_criminisi `.
1. Use the sliders on top of the UI to adjust patch and stencil size. Patch size refers to the size of texels that will be used during inpainting. It should be roughly the size of minimum texture feature size you intend to inpaint. Stencil size refers to radius of the interactive drawing tools explained in the following 2 steps.
1. While holding your left mouse button pressed, move your mouse to mark the target area to be inpainted.
1. While holding your right mouse button pressed, move your mouse to mark the source area from which samples can be copied to target area. If you skip this step, the entire image without source region is used as source area.
1. Press `e` to toggle between editing / inpaint mode.
1. Press `x` to quit.## License
```
Copyright Christoph Heindl 2014-2017Inpaint is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Inpaint is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Inpaint. If not, see .
```