1 /* 2 * Copyright (C) 2013 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #ifndef ANDROID_SERVERS_CAMERA3_OUTPUT_STREAM_INTERFACE_H 18 #define ANDROID_SERVERS_CAMERA3_OUTPUT_STREAM_INTERFACE_H 19 20 #include "Camera3StreamInterface.h" 21 #include <utils/KeyedVector.h> 22 23 namespace android { 24 25 namespace camera3 { 26 27 /** 28 * An interface for managing a single stream of output data from the camera 29 * device. 30 */ 31 class Camera3OutputStreamInterface : public virtual Camera3StreamInterface { 32 public: 33 /** 34 * Set the transform on the output stream; one of the 35 * HAL_TRANSFORM_* / NATIVE_WINDOW_TRANSFORM_* constants. 36 */ 37 virtual status_t setTransform(int transform, bool mayChangeMirror) = 0; 38 39 /** 40 * Return if this output stream is for video encoding. 41 */ 42 virtual bool isVideoStream() const = 0; 43 44 /** 45 * Return if the consumer configuration of this stream is deferred. 46 */ 47 virtual bool isConsumerConfigurationDeferred(size_t surface_id = 0) const = 0; 48 49 /** 50 * Set the consumer surfaces to the output stream. 51 */ 52 virtual status_t setConsumers(const std::vector<sp<Surface>>& consumers) = 0; 53 54 /** 55 * Detach an unused buffer from the stream. 56 * 57 * buffer must be non-null; fenceFd may null, and if it is non-null, but 58 * there is no valid fence associated with the detached buffer, it will be 59 * set to -1. 60 * 61 */ 62 virtual status_t detachBuffer(sp<GraphicBuffer>* buffer, int* fenceFd) = 0; 63 64 /** 65 * Query the surface id. 66 */ 67 virtual ssize_t getSurfaceId(const sp<Surface> &surface) = 0; 68 69 /** 70 * Query the unique surface IDs of current surfaceIds. 71 * When passing unique surface IDs in returnBuffer(), if the 72 * surfaceId has been removed from the stream, the output corresponding to 73 * the unique surface ID will be ignored and not delivered to client. 74 * 75 * Return INVALID_OPERATION if and only if the stream does not support 76 * surface sharing. 77 */ 78 virtual status_t getUniqueSurfaceIds(const std::vector<size_t>& surfaceIds, 79 /*out*/std::vector<size_t>* outUniqueIds) = 0; 80 81 /** 82 * Update the stream output surfaces. 83 */ 84 virtual status_t updateStream(const std::vector<sp<Surface>> &outputSurfaces, 85 const std::vector<OutputStreamInfo> &outputInfo, 86 const std::vector<size_t> &removedSurfaceIds, 87 KeyedVector<sp<Surface>, size_t> *outputMap/*out*/) = 0; 88 89 /** 90 * Drop buffers if dropping is true. If dropping is false, do not drop buffers. 91 */ 92 virtual status_t dropBuffers(bool /*dropping*/) = 0; 93 94 /** 95 * Query the physical camera id for the output stream. 96 */ 97 virtual const String8& getPhysicalCameraId() const = 0; 98 99 /** 100 * Set the batch size for buffer operations. The output stream will request 101 * buffers from buffer queue on a batch basis. Currently only video streams 102 * are allowed to set the batch size. Also if the stream is managed by 103 * buffer manager (Surface group in Java API) then batching is also not 104 * supported. Changing batch size on the fly while there is already batched 105 * buffers in the stream is also not supported. 106 * If the batch size is larger than the max dequeue count set 107 * by the camera HAL, the batch size will be set to the max dequeue count 108 * instead. 109 */ 110 virtual status_t setBatchSize(size_t batchSize = 1) = 0; 111 112 /** 113 * Notify the output stream that the minimum frame duration has changed, or 114 * frame rate has switched between variable and fixed. 115 * 116 * The minimum frame duration is calculated based on the upper bound of 117 * AE_TARGET_FPS_RANGE in the capture request. 118 */ 119 virtual void onMinDurationChanged(nsecs_t duration, bool fixedFps) = 0; 120 121 /** 122 * Modify the stream use case for this output. 123 */ 124 virtual void setStreamUseCase(int64_t streamUseCase) = 0; 125 }; 126 127 // Helper class to organize a synchronized mapping of stream IDs to stream instances 128 class StreamSet { 129 public: 130 status_t add(int streamId, sp<camera3::Camera3OutputStreamInterface>); 131 ssize_t remove(int streamId); 132 sp<camera3::Camera3OutputStreamInterface> get(int streamId); 133 // get by (underlying) vector index 134 sp<camera3::Camera3OutputStreamInterface> operator[] (size_t index); 135 size_t size() const; 136 std::vector<int> getStreamIds(); 137 void clear(); 138 StreamSet()139 StreamSet() {}; 140 StreamSet(const StreamSet& other); 141 142 private: 143 mutable std::mutex mLock; 144 KeyedVector<int, sp<camera3::Camera3OutputStreamInterface>> mData; 145 }; 146 147 } // namespace camera3 148 149 } // namespace android 150 151 #endif 152