Manual camera controls sample
Provides an end-to-end sample to show how to write a camera app using the Windows.Media.Capture API in conjunction with orientation sensors to cover some of the functions that advanced camera apps will require. This sample is based on the Basic camera app sample.
Note: This sample is part of a large collection of UWP feature samples. If you are unfamiliar with Git and GitHub, you can download the entire collection as a ZIP file, but be sure to unzip everything to access shared dependencies. For more info on working with the ZIP file, the samples collection, and GitHub, see Get the UWP samples from GitHub. For more samples, see the Samples portal on the Windows Dev Center.
Specifically, this sample will cover how to:
- Manage the MediaCapture object throughout the lifecycle of the app and through navigation events.
- Acquire a camera located on a specific side of the device. In this case, the sample attempts to get the rear camera.
- Start and stop the preview to a UI element, including mirroring for front-facing cameras.
- Take a picture to a file (taking into account the orientation of the device), and disable the video capture button if the app is running on a device that doesn't support concurrent capturing of photos and video.
- Record a video to a file, and disable the photo capture button if the app is running on a device that doesn't support concurrent capturing of photos and video.
- Discover the capabilities of a device regarding the following advanced camera controls:
- Flash and video light
- Zoom, including Smooth Zoom if supported by the device
- Focus: manual, continuous, and tap-to-focus
- ISO Speed
- Shutter Speed (Exposure)
- Exposure Value
- White Balance
- Configure manual camera controls individually, allowing the user to see the effect the controls would have on the preview (where applicable).
- Handle rotation events for both, the device moving in space and the page orientation changing on the screen. Also apply any necessary corrections to the preview stream rotation and user interactions with the CaptureElement.
- Handle MediaCapture Failed event to clean up the MediaCapture instance when an error occurs.
This sample also implements a custom UI to better simulate the experience that a camera application would provide, so any messages intended for the developer are printed to the debug console.
To keep code complexity low, but offer easier navigation between the different controls, the sample uses partial classes to separate the code that handles specific controls into their own files. Each file is named according to the control they cover, in the format of: MainPage.Control.xaml.cs.
Client: Windows 10
Server: Windows Server 2016 Technical Preview
Phone: Windows 10
Build the sample
- If you download the samples ZIP, be sure to unzip the entire archive, not just the folder with the sample you want to build.
- Start Microsoft Visual Studio 2017 and select File > Open > Project/Solution.
- Press Ctrl+Shift+B, or select Build > Build Solution.
Run the sample
The next steps depend on whether you just want to deploy the sample or you want to both deploy and run it.
Deploying the sample:
- Select Build > Deploy Solution.
Deploying and running the sample:
- To debug the sample and then run it, press F5 or select Debug > Start Debugging. To run the sample without debugging, press Ctrl+F5 or select Debug > Start Without Debugging.