Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/natlee/fisheye-warping
Dewarp top-down fisheye image to panorama and rewarp panorama to fisheye image.
https://github.com/natlee/fisheye-warping
cli fisheye image-processing image-warping opencv opencv-python panorama python3 tools warping
Last synced: 7 days ago
JSON representation
Dewarp top-down fisheye image to panorama and rewarp panorama to fisheye image.
- Host: GitHub
- URL: https://github.com/natlee/fisheye-warping
- Owner: NatLee
- License: mit
- Created: 2023-05-05T07:38:26.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-05-07T13:59:13.000Z (almost 2 years ago)
- Last Synced: 2025-02-01T12:04:01.190Z (19 days ago)
- Topics: cli, fisheye, image-processing, image-warping, opencv, opencv-python, panorama, python3, tools, warping
- Language: Python
- Homepage: https://pypi.org/project/FisheyeWarping/
- Size: 2.23 MB
- Stars: 12
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# **Fisheye Warping**
![]()
![]()
[data:image/s3,"s3://crabby-images/152ac/152acc56196e8e61ea568ccc9ae483288cb11ce7" alt="PyPI pyversions"](https://pypi.python.org/pypi/FisheyeWarping/) [data:image/s3,"s3://crabby-images/71b45/71b457ede4b2b7de05a4acfa6bdcefb4c80d1bf1" alt="PyPI implementation"](https://pypi.python.org/pypi/FisheyeWarping/)
[data:image/s3,"s3://crabby-images/a164d/a164d057c19f25772511ceb955935ed80204a93c" alt="Test"](https://github.com/NatLee/Eagle-Wrappger/actions/workflows/test.yml) [data:image/s3,"s3://crabby-images/94598/9459816dcae634f6f2764d964e6960c05071b388" alt="Release"](https://github.com/NatLee/fisheye-warping/actions/workflows/release.yml)
[data:image/s3,"s3://crabby-images/a63cd/a63cdf89b56fe0d2b791fb95c646227c3e110594" alt="PyPI status"](https://pypi.python.org/pypi/FisheyeWarping/) [data:image/s3,"s3://crabby-images/f128c/f128cd8d35ae6e011f6a484a157e4ea61eb2ca66" alt="PyPI license"](https://pypi.python.org/pypi/FisheyeWarping/)
[data:image/s3,"s3://crabby-images/ef8cd/ef8cdd84cb6c9a0cdd058aa2777335af0676a57c" alt="PyPI version fury.io"](https://pypi.python.org/pypi/FisheyeWarping/)
[data:image/s3,"s3://crabby-images/e5ef2/e5ef256a276c5fff35f6740dc6a59161b8337d44" alt="PyPI download month"](https://pypi.python.org/pypi/FisheyeWarping/) [data:image/s3,"s3://crabby-images/6fa07/6fa07bb492d156d1d63e160514e7426e8cf26524" alt="PyPI download week"](https://pypi.python.org/pypi/FisheyeWarping/) [data:image/s3,"s3://crabby-images/8136f/8136facf6d3ba9f86e2c36aec70ed69135dfda18" alt="PyPI download day"](https://pypi.python.org/pypi/FisheyeWarping/)
[data:image/s3,"s3://crabby-images/6f074/6f0741e051277ec5790964156f886b9120a2b56d" alt="forthebadge made-with-python"](https://www.python.org/)
A tool for dewarping and rewarping on a top-down fisheye image by using OpenCV on Python.
## Installation
```bash
pip install FisheyeWarping
```Check it in [Pypi](https://pypi.org/project/FisheyeWarping/)
## Usage
```bash
fisheyewarping --help
``````
usage: fisheyewarping [-h] [--panorama_output PANORAMA_OUTPUT] [--fisheye_output FISHEYE_OUTPUT] [--save_dewarp_mesh_path SAVE_DEWARP_MESH_PATH] [--save_rewarp_mesh_path SAVE_REWARP_MESH_PATH] [--load_dewarp_mesh_path LOAD_DEWARP_MESH_PATH]
[--load_rewarp_mesh_path LOAD_REWARP_MESH_PATH] [--fisheye_img_path FISHEYE_IMG_PATH] [--panorama_img_path PANORAMA_IMG_PATH] [--use_multiprocessing USE_MULTIPROCESSING]optional arguments:
-h, --help show this help message and exit
--panorama_output PANORAMA_OUTPUT
Specific path for `output`. Default is `./dewarp-output.png`.
--fisheye_output FISHEYE_OUTPUT
Specific path for `output`. Default is `./rewarp-output.png`.
--save_dewarp_mesh_path SAVE_DEWARP_MESH_PATH
Specific path for saving mesh data for `dewarping`. Default is `None`.
--save_rewarp_mesh_path SAVE_REWARP_MESH_PATH
Specific path for saving mesh data for `rewarping`. Default is `None`.
--load_dewarp_mesh_path LOAD_DEWARP_MESH_PATH
Specific path for loading mesh data for `dewarping`. Default is `None`.
--load_rewarp_mesh_path LOAD_REWARP_MESH_PATH
Specific path for loading mesh data for `rewarping`. Default is `None`.
--fisheye_img_path FISHEYE_IMG_PATH
Specific path of your fisheye image for dewarping to a panorama.
--panorama_img_path PANORAMA_IMG_PATH
Specific path of your panorama image for rewarping to a fisheye image.
--use_multiprocessing USE_MULTIPROCESSING
Use multiprocessing to get mesh. Default is `True`.
```## Example
### Dewarp a fisheye image to panorama
- In the first time, you will need to build a mesh file for dewarping.
```bash
fisheyewarping \
--save_dewarp_mesh_path ./dewarp-mesh.pkl \
--fisheye_img_path ./test-fisheye.jpg
``````python
import cv2
from fisheyewarping import FisheyeWarping
fisheye_img = cv2.imread('./test-fisheye.jpg')
frd = FisheyeWarping(fisheye_img, use_multiprocessing=True)
frd.build_dewarp_mesh(save_path='./dewarp-mesh.pkl')
frd.run_dewarp(save_path='./dewarp-output.png')
```- In the next time, you just load the mesh and feel free to go.
```bash
fisheyewarping \
--load_dewarp_mesh_path ./dewarp-mesh.pkl \
--fisheye_img_path ./test-fisheye.jpg
``````python
import cv2
from fisheyewarping import FisheyeWarping
fisheye_img = cv2.imread('./test-fisheye.jpg'.)
frd = FisheyeWarping(fisheye_img, use_multiprocessing=True)
frd.load_dewarp_mesh(save_path='./dewarp-mesh.pkl')
frd.run_dewarp(save_path='./dewarp-output.png')
```### Rewarp any panorama image to fisheye
- In the first time, you will need to build 2 mesh files for dewarping and rewarping by using one fisheye image.
```bash
fisheyewarping \
--save_dewarp_mesh_path ./dewarp-mesh.pkl \
--save_rewarp_mesh_path ./rewarp-mesh.pkl \
--fisheye_img_path ./test-fisheye.jpg
``````python
import cv2
from fisheyewarping import FisheyeWarping
fisheye_img = cv2.imread('./test-fisheye.jpg'.)
frd = FisheyeWarping(fisheye_img, use_multiprocessing=True)
frd.build_dewarp_mesh(save_path='./dewarp-mesh.pkl')
frd.build_rewarp_mesh(save_path='./rewarp-mesh.pkl')
panorama_img = cv2.imread('./test-panorama.jpg'.)
frd.run_rewarp_with_mesh(panorama_img, save_path='./rewarp-output.png')
```- In the next time, you just load the meshes and feel free to go.
```bash
fisheyewarping \
--load_dewarp_mesh_path ./dewarp-mesh.pkl \
--load_rewarp_mesh_path ./rewarp-mesh.pkl \
--panorame_img_path ./test-panorama.jpg
``````python
import cv2
from fisheyewarping import FisheyeWarping
frd = FisheyeWarping(None, use_multiprocessing=True)
frd.load_dewarp_mesh(save_path='./dewarp-mesh.pkl')
frd.load_rewarp_mesh(save_path='./rewarp-mesh.pkl')
panorama_img = cv2.imread('./test-panorama.jpg'.)
frd.run_rewarp_with_mesh(panorama_img, save_path='./rewarp-output.png')
```## Mesh
> The source of mesh image is from (http://paulbourke.net/dome/fish2/).
Here is the mesh image for this tool, it shows the transformation from the original fisheye image to the panorama image.
- Before - **Fisheye**
![]()
- After - **Panorama**
![]()
## Contributor
## LICENSE
[MIT](LICENSE)