Skip to content

This is a Google Photos Frame in Python. It uses the Google Photos API to get the photos and display them randomly in fullscreen.

Notifications You must be signed in to change notification settings

guzmanvig/GooglePhotosFramePy

Repository files navigation

GooglePhotosFramePy: A Configurable Google Photos Frame in Python

IMPORTANT NOTE: The features are fully tested in Windows 10. For other OSs, some tweaks might be needed.

This is a Google Photos Frame in Python. It uses the Google Photos API to get the photos and display them randomly in fullscreen.

Has a bunch of configuration options such as displaying time and date, pausing, dim brightness, etc. Check config.py for the full configuration options.

Tested in: Windows 10, Ubuntu 20, MacOS 14.5

My use case

I have an old Windows tablet that is pretty much useless. I couldn't find any free, open-source, software that would turn it into a digital photo frame that would display my Google Photos. So I decided to create my own.

demo

Potential new features

At the moment, the app serves the purpose I needed it for. However, there are some features that could be added to make it more useful for other people. I'm down to do them if someone requests them.

  • Create a Batch script for Windows to start the program (or Bash for Linux).
  • Support other operating systems (macOS, Linux)
  • Better error handling, especially for when losing connection
  • Windows scheduler to start the app when the computer starts and turn off at night
  • Added configurable pause and brightness dim
  • Add album selection support
  • Support other ways to display the photos (zoomed, cropped, etc) - Zoomed in or with black margins added
  • Persist photo ids in a file to avoid getting them every time (could take time if there are too many)
  • Add whether information
  • Display metadata of photos (like the photo date)
  • Support videos
  • Support multiple accounts
  • Support other cloud services (Dropbox, OneDrive, etc) and local photos
  • Support other transition animations
  • Support other strategies to display the photos (instead of random, like ordered by date for example)

If you need one of these features (or other), feel free to open an issue or a pull request, or contact me at guzmanvigliecca@gmail.com

How to run

Pre-requisite: Python 3.12 installed (didn't test lower versions, but it's possible it works too)

Google Photos API setup

Because this app is not officially published in Google yet, you need to create your own project and credentials.

1 - Go to the Google Developers Console and create a new project.

2 - Enable the Google Photos API.

3 - Enable the photoslibrary.readonly scope.

4 - Set up the OAuth consent screen (you can set it up with minimal information since you will not publish the app).

5 - Add your email as a test user.

6 - Create credentials for a desktop app.

7 - Download the credentials file and save it as client_secret.json in the root folder of this project.

Running the app

Once the previous step is done, run bash run.sh if you are in Linux/MacOS or .\run.bat if you are in Windows. This should start the program. The first time the scripts run, the requirements are installed so it may take some time.

You can also manually create a virtual environment and install the requirements (which is exactly what the scripts do):

1 - Run python -m venv venv to create a virtual environment.

2 - Run venv\Scripts\activate to activate the virtual environment (this is for Windows, for Unix run source venv/bin/activate).

3 - Run pip install -r requirements.txt to install the requirements.

Then, run the following to start the app: python main.py.

How to use

Take a look at config.py to see all the configuration options and modify it as you wish.

The first time you run the app, it will open a browser window asking you to log in to your Google account. Then, the app will get all the photos download links from the date ranges you set in the config.py file, this can take a while depending on the number of photos you have. Then, it will display it in fullscreen randomly.

To quit the app press q (repeatedly if needed).

Note: If you don't see the slideshow in fullscreen, try specifying your screen resolution in the display_width and display_height fields in the config file.

Remote Control

The slideshow can be controlled remotely through a web interface or HTTP endpoints.

Web Interface

A React app is included in the slideshow-control directory that provides a simple interface to:

  • Skip to the next photo
  • Toggle black screen mode on/off
  • Open the current photo in Google Photos

To run it:

  1. Navigate to the slideshow-control directory and install dependencies:
cd slideshow-control
npm install
npm start

The interface will be available at http://localhost:3000 and can be accessed from any device in your network.

HTTP Endpoints

The slideshow also exposes HTTP endpoints on port 5000 that can be used to control it programmatically:

  • PUT /next-photo - Skip to next photo
  • PUT /black-screen - Toggle black screen mode
  • GET /current-photo-url - Get URL of current photo

Example using curl:

# Skip to next photo
curl -X PUT http://localhost:5000/next-photo

# Toggle black screen
curl -X PUT http://localhost:5000/black-screen

Note: Replace localhost with your computer's IP address when accessing from other devices.

About

This is a Google Photos Frame in Python. It uses the Google Photos API to get the photos and display them randomly in fullscreen.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published