.. _cam-tool-label: CamTool Sample ============== *CamTool* is a command line tool that demonstrates the features and API's of CameraSDK. The source code is demonstrating **best practice** usage of CameraSDK, encapsulated in a command line parser. Before you dive into this sample project, you should have read :ref:`getting-started-cpp-label` in the "Getting Started" section. This sample is based on the CMake project file, introduced in the "Getting Started" guide. Download ~~~~~~~~ .. content-if:: :format: html A ZIP file with the project can be found :download:`here ` .. content-if:: :format: pdf Go to our documentation website `developer.phaseone.com `_ to download the project source. .. tip:: See the ``README.md`` file in the project, on how to build. File overview ~~~~~~~~~~~~~ * ``Shell.h/cpp``: A crude interactive shell for entering commands * ``*Commands.h/cpp``: The implementation of camera related commands that are triggered from the shell. SDK is called from here * ``main.cpp``: The entry point that initiates the *Shell* and setup the available *Commands* Available commands ~~~~~~~~~~~~~~~~~~ This is a print of the ``help`` command's output:: Available commands: capture Trigger a capture on the open camera close Close the currently opened camera exit Quit the application help Print this help text hostcapacity Tells the camera how much capacity this host has available for images list Prints a list of visible camera (USB only) liveview [on|off] Shows config and Enable/Disable receiving live view images notif Enable/Disable notifications open [IP=X.X.X.X|serialno=] [password=] [retries=] [timeout=] Open an IP or USB camera opened List all opened cameras pending List pending images count, for all cameras property Control of properties quit Quit the application recv Enable / Disable receiving captured images. save Save received images to CWD .. tip:: **On Linux** if you can not see any connected USB cameras, please refer to our :ref:`linux-trouble-label` guide.