• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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