makelive


Namemakelive JSON
Version 0.6.2 PyPI version JSON
download
home_pageNone
SummaryAdd the necessary metadata to photo + video pair so Photos recognizes them as Live Photos when imported
upload_time2024-10-01 20:39:31
maintainerNone
docs_urlNone
authorNone
requires_python>3.9
licenseNone
keywords
VCS
bugtrack_url
requirements cgmetadata click pyobjc-core pyobjc-framework-AVFoundation pyobjc-framework-Contacts pyobjc-framework-CoreLocation pyobjc-framework-Quartz wheel wurlitzer
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # MakeLive
<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->
[![All Contributors](https://img.shields.io/badge/all_contributors-1-orange.svg?style=flat-square)](#contributors-)
<!-- ALL-CONTRIBUTORS-BADGE:END -->

Convert an photo + video pair into a Live Photo.

This is a simple command line tool that will apply the necessary metadata to a photo + video pair so that when they are imported into the Apple Photos, they will be treated as a Live Photo.

This is useful for converting images taken an Android phone into Live Photos that can be imported into Apple Photos.

## Usage

```bash
makelive image_1234.jpg image_1234.mov
```

## Requirements

- macOS (Tested on 13.5.1; should work on 10.15+)
- Python 3.9+

## Installation

### Install via Pre-Built Binary Installer Package

Download and run the latest installer package for your Mac architecture from the [releases page](https://github.com/RhetTbull/makelive/releases).

### Install via pip or pipx

Alternatively, you can install from PyPI:

- `python3 -m pip install makelive`

Or you can use [pipx](https://github.com/pypa/pipx):

- Open `Terminal` (search for `Terminal` in Spotlight or look in `Applications/Utilities`)
- Install `homebrew` according to instructions at [https://brew.sh/](https://brew.sh/)
- Type the following into Terminal: `brew install pipx`
- Ensure that pipx installed packages are accessible in your PATH by typing: `pipx ensurepath`
- Then type this: `pipx install makelive`
- Now you should be able to run `makelive` by typing: `makelive`

Once you've installed makelive with pipx, to upgrade to the latest version:

    pipx upgrade makelive

> [!NOTE]
> When installing other packages with homebrew, homebrew may update the version of Python installed which would then cause any app (including makelive) installed with `pipx` to fail. If this happens, the easiest fix is to reinstall makelive with:

    pipx reinstall makelive

Alternatively, you can reinstall all apps installed with `pipx` with:

    pipx reinstall-all

### Install from Source

To install from source:

- `git clone git@github.com:RhetTbull/makelive.git`
- `cd makelive`
- `pip install flit`
- `flit install`

## API

You can use makelive to programmatically create Live Photo pairs:

```python
from makelive import make_live_photo

photo_path = "test.jpg"
video_path = "test.mov"
asset_id = make_live_photo(photo_path, video_path)
print(f"Wrote Asset ID: {asset_id} to {photo_path} and {video_path}")
```

You can also check if a photo and video pair are a Live Photo pair and get the asset ID:

```python
from makelive import live_id, is_live_photo_pair
photo_path = "test.jpg"
video_path = "test.mov"
print(f"Is Live Photo Pair: {is_live_photo_pair(photo_path, video_path)}")
print(f"Asset ID: {live_id(photo_path)}")
```

Live Photos can also be created as a [.pvt package](https://fileinfo.com/extension/pvt). Use `save_live_photo_pair_as_pvt` to create a .pvt package from a photo and video pair. This is useful for creating Live Photos that can be shared via AirDrop or other methods that may not preserve the Live Photo metadata. Unlike `make_live_photo`, `save_live_photo_pair_as_pvt` does not modify the original photo and video files but instead copies them into a `.pvt` package and modifies the copies. If the original photo and video are already a Live Photo pair, the `.pvt` package will be created with the same asset ID; if not, a new asset ID will be generated.

```python
from makelive import save_live_photo_pair_as_pvt
photo_path = "test.jpg"
video_path = "test.mov"
asset_id, pvt_path = save_live_photo_pair_as_pvt(photo_path, video_path)
print(f"Wrote .pvt package to {pvt_path} with {asset_id}")
```

> [!NOTE]
> XMP metadata in the QuickTime movie file is not preserved when writing the Content Identifier tag to the movie file which may result in metadata loss.

Metadata including EXIF, IPTC, and XMP are preserved in the image file but will be rewritten and the Core Graphics API may change the order of the metadata and normalize the values. For example, the tag XMP:TagsList will be rewritten as XMP:Subject and the value will be normalized to a list of title case strings.

If you must preserve the original metadata completely, it is recommended to make a copy of the metadata using a tool like [exiftool](https://exiftool.org) before calling this function and then restore the metadata after calling this function. (But take care not to delete the `ContentIdentifier` metadata.)

## How it works

In order for Photos to treat a photo + video pair as a Live Photo, the video file must contain a Content Identifier metadata tag set to a [UUID](https://en.wikipedia.org/wiki/Universally_unique_identifier). The associated photo must contain a Content Identifier metadata tag set to the same UUID. Unfortunately, these tags cannot be written with the standard [exiftool](https://exiftool.org/) utility if they do not already exist in the file as the metadata is stored in Maker Notes which exiftool cannot create.

This tool uses the Core Graphics and AV Foundation frameworks to modify the metadata of the photo and video files to add the required Content Identifier.

## Caution

> [!WARNING]
> This tool has not yet been extensively tested. It is recommended that you make a backup of your photo and video files before using this tool as it will overwrite the files which is required to add the necessary metadata. This also means that the files will be re-encoded and as a result, the file size may change, as may the quality of the image and video. I've used the native Apple APIs to do the encoding at maxixum quality but you should verify that the results are suitable for your needs.

## Source Code

The source code is available [here](https://github.com/RhetTbull/makelive).

## License

MIT License, see [LICENSE](LICENSE) for details.

## Credits

The [Live-Photo-master](https://github.com/GUIYIVIEW/LivePhoto-master) project by [GUIYIVIEW](https://github.com/GUIYIVIEW) was helpful for understanding how to set the asset ID in the QuickTime file. Copyright (c) 2017 GUIYIVIEW and [published under the MIT License](https://github.com/GUIYIVIEW/LivePhoto-master/blob/master/LICENSE).

Thank you to [Yorian](https://github.com/Yorian) who proposed this project and provided the test images. For more information, see [this discussion](https://github.com/RhetTbull/makelive/discussions/1398).

## Contributors ✨

Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):

<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->
<!-- prettier-ignore-start -->
<!-- markdownlint-disable -->
<table>
  <tbody>
    <tr>
      <td align="center" valign="top" width="14.28%"><a href="http://am1006.me"><img src="https://avatars.githubusercontent.com/u/13403435?v=4?s=100" width="100px;" alt="Luitbald"/><br /><sub><b>Luitbald</b></sub></a><br /><a href="https://github.com/RhetTbull/makelive/commits?author=am1006" title="Code">💻</a></td>
    </tr>
  </tbody>
</table>

<!-- markdownlint-restore -->
<!-- prettier-ignore-end -->

<!-- ALL-CONTRIBUTORS-LIST:END -->

This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "makelive",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">3.9",
    "maintainer_email": null,
    "keywords": null,
    "author": null,
    "author_email": "Rhet Turnbull <rturnbull+git@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/46/51/a546b6bad0f498fc0723fae6c336c3b73e5e47cffa2b3f83dcd966c084da/makelive-0.6.2.tar.gz",
    "platform": null,
    "description": "# MakeLive\n<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section -->\n[![All Contributors](https://img.shields.io/badge/all_contributors-1-orange.svg?style=flat-square)](#contributors-)\n<!-- ALL-CONTRIBUTORS-BADGE:END -->\n\nConvert an photo + video pair into a Live Photo.\n\nThis is a simple command line tool that will apply the necessary metadata to a photo + video pair so that when they are imported into the Apple Photos, they will be treated as a Live Photo.\n\nThis is useful for converting images taken an Android phone into Live Photos that can be imported into Apple Photos.\n\n## Usage\n\n```bash\nmakelive image_1234.jpg image_1234.mov\n```\n\n## Requirements\n\n- macOS (Tested on 13.5.1; should work on 10.15+)\n- Python 3.9+\n\n## Installation\n\n### Install via Pre-Built Binary Installer Package\n\nDownload and run the latest installer package for your Mac architecture from the [releases page](https://github.com/RhetTbull/makelive/releases).\n\n### Install via pip or pipx\n\nAlternatively, you can install from PyPI:\n\n- `python3 -m pip install makelive`\n\nOr you can use [pipx](https://github.com/pypa/pipx):\n\n- Open `Terminal` (search for `Terminal` in Spotlight or look in `Applications/Utilities`)\n- Install `homebrew` according to instructions at [https://brew.sh/](https://brew.sh/)\n- Type the following into Terminal: `brew install pipx`\n- Ensure that pipx installed packages are accessible in your PATH by typing: `pipx ensurepath`\n- Then type this: `pipx install makelive`\n- Now you should be able to run `makelive` by typing: `makelive`\n\nOnce you've installed makelive with pipx, to upgrade to the latest version:\n\n    pipx upgrade makelive\n\n> [!NOTE]\n> When installing other packages with homebrew, homebrew may update the version of Python installed which would then cause any app (including makelive) installed with `pipx` to fail. If this happens, the easiest fix is to reinstall makelive with:\n\n    pipx reinstall makelive\n\nAlternatively, you can reinstall all apps installed with `pipx` with:\n\n    pipx reinstall-all\n\n### Install from Source\n\nTo install from source:\n\n- `git clone git@github.com:RhetTbull/makelive.git`\n- `cd makelive`\n- `pip install flit`\n- `flit install`\n\n## API\n\nYou can use makelive to programmatically create Live Photo pairs:\n\n```python\nfrom makelive import make_live_photo\n\nphoto_path = \"test.jpg\"\nvideo_path = \"test.mov\"\nasset_id = make_live_photo(photo_path, video_path)\nprint(f\"Wrote Asset ID: {asset_id} to {photo_path} and {video_path}\")\n```\n\nYou can also check if a photo and video pair are a Live Photo pair and get the asset ID:\n\n```python\nfrom makelive import live_id, is_live_photo_pair\nphoto_path = \"test.jpg\"\nvideo_path = \"test.mov\"\nprint(f\"Is Live Photo Pair: {is_live_photo_pair(photo_path, video_path)}\")\nprint(f\"Asset ID: {live_id(photo_path)}\")\n```\n\nLive Photos can also be created as a [.pvt package](https://fileinfo.com/extension/pvt). Use `save_live_photo_pair_as_pvt` to create a .pvt package from a photo and video pair. This is useful for creating Live Photos that can be shared via AirDrop or other methods that may not preserve the Live Photo metadata. Unlike `make_live_photo`, `save_live_photo_pair_as_pvt` does not modify the original photo and video files but instead copies them into a `.pvt` package and modifies the copies. If the original photo and video are already a Live Photo pair, the `.pvt` package will be created with the same asset ID; if not, a new asset ID will be generated.\n\n```python\nfrom makelive import save_live_photo_pair_as_pvt\nphoto_path = \"test.jpg\"\nvideo_path = \"test.mov\"\nasset_id, pvt_path = save_live_photo_pair_as_pvt(photo_path, video_path)\nprint(f\"Wrote .pvt package to {pvt_path} with {asset_id}\")\n```\n\n> [!NOTE]\n> XMP metadata in the QuickTime movie file is not preserved when writing the Content Identifier tag to the movie file which may result in metadata loss.\n\nMetadata including EXIF, IPTC, and XMP are preserved in the image file but will be rewritten and the Core Graphics API may change the order of the metadata and normalize the values. For example, the tag XMP:TagsList will be rewritten as XMP:Subject and the value will be normalized to a list of title case strings.\n\nIf you must preserve the original metadata completely, it is recommended to make a copy of the metadata using a tool like [exiftool](https://exiftool.org) before calling this function and then restore the metadata after calling this function. (But take care not to delete the `ContentIdentifier` metadata.)\n\n## How it works\n\nIn order for Photos to treat a photo + video pair as a Live Photo, the video file must contain a Content Identifier metadata tag set to a [UUID](https://en.wikipedia.org/wiki/Universally_unique_identifier). The associated photo must contain a Content Identifier metadata tag set to the same UUID. Unfortunately, these tags cannot be written with the standard [exiftool](https://exiftool.org/) utility if they do not already exist in the file as the metadata is stored in Maker Notes which exiftool cannot create.\n\nThis tool uses the Core Graphics and AV Foundation frameworks to modify the metadata of the photo and video files to add the required Content Identifier.\n\n## Caution\n\n> [!WARNING]\n> This tool has not yet been extensively tested. It is recommended that you make a backup of your photo and video files before using this tool as it will overwrite the files which is required to add the necessary metadata. This also means that the files will be re-encoded and as a result, the file size may change, as may the quality of the image and video. I've used the native Apple APIs to do the encoding at maxixum quality but you should verify that the results are suitable for your needs.\n\n## Source Code\n\nThe source code is available [here](https://github.com/RhetTbull/makelive).\n\n## License\n\nMIT License, see [LICENSE](LICENSE) for details.\n\n## Credits\n\nThe [Live-Photo-master](https://github.com/GUIYIVIEW/LivePhoto-master) project by [GUIYIVIEW](https://github.com/GUIYIVIEW) was helpful for understanding how to set the asset ID in the QuickTime file. Copyright (c) 2017 GUIYIVIEW and [published under the MIT License](https://github.com/GUIYIVIEW/LivePhoto-master/blob/master/LICENSE).\n\nThank you to [Yorian](https://github.com/Yorian) who proposed this project and provided the test images. For more information, see [this discussion](https://github.com/RhetTbull/makelive/discussions/1398).\n\n## Contributors \u2728\n\nThanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):\n\n<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->\n<!-- prettier-ignore-start -->\n<!-- markdownlint-disable -->\n<table>\n  <tbody>\n    <tr>\n      <td align=\"center\" valign=\"top\" width=\"14.28%\"><a href=\"http://am1006.me\"><img src=\"https://avatars.githubusercontent.com/u/13403435?v=4?s=100\" width=\"100px;\" alt=\"Luitbald\"/><br /><sub><b>Luitbald</b></sub></a><br /><a href=\"https://github.com/RhetTbull/makelive/commits?author=am1006\" title=\"Code\">\ud83d\udcbb</a></td>\n    </tr>\n  </tbody>\n</table>\n\n<!-- markdownlint-restore -->\n<!-- prettier-ignore-end -->\n\n<!-- ALL-CONTRIBUTORS-LIST:END -->\n\nThis project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Add the necessary metadata to photo + video pair so Photos recognizes them as Live Photos when imported",
    "version": "0.6.2",
    "project_urls": {
        "Home": "https://github.com/RhetTbull/makelive",
        "Issues": "https://github.com/RhetTbull/makelive/issues",
        "Source": "https://github.com/RhetTbull/makelive"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "441ad51a6b426adad30c7a8668e11ad976d341c6ecd058a6942495a10a79487f",
                "md5": "c187da354a98b756ff96165b2d5acac0",
                "sha256": "1228e90282790f81cc7cdf0a795dc99299c02a545d2225e83210461ce30d1808"
            },
            "downloads": -1,
            "filename": "makelive-0.6.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "c187da354a98b756ff96165b2d5acac0",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">3.9",
            "size": 11725,
            "upload_time": "2024-10-01T20:39:30",
            "upload_time_iso_8601": "2024-10-01T20:39:30.082892Z",
            "url": "https://files.pythonhosted.org/packages/44/1a/d51a6b426adad30c7a8668e11ad976d341c6ecd058a6942495a10a79487f/makelive-0.6.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "4651a546b6bad0f498fc0723fae6c336c3b73e5e47cffa2b3f83dcd966c084da",
                "md5": "50b8a89ae5aed3917fcc6ba03572ed62",
                "sha256": "df02b715116e462a3e7316517eb91b8f9a1dbad1d6d41352fd562f44a168e858"
            },
            "downloads": -1,
            "filename": "makelive-0.6.2.tar.gz",
            "has_sig": false,
            "md5_digest": "50b8a89ae5aed3917fcc6ba03572ed62",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">3.9",
            "size": 18723,
            "upload_time": "2024-10-01T20:39:31",
            "upload_time_iso_8601": "2024-10-01T20:39:31.887080Z",
            "url": "https://files.pythonhosted.org/packages/46/51/a546b6bad0f498fc0723fae6c336c3b73e5e47cffa2b3f83dcd966c084da/makelive-0.6.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-01 20:39:31",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "RhetTbull",
    "github_project": "makelive",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [
        {
            "name": "cgmetadata",
            "specs": [
                [
                    ">=",
                    "0.1.6"
                ]
            ]
        },
        {
            "name": "click",
            "specs": [
                [
                    ">=",
                    "8.0"
                ]
            ]
        },
        {
            "name": "pyobjc-core",
            "specs": [
                [
                    ">=",
                    "9.2"
                ]
            ]
        },
        {
            "name": "pyobjc-framework-AVFoundation",
            "specs": [
                [
                    ">=",
                    "9.2"
                ]
            ]
        },
        {
            "name": "pyobjc-framework-Contacts",
            "specs": [
                [
                    ">=",
                    "9.2"
                ]
            ]
        },
        {
            "name": "pyobjc-framework-CoreLocation",
            "specs": [
                [
                    ">=",
                    "9.2"
                ]
            ]
        },
        {
            "name": "pyobjc-framework-Quartz",
            "specs": [
                [
                    ">=",
                    "9.2"
                ]
            ]
        },
        {
            "name": "wheel",
            "specs": [
                [
                    ">=",
                    "0.41.2"
                ]
            ]
        },
        {
            "name": "wurlitzer",
            "specs": [
                [
                    ">=",
                    "3.0.3"
                ]
            ]
        }
    ],
    "lcname": "makelive"
}
        
Elapsed time: 0.31920s