From abe197cf5933c9093e4803232e21a24731cb046a Mon Sep 17 00:00:00 2001 From: Horshack Date: Tue, 19 Mar 2024 07:31:40 -0400 Subject: [PATCH] Moved documentation from testcams.com to GitHub Pages --- docs/canomate_logo_64x64.png | Bin 0 -> 2490 bytes docs/index.html | 592 +++++++++++++++++++++++++++++++++++ 2 files changed, 592 insertions(+) create mode 100644 docs/canomate_logo_64x64.png create mode 100644 docs/index.html diff --git a/docs/canomate_logo_64x64.png b/docs/canomate_logo_64x64.png new file mode 100644 index 0000000000000000000000000000000000000000..0776821c9d0013ffe40d7ee4f503beba107aeb22 GIT binary patch literal 2490 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 + + + +Canomate - Automation tool for Canon cameras + + + + + + + + + +
canomate logo

Canomate - Automation tool for Canon cameras

+

This is the official homepage of Canomate, my open-source utility for automating operations on WiFi-equipped Canon cameras that support Canon's Camera Control API (CCAPI). Canomate runs on Windows, Mac, Linux, and any other platform that has support for Python 3.5+. Canomate is licensed under GPL v3.

+ +

Requirements

+

Cameras Supported

+

As of 8/26/20 the following Canon cameras support CCAPI. Canon USA's list can be downloaded via here:

+
    +
  • R5, R6, RP
  • +
  • 1D X Mark III
  • +
  • M6 Mark II, M200
  • +
  • 90D, Rebel T8i 
  • +
  • PowerShot SX70 HS
  • +
  • PowerShot G5 X Mark II
  • +
  • PowerShot G7 X Mark III
  • +
+

Software Required

+
    +
  • Any OS that supports Python 3.5 or later, including Windows, OSX/Mac, and Linux
  • +
  • Python 3.5 or later. I tested under 3.8.0 during development
  • +
  • Third-party requests module for Python
  • +
+

One-Time Setup Instructions

+

Installing Canomate

+
    +
  1. Download the source files by going to my Canomate GitHub repository, click the green 'Code' button and then "Download ZIP"
  2. +
  3. Unzip the files to a directory on your local system. I recommend creating a canomate directory off your home directory
  4. +
+

Python Setup

+
    +
  1. Canomate requires Python 3.5 or later. You can download the latest version from here. On OSX/Mac, Python 2.7x comes included but you'll need to install a 3.5 or later version of Python for Canomate to work. By default the Python 3 installer will place the python3 executable in /usr/local/bin
  2. +
  3. Canomate uses the third-party requests module for its HTTP communication to the camera. You can install it with either "pip install requests" or with "pip3 install requests".
  4. +
+

Camera Setup

+
    +
  1. Before you can enable CCAPI on your camera you must first perform a one-time activation of the feature using Canon's + CCAPI activation tool, which is distributed on Canon's developer + website here - click "Camera Control API (CCAPI)" to see the download links for the activation tool. + Both Windows and Mac versions are provided. To gain access to the download links you'll need to register on Canon's site, which can be done for free here.
  2. +
  3. To activate your camera using Canon's activation app, connect the camera to your computer over USB and launch the app. It will send some MTP/PTP requests to the camera to activate its CCAPI support. It only takes a second to run.
  4. +
  5. Once CCAPI support has been activated you can enable the feature by going to "Wireless communication settings" in the camera's menu, select "Wi-Fi +settings", then scroll down to "Camera Control API". You'll need to select the SSID and enter a password for +your local wireless network if you haven't already done so for one of the camera's other wireless features. If your router supports WPS you can use it to complete the setup faster. You'll be prompted to use an Auto (DHCP) or static IP address for the camera - a static IP may make it easier to use +this Canomate since you'll always know the camera's IP address rather than +having to check the camera (although most routers will reuse the same IP +address for a given MAC address).. At the last step of the process the +camera will display a URL you can access; enter that URL into your computer's browser +to finalize the setup and verify everything is working.
  6. +
  7. When done you'll also want to enable "Auto connect" in the same Camera +Control API menu of the camera; that way the camera will automatically +connect to your network and enable the CCAPI whenever you turn the camera +on. You may need to temporarily disconnect from CCAPI in the camera menu in +order to turn "Auto connect" on. +
  8. +
+

Quick Start Guide

+

Launching Canomate

+

Canomate can be started in one of the following ways:

+
    +
  1. Type "canomate.py" for systems that have Python 3 configured as the default handler for .py files or systems which honor the "!/usr/bin/env python3" directive at the top of the file
  2. +
  3. Type "python3 canomate.py" for systems that have Python 2 configured as the default handler for .py files (Mac for example)
  4. +
  5. Type "python canomate.py" for systems where python involves Python 3 by default.
  6. +
+

Canomate is a command-line tool. There are many options, both from the command line and within the automation script you create. Here is a guide on the bare essential options to get started.

+

Essential Command Line options

+

--ipaddress=<addr> - The IP address of the camera on your local WiFi network. You can get this address by going to the "Wireless Communication settings" in the camera's menu and going to "Camera Control API", "Wi-Fi settings", "Camera Control API". The URL at the bottom of the screen includes the IP address of the camera

+

--opfile=<filename> - The path/filename of the text file containing your automation script

+

Simple Automation Scripts

+

The automation script is a text file you create that lists all the automation operations to perform. Each line takes the form of <Operation Name> <param=value>. For example, here is a simple script that displays the model/serial # information from the camera, followed by the current P/A/S/M mode dial and exposure settings, and finally, the current still image quality settings:

+
+
+PrintCameraInfo
+PrintShootingSettings
+PrintStillImageQuality listavailable=yes
+
+
+

Here is the output from the above script:

+
+
+canomate v0.01 - Automation Utility for Canon cameras (uses Canon Control API via WiFi)
+Copyright (c) Horshack, System Time: 08/26/20 12:38:00, Py: 3.8.0, OS: Windows
+
+PrintCameraInfo: Model: Canon EOS RP, S/N: XXXXXXXXXXXX, Firmware: 1.5.0
+PrintShootingSettings: Mode: m, Aperture: f8.0, SS: 1/250, ISO: 200, EC:
+PrintStillImageQuality: Raw: none, JPEG: small2 Available: Raw: ['none', 'raw', 'craw'], JPEG: ['none', 'large_fine', 'large_normal', 'medium_fine', 'medium_normal', 'small1_fine', 'small1_normal', 'small2']
+>>>> canomate session over (exit=0), logs at "C:\develop\canomate\canomate-appdata"
+
+
+

After the program banner, each line of output corresponds to a single automation operation. Notice the "listavailable=yes" parameter for PrintStillImageQuality - this parameter is available for many of the PrintXXX operations and will display all the possible choices for the setting, along with the current setting on the camera. This is useful during the development of your script so you'll know how to specify a given setting. For example, let's say you want to change the JPEG shooting quality from it's current setting of 'small2' to a larger size. You would use the SetStillImageQuality operation, specifying the desired JPEG quality option from the available options displayed by PrintStillImageQuality.

+
+
SetStillImageQuality rawquality=none jpegquality=large_normal
+
+

Let's do something more useful - like taking a photo! Let's also set the specific exposure settings we want to use rather than relying on whatever the camera is currently set to. Here is the script:

+
+
+AssertCameraSettings moviemode=off modedial=m 
+SetAperture aperture=f5.6
+SetShutterSpeed shutterspeed=1/200
+SetIso iso=400
+TakePhoto
+
+
+

The first operation "AssertCameraSettings" tells Canomate to make sure the camera is in stills mode and the camera's mode dial is set to 'm' (Manual), which is necessary for the camera to accept all three of the exposure settings we want to set. If the camera were in another mode like 'av' (Aperture Priority) or 'tv' (Shutter Priority) then the camera wouldn't let us set the Shutter Speed and Aperture respectively since those are automatically calculated by the camera in those modes. Using "AssertCameraSettings" operations is good practice since it avoids having to decipher subsequent error messages if you attempt a setting or operation that is incompatible with the camera's current mode of operation. When Canomate encounters the "AssertCameraSettings" operation it retrieves the camera setting associated with each specified setting and verifies it matches the value specified, in this case making sure the camera's Mode Dial is set to 'm'. If the camera's mode dial is in any other position then Canomate will display a message and terminate the script. For example:

+
+
AssertCameraSettings: Mode dial setting is "av" but must be "m"
+
+

The remaining operations are self-explanatory. The photo will be stored on the camera's internal media card, the same as if you took the photo holding the camera yourself. There are additional automation operations you can use to retrieve information about the photo just taken and also an operation to download it. You can even configure an operation to launch an application of your choice to handle the downloaded photo, such as your favorite image viewer. All thisfunctionality isn't just limited to stills - you can also automate the taking of videos as well.

+

Automation Script Reference

+Detailed documentation for each of the operation's automation parameters is a bit sparse for now. See the RegressionTest_RP.txt file (and its output here) for examples of each operation and its parameters in use. +

Overview

+

The automation script is a text file you create that lists all the automation operations to perform. Each line is in the form of <Operation Name> <param=value>. Operations can take zero, one, or more parameters, depending on the specific operation. Some parameters are common to all operations.

+

The value for each parameter can optionally be enclosed in double-quotes, unless the operation contains a space, in which case quotes are mandatory. Filenames are an example of parameters that should be quoted.

+

If the same parameter is specified multiple times then the last parameter overrides the previous instances.

+

You can include comments in your script by beginning the line with a # sign.

+

Groups

+

Automation operations can optionally be placed inside a Group operation. This makes it easy to repeat a given set of operations using the 'grouprepeatcount' parameter. The alternative would require copying and pasting the same set of operations multiple times. Each Group operation in the script must have a corresponding EndGroup.

+

Parameter Inheritance

+

There are up to four levels inheritance for parameters, listed as followed in lowest to highest priority: Defaults, Command Line, Group, and Operation. "Command Line" inheritance applies only to parameters that can be specified on both the command line and in the automation script, such as --timeout.

+

Parameters specified for a Group operation are inherited by all operations within the group. For example, 'retrycount' specified for a Group becomes the default retry count for each operation contained within the Group. That paramter can be overridden on a per-operation basis by supplying the 'retrycount' parameter for the operation. Parameters specific to Groups are not inherited by the operations within the group, or to nested groups . For example, the following script will execute each operation within the group 2 times for each iteration of the group, and perform 3 iterations of the group.

+
+
+# Example of group vs operation repeat counts
+Group grouprepeatcount=3 repeatcount=2
+PrintMessageToLog message="Hello, world"
+PrintMessageToLog message="Cruel, Cruel, world"
+EndGroup
+
+
+

Output:

+
+
+Performing group "Example 1", Iteration 1/3
+PrintMessageToLog: Hello, world
+PrintMessageToLog: Hello, world
+PrintMessageToLog: Cruel, Cruel, world
+PrintMessageToLog: Cruel, Cruel, world
+Performing group "Example 1", Iteration 2/3
+PrintMessageToLog: Hello, world
+PrintMessageToLog: Hello, world
+PrintMessageToLog: Cruel, Cruel, world
+PrintMessageToLog: Cruel, Cruel, world
+Performing group "Example 1", Iteration 3/3
+PrintMessageToLog: Hello, world
+PrintMessageToLog: Hello, world
+PrintMessageToLog: Cruel, Cruel, world
+PrintMessageToLog: Cruel, Cruel, world
+
+
+

Group Nesting

+

Groups can be nested. Parameters specified on the outer group are inherited by operations contained inside nested group. Group-specific parameters are never inherited by either operations or nested groups. In the following example, group "Inner" does not inherit the 'grouprepeatcount' of "Outer", but the operations within "Inner" do inherit the 'repeatcount' of "Outer"

+
+
Group groupname="Outer" grouprepeatcount=2 repeatcount=3
+PrintMessageToLog message="I'm an outtie"
+Group groupname="Inner"
+PrintMessageToLog message="I'm an innie"
+EndGroup
+EndGroup
+
+
+

Output:

+
+
Performing group "Outer", Iteration 1/2
+PrintMessageToLog: I'm an outtie
+PrintMessageToLog: I'm an outtie
+PrintMessageToLog: I'm an outtie
+Performing group "Innner", Iteration 1/1
+PrintMessageToLog: I'm an innie
+PrintMessageToLog: I'm an innie
+PrintMessageToLog: I'm an innie
+Performing group "Outer", Iteration 2/2
+PrintMessageToLog: I'm an outtie
+PrintMessageToLog: I'm an outtie
+PrintMessageToLog: I'm an outtie
+Performing group "Innner", Iteration 1/1
+PrintMessageToLog: I'm an innie
+PrintMessageToLog: I'm an innie
+PrintMessageToLog: I'm an innie
+
+
+

Operation Table

+

The following table lists all operations available and the parameters they accept. Parameters in red are required. Parameters in black are optional

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
OperationParameters
Operation Containers
Groupgroupname, grouprepeatcount
EndGroup 
Information
PrintCameraInfo 
PrintCameraDateTime 
PrintShootingSettings 
PrintShootingModeDial 
PrintLensInfo 
PrintBatteryInfo 
PrintTemperatureStatus 
Exposure
PrintAperturelistavailable
SetApertureaperture
PrintShutterSpeedlistavailable
SetShutterSpeedshutterspeed
PrintIsolistavailable
SetIsoiso
PrintExposureCompensationlistavailable
SetExposureCompensationexposurecompensation
PrintMeteringModelistavailable
SetMeteringModemeteringmode
WB/Picture Controls
PrintWhiteBalancelistavailable
SetWhiteBalance whitebalance
Stills Operation
TakePhotoautofocus
PrintStillImageQualitylistavailable
SetStillImageQualityrawquality, jpegquality
Movie Operation
PrintMovieMode 
EnterMovieMode 
ExitMovieMode 
PrintMovieQualitylistavailable
SetMovieQualitymoviequality
StartMovieRecord 
StopMovieRecord 
AF/Drive Mode
PrintDriveModelistavailable
SetDriveModedrivemode
PrintAfOperation 
PrintAfMethodlistavailable
SetAfMethodafmethod
File Operations
WaitForNewFilesOnCameramaxwaittime
GetInfoOnNewFilesPolled 
DownloadNewFilesPolledoutputdir, ifexists
DownloadFileByUrlurl, outputdir, ifexists
Non-Camera Operations
RunExecutable

executable, waitforcompletion, exitonlauncherr, appendlastdownloadstoargs, outputfile, writemode, assertexitcode. Arguments to executable specified on separate line via RunExecutableArgs

ExitAppexitcode
Delaydelaytime
WaitForEnterKeyToContinuebeep
Beep 
PrintMessageToLogmessage
Misc. / Utility
SyncDateTimeskewsecs
AssertCameraSettingsmodedial, moviemode, afoperation
GetPendingEventsprintevents
DisconnectWireless 
PrintAPI 
GetInfoByUrlurl
+

Parameters Common to All Operations

+

The following table lists parameters available to all operations. When specified on a Group the parameters will be inherited by all operations the group contains - the children can still override their inherited parameters by specifying the parameter for the operation.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ParameterDescription
repeatcountNumber of times operation is repeated before moving on to next operation. Default is 1
delayafterAmount of time to delay after completing operation before the next operation is performed. Can be specified as a value in seconds or in hh:mm:ss or mm:ss form. Default is 0
timeoutOverrides --timeout command line parameter for this operation.
downloadtimeoutOverrides --downloadtimeout command line parameter for this operation.
transportretriesOverrides --transportretries command line parameter for this operation.
cmdretriesOverrides --cmdretries command line parameter for this operation.
retrydelayOverrides --retrydelay command line parameter for this operation.
maxbusyretrytimeOverrides --maxbusyretrytime command line parameter for this operation.
exitoncmderrOverrides --exitoncmderr command line parameter for this operation.
+

Operations Reference

+

<To Do>

+

Command Line Reference

+

All argument names are case sensitive but the optional values for each argument are case-insensitive. For example "--logginglevel" must be under-case but the actual value specified can be any case.

+

You can abbreviate any argument name by using just enough characters to uniquely distinguish it from other argument names. For example, --ip in place of --ipaddress.

+

--help
+ Prints a help display listing all the typical options supported. You can also obtain help by invoking Canomate with no arguments

+

!filename
+ Load additional arguments from a text file. In addition to any parameter files you specify, Canomate will always load a file named 'canomate-defaultopts' from the same directory Canomate is in. The parameters from the default file will be loaded first, allowing you to override them with parameters from your own files and those specified on the command line. All parameter files must be formatted so that each parameter word is on a separate line, which is a requirement of Python's argparse routine. For example:

+
	--ipaddress
+	192.168.1.155
+	--opfile
+	takephotos.txt
+
+

--ipaddress address (no default - required parameter)
+Specifies the IP address of the camera. You can get this address by going to the "Wireless Communication settings" in the camera's menu and going to "Camera Control API", "Wi-Fi settings", "Camera Control API". The URL at the bottom of the screen includes the IP address of the camera

+

--port port (default = 8080)
+ The CCAPI port the camera is configured to. The default value is 8080, which is the default Canon uses.

+

--opfile <filename>
+ Path/filename of the automation script. Ops can alternatively be specified directly on the command line via --op.

+

--op <op | op | ...>
+ As an alternative to using an automation script via --optfile you can enter operations directly on the command line. This is useful for simple operations. You can specify multiple operations by separating each with a | character. It's recommended to enclose the entire list in double quotes, for example: --op "PrintCameraInfo | Delay time=5"

+

--outputdir <directory> (default = current directory)
+The directory to store downloaded images and movies. By default the current directory will be used. The directory specified with this option can be overridden on a per-automation op basis via outputdir=<path> parameter to the op.

+

--ifexists [uniquename | skip | overwrite | prompt | exit] (default = uniquename)
+ Specifies what operation to take if a local file exists in the output directory matching a file to be downloaded. The default 'uniquename' will cause a unique filename to be generated by adding -new-x suffix (for example, DSC_1575.cr3 becomes DSC_1575-new-1.cr3, DSC_1575-new-2.cr3, etc...). 'skip' will cause the file to be skipped and not downloaded. 'overwrite' will overwrite the local file with the downloaded file. 'prompt' will present a choice of operations to take on the console (uniquename/skip/overwrite/prompt/exit). 'exit' will cause the application to terminate whenever an existing file with the same name as a download candidate is found.

+

--exitoncmderr [yes | no] (default = yes)
+ Specifies whether the automation script is stopped whenever the Camera returns an error for an attempted operation. There are two broad types of errors in communication with the camera - transport and command. A transport error means the HTTP request failed to be delivered to the camera. The most common type of transport error is a Timeout, which can occur if the camera is turned off or has its CCAPI feature disabled. Transport errors are retried a user-configured number of times but if those retries are exhausted the script unconditionally terminates. In contrast, a command error occurs when the request was successfully delivered to the camera but the camera reported the request could not be completed. An example is attempting a StartMovieRecord when the camera is in stills mode or attempting to set the shutter speed while the camera is in Aperture-Priority mode. This option specifies whether the script is terminated if all the command error retries have been exhausted. This parameter can be override on a per-op basis in the automation script.

+

--timeout <time value> (default is 5)
+Specifies the timeout for all CCAPI requests to the camera except for downloads, which is specified via --downloadtimeout. <time value> can be either a value in seconds or a time code in hh:mm:ss or mm:ss format. For example, 5:30 to set a timeout of 5 minutes and 30 seconds. This parameter can be override on a per-op basis in the automation script.

+

--downloadtimeout <time value> (default is 0, for no timeout)
+Specifies the timeout for CCAPI requests to the camera corresponding to the download of images or movie files. <time value> can be either a value in seconds or a time code in hh:mm:ss or mm:ss format. This parameter can be override on a per-op basis in the automation script.

+

--transportretries <retry count> (default = 2)
+ Specifies the number of retries performed after a CCAPI transport error, such as a timeout. If all retries are exhausted the automation script will be terminated. This parameter can be override on a per-op basis in the automation script.

+

--cmdretries <retry count> (default = 2)
+ Specifies the number of retries performed after a CCAPI command error, which is an error that occurs when the camera successfully received a request but indicated it was invalid or could not be completed. If all retries are exhausted the automation script will be terminated based on the --exitoncmderr setting. This parameter can be override on a per-op basis in the automation script.

+

--retrydelay <time value> (default = 0, no delay)
+Specifies the amount of time to delay before retrying a transport or command error. <time value> can be either a value in seconds or a time code in hh:mm:ss or mm:ss format. This parameter can be override on a per-op basis in the automation script.

+

--maxbusyretrytime <time value> (default = 10 seconds)
+Specifies the amount of time a request is retried that fails with a "busy or "preparing" command error status from the camera, both of which indicate a temporary unavailability condition. This is a special case of command error handling that runs in parallel to the regular command error handling managed by --cmdretries. The purpose is to allow the recovery of temporary busy conditions without having to increase the normal command error retry counts. This parameter can be override on a per-op basis in the automation script.

+

--logginglevel [normal | verbose | debug] (default = normal)
+ The verbosity level of logging for an Canomate session. Canomate outputs its messages both to the console (stdout/stderr) and to a pair of logging files, named canomate-log-last.txt (log messages from most recent session) and canomate-log-lifetime.txt (log messages from all sessions). 'normal' indicates that only important/useful informational messages will be logged. 'verbose' includes some additional messages, useful for instance when you'd like more information about why a particular file was not downloaded. 'debug' will include all developer-level messages and debug information.

+

Features Planned for Next Release

+

Too many to list :)

+

GPL v3 License

+
    Canomate - Automation for Canon Cameras 
+    Copyright (C) 2020, Horshack
+
+    This program is free software: you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation, either version 3 of the License, or
+    (at your option) any later version.
+
+    This program is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+

+ Credits

+ + +