/* * Copyright (C) 2012 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ANDROID_SERVERS_CAMERA_CAMERA2_STREAMINGPROCESSOR_H #define ANDROID_SERVERS_CAMERA_CAMERA2_STREAMINGPROCESSOR_H #include <utils/Mutex.h> #include <utils/String16.h> #include <gui/BufferItemConsumer.h> #include "camera/CameraMetadata.h" namespace android { class Camera2Client; class CameraDeviceBase; class IMemory; namespace camera2 { struct Parameters; class Camera2Heap; /** * Management and processing for preview and recording streams */ class StreamingProcessor : public virtual VirtualLightRefBase { public: explicit StreamingProcessor(sp<Camera2Client> client); ~StreamingProcessor(); status_t setPreviewWindow(const sp<Surface>& window); status_t setRecordingWindow(const sp<Surface>& window); bool haveValidPreviewWindow() const; bool haveValidRecordingWindow() const; status_t updatePreviewRequest(const Parameters ¶ms); status_t updatePreviewStream(const Parameters ¶ms); status_t deletePreviewStream(); int getPreviewStreamId() const; status_t updateRecordingRequest(const Parameters ¶ms); // If needsUpdate is set to true, a updateRecordingStream call with params will recreate // recording stream status_t recordingStreamNeedsUpdate(const Parameters ¶ms, bool *needsUpdate); status_t updateRecordingStream(const Parameters ¶ms); status_t deleteRecordingStream(); int getRecordingStreamId() const; enum StreamType { NONE, PREVIEW, RECORD }; status_t startStream(StreamType type, const Vector<int32_t> &outputStreams); // Toggle between paused and unpaused. Stream must be started first. status_t togglePauseStream(bool pause); status_t stopStream(); // Returns the request ID for the currently streaming request // Returns 0 if there is no active request. status_t getActiveRequestId() const; status_t incrementStreamingIds(); status_t dump(int fd, const Vector<String16>& args); private: mutable Mutex mMutex; enum { NO_STREAM = -1 }; wp<Camera2Client> mClient; wp<CameraDeviceBase> mDevice; int mId; StreamType mActiveRequest; bool mPaused; Vector<int32_t> mActiveStreamIds; // Preview-related members int32_t mPreviewRequestId; int mPreviewStreamId; CameraMetadata mPreviewRequest; sp<Surface> mPreviewWindow; int32_t mRecordingRequestId; int mRecordingStreamId; sp<Surface> mRecordingWindow; CameraMetadata mRecordingRequest; }; }; // namespace camera2 }; // namespace android #endif