{ "info": { "author": "abhiTronix", "author_email": "abhi.una12@gmail.com", "bugtrack_url": null, "classifiers": [ "Development Status :: 5 - Production/Stable", "Intended Audience :: Developers", "License :: OSI Approved :: MIT License", "Programming Language :: Python :: 2.7", "Programming Language :: Python :: 3", "Programming Language :: Python :: 3.4", "Programming Language :: Python :: 3.5", "Programming Language :: Python :: 3.6", "Programming Language :: Python :: 3.7" ], "description": "\n\n

\n \"VidGear\n

\n

\n \"VidGear\n

\n\n
\n\n[Releases][release]   |   [Gears](#gears)   |   [Wiki Documentation][wiki]   |   [Installation](#installation)   |   [License](#license)\n\n[![PyPi version][pypi-badge]][pypi] [![Build Status][travis-cli]][travis] [![Build Status][appveyor]][app] [![Say Thank you][Thank-you]][thanks] [![Twitter][twitter-badge]][twitter-intent] \n\n[![Buy Me A Coffee][Coffee-badge]][coffee]\n\n
\n\n \n\nVidGear is a powerful python Video Processing library built with multi-threaded [**Gears**](#gear)(_a.k.a APIs_) each with a unique set of trailblazing features. These APIs provides a easy-to-use, highly extensible, and multi-threaded wrapper around many underlying state-of-the-art python libraries such as *[OpenCV \u27b6][opencv], [FFmpeg \u27b6][ffmpeg], [picamera \u27b6][picamera], [pafy \u27b6][pafy], [pyzmq \u27b6][pyzmq] and [python-mss \u27b6][mss]*\n\n \n\nThe following **functional block diagram** clearly depicts the functioning of VidGear library:\n\n

\n \"@Vidgear\n

\n\n \n\n## Table of Contents\n\n[**TL;DR**](#tldr)\n\n[**New Release : VidGear 0.1.5**](#new-release-sneekpeak--vidgear-015)\n\n[**Installation Options**](#installation)\n * [**Prerequisites**](#prerequisites)\n * [**1 - PyPI Install**](#option-1-pypi-install)\n * [**2 - Release Archive Download**](#option-2-release-archive-download)\n * [**3 - Clone Repo**](#option-3-clone-the-repo)\n\n[**Gears: What are these?**](#gears)\n * [**CamGear**](#camgear)\n * [**PiGear**](#pigear)\n * [**VideoGear**](#videogear)\n * [**ScreenGear**](#screengear)\n * [**WriteGear**](#writegear)\n * [**NetGear**](#netgear)\n\n**For Developers/Contributors**\n * [**Testing**](#testing)\n * [**Contributing**](#contributing)\n\n[**Documentation**](#documentation)\n\n[**Project Motivation**](#project-motivation)\n\n**Additional Info**\n * [**Supported Python legacies**](#supported-python-legacies)\n * [**Changelog**](#changelog)\n * [**License**](#license)\n\n \n\n## TL;DR\n *VidGear is an [ultrafast\u27b6][ultrafast-wiki], compact, flexible and easy-to-adapt complete Video Processing Python Library.*\n\n Built with simplicity in mind, VidGear lets programmers and software developers to easily integrate and perform complex Video Processing tasks in their existing or new applications, without going through various underlying python library's documentation and using just a few lines of code. Beneficial for both, if you're new to Programming with Python language or a pro at it. \n\n For more advanced information see the [Wiki Documentation \u27b6][wiki].\n\n\n\n\n \n\n## New Release SneekPeak : VidGear 0.1.5\n * Released new ScreenGear API, supports Live ScreenCasting.\n * Released new NetGear API, aids real-time frame transfer through messaging(ZmQ) over the network.\n * Released new Stabilizer Class, for minimum latency Video Stabilization with OpenCV.\n * Updated VideoGear API to be used as an internal wrapper around Stabilizer Class.\n * Implemented exclusive Threaded Queue Mode for blazingly fast, synchronized and error-free multi-threading APIs.\n * Added Option to use VidGear API's standalone.\n * Several Performance enhancements and Bugs exterminated.\n * Revamped Docs and [many more...](changelog.md)\n\n \n\n## Installation\n\n### Prerequisites\n\nTo use VidGear in your python application, you must check the following dependencies before you install VidGear :\n\n* Must support [these Python legacies](#supported-python-legacies) and [pip][pip] already installed.\n\n\n* **`OpenCV:`** VidGear must require OpenCV(3.0+) python enabled binaries to be installed on your machine for its core functions. For its installation, you can follow these online tutorials for [linux][OpenCV-linux] and [raspberry pi][OpenCV-pi], otherwise, install it via pip:\n\n ```sh\n pip install opencv-python\n ```\n\n* **`FFmpeg:`** VidGear must require FFmpeg for its powerful video compression and encoding capabilities. :star2: Follow this [**FFmpeg wiki page**][ffmpeg-wiki] for its installation. :star2:\n\n* **`picamera:`** Required for using Raspberry Pi Camera Modules(_such as OmniVision OV5647 Camera Module_) on your Raspberry Pi machine. You can easily install it via pip:\n\n ```sh\n pip install picamera\n ``` \n Also, make sure to enable Raspberry Pi hardware-specific settings prior to using this library.\n\n* **`mss:`** Required for Screen Casting. Install it via pip:\n\n ```sh\n pip install mss\n ```\n* **`pyzmq:`** Required for transferring video frames through _ZeroMQ messaging system_ over the network. Install it via pip:\n\n ```sh\n pip install pyzmq\n ```\n\n* **`pafy:`** For direct YouTube Video streaming, Vidgear needs [`pafy`][pafy] and latest [`youtube-dl`][yt-dl](as pafy's backend) python libraries installed. Install it via pip:\n\n ```sh\n pip install pafy\n pip install -U youtube-dl\n ```\n\n\n \n\n### Option 1: PyPI Install\n\n> Best option for **quickly** getting VidGear installed.\n\n```sh\n pip install vidgear\n```\n \n\n### Option 2: Release Archive Download\n\n> Best option if you want a **compressed archive**.\n\nVidGear releases are available for download as packages in the [latest release][release]\n\n \n\n### Option 3: Clone the Repository\n\n> Best option for **automatically installing required dependencies**(_except FFmpeg_), or for **latest patches**(_maybe experimental_), or **contributing** to development.\n\nYou can clone this repository's `testing` branch for development and thereby can install as follows:\n```sh\n git clone https://github.com/abhiTronix/vidgear.git\n cd vidgear\n git checkout testing\n pip install .\n```\n\n \n\n## Gears:\n\nVidGear is built with multi-threaded **Gears** each with some unique function/mechanism. Each **Gear** is designed exclusively to handle/control different device-specific video streams, network streams, and media encoders. These APIs provides an easy-to-use, highly extensible, and a multi-threaded wrapper around many underlying various python libraries to exploit their features and functions directly while providing robust error-handling. \n\n**These Gears can be classified as follows:**\n\n**A. VideoCapture Gears:**\n\n * [**CamGear:**](#camgear) _Targets various IP-USB-Cameras/Network-Streams/YouTube-Video-URL._\n * [**PiGear:**](#pigear) _Targets various Raspberry Pi Camera Modules._\n * [**ScreenGear:**](#screengear) _Enables ultra-fast Screen Casting._ \n * [**VideoGear:**](#videogear) _A common API with Video Stabilizer wrapper._ \n\n**B. VideoWriter Gear:**\n\n * [**WriteGear:**](#writegear) _Handles easy Lossless Video Encoding and Compression._\n\n**C. Network Gear:**\n\n * [**NetGear:**](#netgear) _Targets synchronous video frames transferring between interconnecting systems over the network._\n\n \n\n### CamGear\n\nCamGear supports a diverse range of video streams which can handle/control video stream almost any IP/USB Cameras, multimedia video file format ([_upto 4k tested_][test-4k]), network stream URL such as `http(s), rtp, rstp, mms, etc.` In addition to this, it also supports live Gstreamer's RAW pipelines and YouTube video/livestreams URLs. CamGear provides a flexible, high-level multi-threaded wrapper around `OpenCV's` [VideoCapture class][opencv-vc] with access almost all of its available parameters and also employs `pafy's` APIs for live [YouTube streaming][youtube-wiki]. Furthermore, CamGear relies exclusively on [**Threaded Queue mode**][TQM-wiki] for ultra-fast, error-free and synchronized frame handling.\n\n\n**Following simplified functional block diagram depicts CamGear API's generalized working:**\n\n

\n \"CamGear\n

\n\n**CamGear API Guide:**\n\n[>>> Usage Guide][camgear-wiki]\n\n \n\n### VideoGear\n\nVideoGear API provides a special internal wrapper around VidGear's exclusive [**Video Stabilizer**][stablizer-wiki] class. Furthermore, VideoGear API can provide internal access to both [CamGear](#camgear) and [PiGear](#pigear) APIs separated by a special flag. Thereby, _this API holds the exclusive power for any incoming VideoStream from any source, whether it is live or not, to stabilize it directly with minimum latency and memory requirements._\n\n**Below is a snapshot of a VideoGear Stabilizer in action:**\n\n

\n \"VideoGear\n
\n Original Video Courtesy@SIGGRAPH2013\n

\n\nCode to generate above VideoGear API Stabilized Video(_See more detailed usage examples [here][stablizer-wiki-ex]_): \n\n```python\n# import libraries\nfrom vidgear.gears import VideoGear\nimport numpy as np\nimport cv2\n\nstream_stab = VideoGear(source='test.mp4', stabilize = True).start() # To open any valid video stream with `stabilize` flag set to True.\nstream_org = VideoGear(source='test.mp4').start() # open same stream without stabilization for comparison\n\n# infinite loop\nwhile True:\n\n frame_stab = stream_stab.read()\n # read stabilized frames\n\n # check if frame is None\n if frame_stab is None:\n #if True break the infinite loop\n break\n\n #read original frame\n frame_org = stream_org.read()\n\n #concatenate both frames\n output_frame = np.concatenate((frame_org, frame_stab), axis=1)\n\n #put text\n cv2.putText(output_frame, \"Before\", (10, output_frame.shape[0] - 10),cv2.FONT_HERSHEY_SIMPLEX, 0.6, (0,255,0), 2)\n cv2.putText(output_frame, \"After\", (output_frame.shape[1]//2+10, frame.shape[0] - 10),cv2.FONT_HERSHEY_SIMPLEX, 0.6, (0,255,0), 2)\n\n cv2.imshow(\"Stabilized Frame\", output_frame)\n # Show output window\n\n key = cv2.waitKey(1) & 0xFF\n # check for 'q' key-press\n if key == ord(\"q\"):\n #if 'q' key-pressed break out\n break\n\ncv2.destroyAllWindows()\n# close output window\nstream_org.stop()\nstream_stab.stop()\n# safely close video streams.\n```\n\n\n**VideoGear API Guide:**\n\n[>>> Usage Guide][videogear-wiki]\n\n \n\n### PiGear\n\nPiGear is similar to CamGear but made to support various Raspberry Pi Camera Modules (such as [OmniVision OV5647 Camera Module][OV5647-picam] and [Sony IMX219 Camera Module][IMX219-picam]). To interface with these modules correctly, PiGear provides a flexible multi-threaded wrapper around complete [picamera][picamera] python library, and provides us the ability to exploit its various features like `brightness, saturation, sensor_mode, etc.` effortlessly. \n\n**Following simplified functional block diagram depicts PiGear API:**\n\n

\n \"PiGear\n

\n\n**PiGear API Guide:**\n\n[>>> Usage Guide][pigear-wiki]\n\n \n\n### ScreenGear\n\nWith ScreenGear, we can easily define an area on the computer screen or an open window to record the live screen frames in real-time at the expense of insignificant latency. To achieve this, ScreenGear provides a high-level multi-threaded wrapper around [**`mss`**][mss] python library API and also supports the flexible direct parameter manipulation. \n\n**Below is a snapshot of a ScreenGear API in action:**\n\n

\n \"ScreenGear\n

\n\nCode to generate the above result:\n\n```python\n# import libraries\nfrom vidgear.gears import ScreenGear\nimport cv2\n\nstream = ScreenGear().start()\n\n# infinite loop\nwhile True:\n\n frame = stream.read()\n # read frames\n\n # check if frame is None\n if frame is None:\n #if True break the infinite loop\n break\n\n cv2.imshow(\"Output Frame\", frame)\n # Show output window\n\n key = cv2.waitKey(1) & 0xFF\n # check for 'q' key-press\n if key == ord(\"q\"):\n #if 'q' key-pressed break out\n break\n\ncv2.destroyAllWindows()\n# close output window\n\nstream.stop()\n# safely close video stream.\n```\n\n**ScreenGear API Guide:**\n\n[>>> Usage Guide][screengear-wiki]\n\n\n \n\n\n### WriteGear\n\nWriteGear is undoubtedly the most powerful Video Processing Gear of them all. It solely handles various powerful FFmpeg tools that allow us to do almost anything you can imagine with multimedia files. With WriteGear API, you can process real-time video frames into a lossless format and specification suitable for our playback in just a few lines of codes. These specifications include setting bitrate, codec, framerate, resolution, subtitles, compression, etc. Furthermore, we can multiplex extracted audio at the output with compression and all that in real-time(see this example). In addition to this, WriteGear also provides flexible access to OpenCV's VideoWriter API which provides some basic tools for video frames encoding but without compression.\n\n**WriteGear primarily operates in the following two modes:**\n\n * **Compression Mode:** In this mode, WriteGear utilizes [**`FFmpeg's`**][ffmpeg] inbuilt encoders to encode lossless multimedia files. It provides us the ability to exploit almost any available parameters available within FFmpeg, with so much ease and flexibility and while doing that it robustly handles all errors/warnings quietly. **You can find more about this mode [here][cm-writegear-wiki]**.\n\n * **Non-Compression Mode:** In this mode, WriteGear utilizes basic OpenCV's inbuilt [**VideoWriter API**][opencv-vw]. Similar to compression mode, WriteGear also supports all parameters manipulation available within OpenCV's VideoWriter API. But this mode lacks the ability to manipulate encoding parameters and other important features like video compression, audio encoding, etc. **You can learn about this mode [here][ncm-writegear-wiki]**.\n\n**Following functional block diagram depicts WriteGear API's generalized working:**\n\n

\n \"WriteGear\n

\n\n**WriteGear API Guide:**\n\n[>>> Usage Guide][writegear-wiki]\n\n \n\n### NetGear\n\nNetGear is exclusively designed to transfer video frames synchronously between interconnecting systems over the network in real-time. This is achieved by implementing a high-level wrapper around [PyZmQ][pyzmq] python library that contains python bindings for [ZeroMQ](http://zeromq.org/) - a high-performance asynchronous distributed messaging library that aim to be used in distributed or concurrent applications. It provides a message queue, but unlike message-oriented middleware, a ZeroMQ system can run without a dedicated message broker. Furthermore, NetGear currently supports two ZeroMQ messaging patterns: i.e `zmq.PAIR` and `zmq.REQ and zmq.REP`.\n\n**NetGear API has two modes of operations:**\n * **Send Mode:**(a.k.a Server configuration) which employs `send()` function to send frames to the client(s). You can use this function to send messages to client(s) too.\n * **Receive Mode:**(a.k.a Client configuration) which employs `recv()` function to receive frames sent by server. Client send back confirmation when frame is received successfully.\n\n\n**Following functional block diagram depicts NetGear API:**\n\n

\n \"NetGear\n

\n\n**NetGear API Guide:**\n\n[>>> Usage Guide][netgear-wiki]\n\n \n\n\n## Documentation\n\nThe full documentation for all VidGear classes and functions can be found in the link below:\n\n* [Wiki Documentation - English][wiki]\n\n \n\n## Testing\n\n* **Prerequisites:** Testing VidGear require some *additional dependencies & data* which can be downloaded manually as follows:\n\n * **Clone & Install [Testing Branch](#option-3-clone-the-repo)**\n\n * **Download few additional python libraries:**\n ```sh\n pip install six\n pip install pytest\n ```\n\n * **Download Test Dataset:** To perform tests, additional *test dataset* is required, which can be downloaded by running [*bash script*][bs_script_dataset] as follows:\n\n ```sh\n chmod +x scripts/prepare_dataset.sh\n ./scripts/prepare_dataset.sh #for windows, use `sh scripts/pre_install.sh`\n ```\n\n* **Run Tests:** Then various VidGear tests can be run with `pytest`(*in VidGear's root folder*) as below:\n\n ```sh\n pytest -sv #-sv for verbose output.\n ```\n\n  \n\n## Contributing\n\nSee [contributing.md](contributing.md)\n\n  \n\n## Project Motivation\n\nSee [Wiki: Project Motivation][wiki-vidgear-purpose]\n\n \n\n## Supported Python legacies\n\n * **Python 2.7 legacies:** *VidGear v0.1.5 is officially the last Python 2.7 legacies supporting version.* Kindly migrate your source code to Python 3 as soon as possible.\n\n * **Python 3.x legacies:** follows the [numpy][numpy] releases.\n\n \n\n## Changelog\n\nSee [changelog.md](changelog.md)\n\n  \n\n## License\n\nCopyright \u00a9 abhiTronix 2019\n\nThis project is licensed under the [MIT][license] license.\n\n\n\n\n\n\n[appveyor]:https://img.shields.io/appveyor/ci/abhitronix/vidgear.svg?style=for-the-badge&logo=appveyor\n[travis-cli]:https://img.shields.io/travis/abhiTronix/vidgear.svg?style=for-the-badge&logo=travis\n[prs-badge]:https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=for-the-badge&logo=data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAABC0lEQVRYhdWVPQoCMRCFX6HY2ghaiZUXsLW0EDyBrbWtN/EUHsHTWFnYyCL4gxibVZZlZzKTnWz0QZpk5r0vIdkF/kBPAMOKeddE+CQPKoc5Yt5cTjBMdQSwDQToWgBJAn3jmhqgltapAV6E6b5U17MGGAUaUj07TficMfIBZDV6vxowBm1BP9WbSQE4o5h9IjPJmy73TEPDDxVmoZdQrQ5jRhly9Q8tgMUXkIIWn0oG4GYQfAXQzz1PGoCiQndM7b4RgJay/h7zBLT3hASgoKjamQJMreKf0gfuAGyYtXEIAKcL/Dss15iq6ohXghozLYiAMxPuACwtIT4yeQUxAaLrZwAoqGRKGk7qDSYTfYQ8LuYnAAAAAElFTkSuQmCC\n[twitter-badge]:https://img.shields.io/twitter/url/http/shields.io.svg?style=for-the-badge&logo=twitter\n[pypi-badge]:https://img.shields.io/pypi/v/vidgear.svg?style=for-the-badge&logo=data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAABC0lEQVRYhdWVPQoCMRCFX6HY2ghaiZUXsLW0EDyBrbWtN/EUHsHTWFnYyCL4gxibVZZlZzKTnWz0QZpk5r0vIdkF/kBPAMOKeddE+CQPKoc5Yt5cTjBMdQSwDQToWgBJAn3jmhqgltapAV6E6b5U17MGGAUaUj07TficMfIBZDV6vxowBm1BP9WbSQE4o5h9IjPJmy73TEPDDxVmoZdQrQ5jRhly9Q8tgMUXkIIWn0oG4GYQfAXQzz1PGoCiQndM7b4RgJay/h7zBLT3hASgoKjamQJMreKf0gfuAGyYtXEIAKcL/Dss15iq6ohXghozLYiAMxPuACwtIT4yeQUxAaLrZwAoqGRKGk7qDSYTfYQ8LuYnAAAAAElFTkSuQmCC\n[Thank-you]:https://img.shields.io/badge/Say%20Thanks-!-1EAEDB.svg?style=for-the-badge&logo=data%3Aimage%2Fsvg%2Bxml%3Bbase64%2CPD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJzdmcyIiB3aWR0aD0iNjQ1IiBoZWlnaHQ9IjU4NSIgdmVyc2lvbj0iMS4wIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPiA8ZyBpZD0ibGF5ZXIxIj4gIDxwYXRoIGlkPSJwYXRoMjQxNyIgZD0ibTI5Ny4zIDU1MC44N2MtMTMuNzc1LTE1LjQzNi00OC4xNzEtNDUuNTMtNzYuNDM1LTY2Ljg3NC04My43NDQtNjMuMjQyLTk1LjE0Mi03Mi4zOTQtMTI5LjE0LTEwMy43LTYyLjY4NS01Ny43Mi04OS4zMDYtMTE1LjcxLTg5LjIxNC0xOTQuMzQgMC4wNDQ1MTItMzguMzg0IDIuNjYwOC01My4xNzIgMTMuNDEtNzUuNzk3IDE4LjIzNy0zOC4zODYgNDUuMS02Ni45MDkgNzkuNDQ1LTg0LjM1NSAyNC4zMjUtMTIuMzU2IDM2LjMyMy0xNy44NDUgNzYuOTQ0LTE4LjA3IDQyLjQ5My0wLjIzNDgzIDUxLjQzOSA0LjcxOTcgNzYuNDM1IDE4LjQ1MiAzMC40MjUgMTYuNzE0IDYxLjc0IDUyLjQzNiA2OC4yMTMgNzcuODExbDMuOTk4MSAxNS42NzIgOS44NTk2LTIxLjU4NWM1NS43MTYtMTIxLjk3IDIzMy42LTEyMC4xNSAyOTUuNSAzLjAzMTYgMTkuNjM4IDM5LjA3NiAyMS43OTQgMTIyLjUxIDQuMzgwMSAxNjkuNTEtMjIuNzE1IDYxLjMwOS02NS4zOCAxMDguMDUtMTY0LjAxIDE3OS42OC02NC42ODEgNDYuOTc0LTEzNy44OCAxMTguMDUtMTQyLjk4IDEyOC4wMy01LjkxNTUgMTEuNTg4LTAuMjgyMTYgMS44MTU5LTI2LjQwOC0yNy40NjF6IiBmaWxsPSIjZGQ1MDRmIi8%2BIDwvZz48L3N2Zz4%3D\n[Coffee-badge]:https://abhitronix.github.io/img/vidgear/orange_img.png\n\n\n\n[release]:https://github.com/abhiTronix/vidgear/releases/latest\n[pypi]:https://pypi.org/project/vidgear/\n[thanks]:https://saythanks.io/to/abhiTronix\n[twitter-intent]:https://twitter.com/intent/tweet?url=https%3A%2F%2Fgithub.com%2FabhiTronix%2Fvidgear&via%20%40abhi_una12&text=VidGear%20-%20A%20simple%2C%20powerful%2C%20flexible%20%26%20threaded%20Python%20Video%20Processing%20Library&hashtags=vidgear%20%23multithreaded%20%23python%20%23video-processing%20%23github\n[coffee]:https://www.buymeacoffee.com/2twOXFvlA\n[license]:https://github.com/abhiTronix/vidgear/blob/master/LICENSE\n[travis]:https://travis-ci.org/abhiTronix/vidgear\n[app]:https://ci.appveyor.com/project/abhiTronix/vidgear\n\n[test-4k]:https://github.com/abhiTronix/vidgear/blob/e0843720202b0921d1c26e2ce5b11fadefbec892/vidgear/tests/benchmark_tests/test_benchmark_playback.py#L65\n[bs_script_dataset]:https://github.com/abhiTronix/vidgear/blob/testing/scripts/bash/prepare_dataset.sh\n\n[wiki]:https://github.com/abhiTronix/vidgear/wiki\n[wiki-vidgear-purpose]:https://github.com/abhiTronix/vidgear/wiki/Project-Motivation#why-is-vidgear-a-thing\n[ultrafast-wiki]:https://github.com/abhiTronix/vidgear/wiki/FAQ-&-Troubleshooting#2-vidgear-is-ultrafast-but-how\n[ffmpeg-wiki]:https://github.com/abhiTronix/vidgear/wiki/FFmpeg-Installation\n[youtube-wiki]:https://github.com/abhiTronix/vidgear/wiki/CamGear#2-camgear-api-with-live-youtube-piplineing-using-video-url\n[TQM-wiki]:https://github.com/abhiTronix/vidgear/wiki/Threaded-Queue-Mode\n[camgear-wiki]:https://github.com/abhiTronix/vidgear/wiki/CamGear#camgear-api\n[stablizer-wiki]:https://github.com/abhiTronix/vidgear/wiki/Stabilizer-Class\n[stablizer-wiki-ex]:https://github.com/abhiTronix/vidgear/wiki/Real-time-Video-Stabilization#usage\n[videogear-wiki]:https://github.com/abhiTronix/vidgear/wiki/VideoGear#videogear-api\n[pigear-wiki]:https://github.com/abhiTronix/vidgear/wiki/PiGear#pigear-api\n[cm-writegear-wiki]:https://github.com/abhiTronix/vidgear/wiki/Compression-Mode:-FFmpeg\n[ncm-writegear-wiki]:https://github.com/abhiTronix/vidgear/wiki/Non-Compression-Mode:-OpenCV\n[screengear-wiki]:https://github.com/abhiTronix/vidgear/wiki/ScreenGear#screengear-api\n[writegear-wiki]:https://github.com/abhiTronix/vidgear/wiki/WriteGear#writegear-api\n[netgear-wiki]:https://github.com/abhiTronix/vidgear/wiki/NetGear#netgear-api\n\n\n\n\n[OpenCV-linux]:https://www.pyimagesearch.com/2018/05/28/ubuntu-18-04-how-to-install-opencv/\n[OpenCV-pi]:https://www.pyimagesearch.com/2018/09/26/install-opencv-4-on-your-raspberry-pi/\n[prs]:http://makeapullrequest.com \"Make a Pull Request (external link) \u27b6\"\n[opencv]:https://github.com/opencv/opencv\n[ffmpeg]:https://ffmpeg.org/\n[picamera]:https://github.com/waveform80/picamera\n[pafy]:https://github.com/mps-youtube/pafy\n[pyzmq]:https://github.com/zeromq/pyzmq\n[mss]:https://github.com/BoboTiG/python-mss\n[pip]:https://pip.pypa.io/en/stable/installing/\n[opencv-vc]:https://docs.opencv.org/master/d8/dfe/classcv_1_1VideoCapture.html#a57c0e81e83e60f36c83027dc2a188e80\n[OV5647-picam]:https://github.com/techyian/MMALSharp/wiki/OmniVision-OV5647-Camera-Module\n[IMX219-picam]:https://github.com/techyian/MMALSharp/wiki/Sony-IMX219-Camera-Module\n[opencv-vw]:https://docs.opencv.org/3.4/d8/dfe/classcv_1_1VideoCapture.html\n[yt-dl]:https://github.com/ytdl-org/youtube-dl/\n[numpy]:https://github.com/numpy/numpy\n\n", "description_content_type": "text/markdown", "docs_url": null, "download_url": "https://github.com/abhiTronix/vidgear/tarball/0.1.5", "downloads": { "last_day": -1, "last_month": -1, "last_week": -1 }, "home_page": "https://github.com/abhiTronix/vidgear", "keywords": "opencv,multithreading,FFmpeg,picamera,mss,pyzmq,pafy,Video Processing,Video Stablization,Computer Vision", "license": "MIT License", "maintainer": "", "maintainer_email": "", "name": "vidgear", "package_url": "https://pypi.org/project/vidgear/", "platform": "", "project_url": "https://pypi.org/project/vidgear/", "project_urls": { "Bug Reports": "https://github.com/abhiTronix/vidgear/issues", "Download": "https://github.com/abhiTronix/vidgear/tarball/0.1.5", "Funding": "https://www.buymeacoffee.com/2twOXFvlA", "Homepage": "https://github.com/abhiTronix/vidgear", "Source": "https://github.com/abhiTronix/vidgear" }, "release_url": "https://pypi.org/project/vidgear/0.1.5/", "requires_dist": [ "pafy", "mss", "youtube-dl", "requests", "pyzmq" ], "requires_python": ">=2.7", "summary": "Powerful python Video Processing library built with Multi-Threaded Gears(a.k.a APIs) each with a unique set of trailblazing features.", "version": "0.1.5" }, "last_serial": 5577973, "releases": { "0.1.0": [ { "comment_text": "", "digests": { "md5": "1f893f9c478a6c5f6fa43122e9f13ffe", "sha256": "cc1ee4b0435d71b21f5310454b409c0c2f6be79509a9499e9314319d97626d7e" }, "downloads": -1, "filename": "vidgear-0.1.0-py2.py3-none-any.whl", "has_sig": false, "md5_digest": "1f893f9c478a6c5f6fa43122e9f13ffe", "packagetype": "bdist_wheel", "python_version": "py2.py3", "requires_python": ">=2.7", "size": 5291, "upload_time": "2019-03-24T15:12:53", "url": "https://files.pythonhosted.org/packages/40/51/59159ecae9a6526d6d87ab69e48353efa77805ce8df40a1c19fce09a66c3/vidgear-0.1.0-py2.py3-none-any.whl" } ], "0.1.1": [ { "comment_text": "", "digests": { "md5": "b4ba8ba7eb007433ab67ae3a2a77c4c1", "sha256": "0cca7c7fbac160439e864aa37ef73fac9930fd8fb50397206d70757e943e6645" }, "downloads": -1, "filename": "vidgear-0.1.1-py2.py3-none-any.whl", "has_sig": false, "md5_digest": "b4ba8ba7eb007433ab67ae3a2a77c4c1", "packagetype": "bdist_wheel", "python_version": "py2.py3", "requires_python": ">=2.7", "size": 6865, "upload_time": "2019-03-24T15:41:24", "url": "https://files.pythonhosted.org/packages/da/5f/80885ec3cd1c4b248bfc71fbfa41b31a44daeb9f2dd580448be814fe9469/vidgear-0.1.1-py2.py3-none-any.whl" } ], "0.1.2": [ { "comment_text": "", "digests": { "md5": "2232321015ef0830c0cd283ae0a331d1", "sha256": "9ed2b621a7cfc5f87d7590e3b44fa004bceb895f7f6ef0b6c820236af13df716" }, "downloads": -1, "filename": "vidgear-0.1.2-py2.py3-none-any.whl", "has_sig": false, "md5_digest": "2232321015ef0830c0cd283ae0a331d1", "packagetype": "bdist_wheel", "python_version": "py2.py3", "requires_python": ">=2.7", "size": 8749, "upload_time": "2019-03-28T13:01:46", "url": "https://files.pythonhosted.org/packages/91/8d/acb230e454d39f4304ea8e04202ef4a3120bd507dca42bdeb8521b7fb0e6/vidgear-0.1.2-py2.py3-none-any.whl" } ], "0.1.3": [ { "comment_text": "", "digests": { "md5": "3dc5c2f3c0fa8a75123956b6818d2a3d", "sha256": "59c573363c726bdc0cc77d0744352bdbcc3e9266bf5ee16220e1bd46e247582e" }, "downloads": -1, "filename": "vidgear-0.1.3-py2.py3-none-any.whl", "has_sig": false, "md5_digest": "3dc5c2f3c0fa8a75123956b6818d2a3d", "packagetype": "bdist_wheel", "python_version": "py2.py3", "requires_python": ">=2.7", "size": 8820, "upload_time": "2019-04-07T15:45:21", "url": "https://files.pythonhosted.org/packages/f0/9f/5725a25188eefde39049f81a4cb64ceb212b1f94a5f5c39aef81cf35a2b6/vidgear-0.1.3-py2.py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "bf1604e8e376ef7ba8706895055442b4", "sha256": "5cd819d2833da7a88d7e28a2d7762dc75c61af9fc5aabca0d0b5a88f3554811b" }, "downloads": -1, "filename": "vidgear-0.1.3.tar.gz", "has_sig": false, "md5_digest": "bf1604e8e376ef7ba8706895055442b4", "packagetype": "sdist", "python_version": "source", "requires_python": ">=2.7", "size": 6537, "upload_time": "2019-04-07T15:45:22", "url": "https://files.pythonhosted.org/packages/95/c6/2a104c07f01692560d82af0399f40b3a9d01b4fec25d9a0f62d21a47a89c/vidgear-0.1.3.tar.gz" } ], "0.1.4": [ { "comment_text": "", "digests": { "md5": "c0f31ef1041f77af3b5ff6901b8f1650", "sha256": "601d5e0cb2679adafb2da958450af49149c99303772fc7c1b19ccff14be31470" }, "downloads": -1, "filename": "vidgear-0.1.4-py2.py3-none-any.whl", "has_sig": false, "md5_digest": "c0f31ef1041f77af3b5ff6901b8f1650", "packagetype": "bdist_wheel", "python_version": "py2.py3", "requires_python": ">=2.7", "size": 24823, "upload_time": "2019-05-13T03:10:00", "url": "https://files.pythonhosted.org/packages/1c/2c/f5bdbacc75156c5290cbaa0120ed9165f47aac5bd635bf2af40146f57fc4/vidgear-0.1.4-py2.py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "f9791ff1be162ddd8cb52c29ba78157e", "sha256": "e63fb0376703745fc0e02aed271b50d1a1e413a84697050c04667c1a8dc4da6c" }, "downloads": -1, "filename": "vidgear-0.1.4.tar.gz", "has_sig": false, "md5_digest": "f9791ff1be162ddd8cb52c29ba78157e", "packagetype": "sdist", "python_version": "source", "requires_python": ">=2.7", "size": 19527, "upload_time": "2019-05-13T03:10:02", "url": "https://files.pythonhosted.org/packages/6d/54/2e192574fa6f1821e183ed266d9645cf37e9fc573419859f17e43b1be099/vidgear-0.1.4.tar.gz" } ], "0.1.5": [ { "comment_text": "", "digests": { "md5": "e2e6abeeb360f089ee075b1a9fb59ca4", "sha256": "59822f5756ef08305fe1a86151a46e4e19a7865e6eb266c2902f46a40e40b185" }, "downloads": -1, "filename": "vidgear-0.1.5-py2.py3-none-any.whl", "has_sig": false, "md5_digest": "e2e6abeeb360f089ee075b1a9fb59ca4", "packagetype": "bdist_wheel", "python_version": "py2.py3", "requires_python": ">=2.7", "size": 45377, "upload_time": "2019-07-24T14:48:23", "url": "https://files.pythonhosted.org/packages/b4/b0/fd845d973cd15f38e1b479009bf0a005677a0375722cb0de3130bcf34c6c/vidgear-0.1.5-py2.py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "89d5bf961fa98d2f9eaa4fb3b38e05c0", "sha256": "464114b7a0babf90b04b743865483e59f8c4c78d8bb6c430bf9ead138a11b761" }, "downloads": -1, "filename": "vidgear-0.1.5.tar.gz", "has_sig": false, "md5_digest": "89d5bf961fa98d2f9eaa4fb3b38e05c0", "packagetype": "sdist", "python_version": "source", "requires_python": ">=2.7", "size": 41691, "upload_time": "2019-07-24T14:48:25", "url": "https://files.pythonhosted.org/packages/05/f4/67bd641a75442ffbc0167b4d81dffb6e858c5809955a23bd92cf63c987e1/vidgear-0.1.5.tar.gz" } ] }, "urls": [ { "comment_text": "", "digests": { "md5": "e2e6abeeb360f089ee075b1a9fb59ca4", "sha256": "59822f5756ef08305fe1a86151a46e4e19a7865e6eb266c2902f46a40e40b185" }, "downloads": -1, "filename": "vidgear-0.1.5-py2.py3-none-any.whl", "has_sig": false, "md5_digest": "e2e6abeeb360f089ee075b1a9fb59ca4", "packagetype": "bdist_wheel", "python_version": "py2.py3", "requires_python": ">=2.7", "size": 45377, "upload_time": "2019-07-24T14:48:23", "url": "https://files.pythonhosted.org/packages/b4/b0/fd845d973cd15f38e1b479009bf0a005677a0375722cb0de3130bcf34c6c/vidgear-0.1.5-py2.py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "89d5bf961fa98d2f9eaa4fb3b38e05c0", "sha256": "464114b7a0babf90b04b743865483e59f8c4c78d8bb6c430bf9ead138a11b761" }, "downloads": -1, "filename": "vidgear-0.1.5.tar.gz", "has_sig": false, "md5_digest": "89d5bf961fa98d2f9eaa4fb3b38e05c0", "packagetype": "sdist", "python_version": "source", "requires_python": ">=2.7", "size": 41691, "upload_time": "2019-07-24T14:48:25", "url": "https://files.pythonhosted.org/packages/05/f4/67bd641a75442ffbc0167b4d81dffb6e858c5809955a23bd92cf63c987e1/vidgear-0.1.5.tar.gz" } ] }