vidpy


Namevidpy JSON
Version 0.2.0 PyPI version JSON
download
home_pagehttps://antiboredom.github.io/vidpy
SummaryVideo editing and compositing in Python
upload_time2023-10-12 04:12:45
maintainer
docs_urlNone
authorSam Lavigne
requires_python
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            VidPy
=====

.. image:: https://api.travis-ci.org/antiboredom/vidpy.svg
        :target: https://travis-ci.org/antiboredom/vidpy

A Python video editor and compositor based on the `MLT Multimedia
Framework <https://www.mltframework.org/>`__.

VidPy is currently in alpha - there are probably a bunch of bugs, and
the api will likely change. If you're interested in testing it out,
please do, and leave comments/suggestions/issues in the `issue
tracker <https://github.com/antiboredom/vidpy/issues>`__.

Read the full documentation here: https://antiboredom.github.io/vidpy

Installation/Dependencies
-------------------------

VidPy requires melt, which can be tricky to properly install on Mac and
Windows. The easiest option is to install Shotcut (an open source video
editor) which comes with a prebuilt melt binary.

Mac/Windows
~~~~~~~~~~~

1. `Install Shotcut <https://www.shotcut.org/download/>`__ (on a mac with brew: ``brew cask install shotcut``
2. Install VidPy with: ``pip install vidpy``

Ubuntu/Debian
~~~~~~~~~~~~~

1. Install melt: ``sudo apt-get install melt``
2. Install VidPy: ``pip install vidpy``

Setup
-----

VidPy will attempt to locate the melt binary, searching first for a
Shotcut installation on Mac/Windows. You can also point VidPy to a
specific binary like so:

.. code:: python

    from vidpy import config
    config.MELT_BINARY = '/path/to/melt'

Overview
--------

Use the ``Clip`` class to create and manipulate video clips, and the
``Composition`` class to put clips together.

``Composition()`` takes a list of clips as input, and then allows you to
save an output video with ``save()``, or to preview with ``preview()``.

By default a composition will treat each clip as a separate track,
playing them all at the same time.

.. code:: python

    from vidpy import Clip, Composition

    clip1 = Clip('video.mp4')
    clip2 = Clip('anothervideo.mp4')

    # play videos on top of each other
    composition = Composition([clip1, clip2])
    composition.save('output.mp4')

You can tell clips when to start playing with the ``offset`` parameter,
or with ``set_offset()`` after instantiation. All time is in seconds.

.. code:: python

    # start playing clip one after 1.5 seconds
    clip1 = Clip('video.mp4', offset=1.5)

    clip2 = Clip('anothervideo.mp4')
    clip2.set_offset(5) # start clip2 after 5 seconds

    composition = Composition([clip1, clip2])
    composition.save('output.mp4')

Trim clips with ``start`` and ``end`` parameters, or with the ``cut``
method.

.. code:: python

    # only use the first second of the clip
    clip1 = Clip('video.mp4', start=0, end=1)

    clip2 = Clip('anothervideo.mp4')
    clip2.cut(start=2, end=4) # use clip2 from 2 to 4 seconds

You can also play clips one after the other (instead of all at the same
time) by adding ``singletrack=True`` as a parameter to your composition.

.. code:: python

    composition = Composition([clip1, clip2], singletrack=True)
    composition.save('output.mp4')

``Composition`` also allows you to set dimensions, fps, and background
color.

.. code:: python

    # create a 1280x720 composition at 30 fps with a red background
    composition = Composition(clips, bgcolor="#ff0000", width=1280, height=720, fps=30)

    # preview it
    composition.preview()

Finally, you can convert compositions to clips to reuse.

.. code:: python

    comp = Composition([clip1, clip2, clip3], singletrack=True)
    clip = Clip(comp)

    # do stuff with the entire composition
    clip.cut(0, 1)

Filters & Effects
-----------------

There are a number of effects built into VidPy:

.. code:: python

    clip.fadein(1)      # fade the clip in over 1 second
    clip.fadeout(0.5)   # fade the clip over 0.5 seconds
    clip.glow()         # add a glow effect
    clip.spin(2)        # make the clip spin around. (Why would you do this? I don't know!)
    clip.chroma()       # attempt to automatically remove the background color
    clip.volume(0)      # mute a video

    # set clip's position 
    clip.position(x=100, y=20)

    # resize a clip
    clip.position(w='50%', h='20%'')

    # start the clip scaled to 200% at coordinates (0, 0)
    # then move it to (200, 200) and scale it to 90% over 5 seconds
    clip.zoompan([0, 0, '200%', '200%'], [200, 200, '90%', '90%'], start=0, end=5)

For a full list see the filters documentation: (link to come)

You can also use `any filter supported by
mlt <https://www.mltframework.org/plugins/PluginsFilters/>`__ with the
``fx`` method. The first parameter should be the name of the filter, and
the second a dictionary of options.

For example, to add a `cartoon
effect <https://www.mltframework.org/plugins/FilterFrei0r-cartoon/>`__:

.. code:: python

    # use the full filter name as the first parameter
    # and then a dictionary of options, based on the mlt documentation
    clip.fx('frei0r.cartoon', {'0': 0.999})

Or, `play with
colors <https://www.mltframework.org/plugins/FilterAvfilter-colorchannelmixer/>`__:

.. code:: python

    clip.fx('avfilter.colorchannelmixer', {'av.rr': 2, 'av.br': 2})

Remember to look at the mlt docs to figure out what parameters to pass
in.

Text
----

Use the ``Text`` class to add text clips

.. code:: python

    from vidpy import Text

    text_clip = Text("A spectre is haunting Europe.", font="Comic Sans Ms", size=100, color="#ff0000")

Some optional parameters for text clips are:

``font`` any font name on your system

``color`` color of text

``weight`` between 100 and 1000

``style`` normal or italic

``olcolor`` outline color

``outline`` outline size

``halign`` horizontal alignment (left, center, right)

``valign`` vertical alignment (top, middle, bottom)

``bbox`` a bounding box to put the text in (x, y, width, height)

Credits
-------

VidPy is by `Sam Lavigne <http://lav.io>`__, and draws heavily from
`MoviePy by Zulko <http://zulko.github.io/moviepy/>`__.

            

Raw data

            {
    "_id": null,
    "home_page": "https://antiboredom.github.io/vidpy",
    "name": "vidpy",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "",
    "author": "Sam Lavigne",
    "author_email": "lavigne@saaaam.com",
    "download_url": "https://files.pythonhosted.org/packages/8e/04/120c1fcfab3064fed7bbba76315beb35e98368000754b64f56a20a63c493/vidpy-0.2.0.tar.gz",
    "platform": null,
    "description": "VidPy\n=====\n\n.. image:: https://api.travis-ci.org/antiboredom/vidpy.svg\n        :target: https://travis-ci.org/antiboredom/vidpy\n\nA Python video editor and compositor based on the `MLT Multimedia\nFramework <https://www.mltframework.org/>`__.\n\nVidPy is currently in alpha - there are probably a bunch of bugs, and\nthe api will likely change. If you're interested in testing it out,\nplease do, and leave comments/suggestions/issues in the `issue\ntracker <https://github.com/antiboredom/vidpy/issues>`__.\n\nRead the full documentation here: https://antiboredom.github.io/vidpy\n\nInstallation/Dependencies\n-------------------------\n\nVidPy requires melt, which can be tricky to properly install on Mac and\nWindows. The easiest option is to install Shotcut (an open source video\neditor) which comes with a prebuilt melt binary.\n\nMac/Windows\n~~~~~~~~~~~\n\n1. `Install Shotcut <https://www.shotcut.org/download/>`__ (on a mac with brew: ``brew cask install shotcut``\n2. Install VidPy with: ``pip install vidpy``\n\nUbuntu/Debian\n~~~~~~~~~~~~~\n\n1. Install melt: ``sudo apt-get install melt``\n2. Install VidPy: ``pip install vidpy``\n\nSetup\n-----\n\nVidPy will attempt to locate the melt binary, searching first for a\nShotcut installation on Mac/Windows. You can also point VidPy to a\nspecific binary like so:\n\n.. code:: python\n\n    from vidpy import config\n    config.MELT_BINARY = '/path/to/melt'\n\nOverview\n--------\n\nUse the ``Clip`` class to create and manipulate video clips, and the\n``Composition`` class to put clips together.\n\n``Composition()`` takes a list of clips as input, and then allows you to\nsave an output video with ``save()``, or to preview with ``preview()``.\n\nBy default a composition will treat each clip as a separate track,\nplaying them all at the same time.\n\n.. code:: python\n\n    from vidpy import Clip, Composition\n\n    clip1 = Clip('video.mp4')\n    clip2 = Clip('anothervideo.mp4')\n\n    # play videos on top of each other\n    composition = Composition([clip1, clip2])\n    composition.save('output.mp4')\n\nYou can tell clips when to start playing with the ``offset`` parameter,\nor with ``set_offset()`` after instantiation. All time is in seconds.\n\n.. code:: python\n\n    # start playing clip one after 1.5 seconds\n    clip1 = Clip('video.mp4', offset=1.5)\n\n    clip2 = Clip('anothervideo.mp4')\n    clip2.set_offset(5) # start clip2 after 5 seconds\n\n    composition = Composition([clip1, clip2])\n    composition.save('output.mp4')\n\nTrim clips with ``start`` and ``end`` parameters, or with the ``cut``\nmethod.\n\n.. code:: python\n\n    # only use the first second of the clip\n    clip1 = Clip('video.mp4', start=0, end=1)\n\n    clip2 = Clip('anothervideo.mp4')\n    clip2.cut(start=2, end=4) # use clip2 from 2 to 4 seconds\n\nYou can also play clips one after the other (instead of all at the same\ntime) by adding ``singletrack=True`` as a parameter to your composition.\n\n.. code:: python\n\n    composition = Composition([clip1, clip2], singletrack=True)\n    composition.save('output.mp4')\n\n``Composition`` also allows you to set dimensions, fps, and background\ncolor.\n\n.. code:: python\n\n    # create a 1280x720 composition at 30 fps with a red background\n    composition = Composition(clips, bgcolor=\"#ff0000\", width=1280, height=720, fps=30)\n\n    # preview it\n    composition.preview()\n\nFinally, you can convert compositions to clips to reuse.\n\n.. code:: python\n\n    comp = Composition([clip1, clip2, clip3], singletrack=True)\n    clip = Clip(comp)\n\n    # do stuff with the entire composition\n    clip.cut(0, 1)\n\nFilters & Effects\n-----------------\n\nThere are a number of effects built into VidPy:\n\n.. code:: python\n\n    clip.fadein(1)      # fade the clip in over 1 second\n    clip.fadeout(0.5)   # fade the clip over 0.5 seconds\n    clip.glow()         # add a glow effect\n    clip.spin(2)        # make the clip spin around. (Why would you do this? I don't know!)\n    clip.chroma()       # attempt to automatically remove the background color\n    clip.volume(0)      # mute a video\n\n    # set clip's position \n    clip.position(x=100, y=20)\n\n    # resize a clip\n    clip.position(w='50%', h='20%'')\n\n    # start the clip scaled to 200% at coordinates (0, 0)\n    # then move it to (200, 200) and scale it to 90% over 5 seconds\n    clip.zoompan([0, 0, '200%', '200%'], [200, 200, '90%', '90%'], start=0, end=5)\n\nFor a full list see the filters documentation: (link to come)\n\nYou can also use `any filter supported by\nmlt <https://www.mltframework.org/plugins/PluginsFilters/>`__ with the\n``fx`` method. The first parameter should be the name of the filter, and\nthe second a dictionary of options.\n\nFor example, to add a `cartoon\neffect <https://www.mltframework.org/plugins/FilterFrei0r-cartoon/>`__:\n\n.. code:: python\n\n    # use the full filter name as the first parameter\n    # and then a dictionary of options, based on the mlt documentation\n    clip.fx('frei0r.cartoon', {'0': 0.999})\n\nOr, `play with\ncolors <https://www.mltframework.org/plugins/FilterAvfilter-colorchannelmixer/>`__:\n\n.. code:: python\n\n    clip.fx('avfilter.colorchannelmixer', {'av.rr': 2, 'av.br': 2})\n\nRemember to look at the mlt docs to figure out what parameters to pass\nin.\n\nText\n----\n\nUse the ``Text`` class to add text clips\n\n.. code:: python\n\n    from vidpy import Text\n\n    text_clip = Text(\"A spectre is haunting Europe.\", font=\"Comic Sans Ms\", size=100, color=\"#ff0000\")\n\nSome optional parameters for text clips are:\n\n``font`` any font name on your system\n\n``color`` color of text\n\n``weight`` between 100 and 1000\n\n``style`` normal or italic\n\n``olcolor`` outline color\n\n``outline`` outline size\n\n``halign`` horizontal alignment (left, center, right)\n\n``valign`` vertical alignment (top, middle, bottom)\n\n``bbox`` a bounding box to put the text in (x, y, width, height)\n\nCredits\n-------\n\nVidPy is by `Sam Lavigne <http://lav.io>`__, and draws heavily from\n`MoviePy by Zulko <http://zulko.github.io/moviepy/>`__.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Video editing and compositing in Python",
    "version": "0.2.0",
    "project_urls": {
        "Homepage": "https://antiboredom.github.io/vidpy"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8e04120c1fcfab3064fed7bbba76315beb35e98368000754b64f56a20a63c493",
                "md5": "0877333f2a76786fc6da5a6fc1c3a9b1",
                "sha256": "42c50b43c447b5ed3d5dd4ce29f8855a57cf90a33668cf818f64a49e44affdb9"
            },
            "downloads": -1,
            "filename": "vidpy-0.2.0.tar.gz",
            "has_sig": false,
            "md5_digest": "0877333f2a76786fc6da5a6fc1c3a9b1",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 30113,
            "upload_time": "2023-10-12T04:12:45",
            "upload_time_iso_8601": "2023-10-12T04:12:45.179922Z",
            "url": "https://files.pythonhosted.org/packages/8e/04/120c1fcfab3064fed7bbba76315beb35e98368000754b64f56a20a63c493/vidpy-0.2.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-10-12 04:12:45",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "lcname": "vidpy"
}
        
Elapsed time: 0.14389s