/* * Copyright (C) 2022 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 CPP_EVS_SAMPLEDRIVER_AIDL_INCLUDE_VIDEOCAPTURE_H #define CPP_EVS_SAMPLEDRIVER_AIDL_INCLUDE_VIDEOCAPTURE_H #include #include #include #include #include typedef v4l2_buffer imageBuffer; class VideoCapture final { public: bool open(const char* deviceName, const int32_t width = 0, const int32_t height = 0); void close(); bool startStream(std::function callback = nullptr); void stopStream(); // Valid only after open() __u32 getWidth() { return mWidth; }; __u32 getHeight() { return mHeight; }; __u32 getStride() { return mStride; }; __u32 getV4LFormat() { return mFormat; }; // NULL until stream is started void* getLatestData() { if (mFrames.empty()) { // No frame is available return nullptr; } // Return a pointer to the buffer captured most recently const int latestBufferId = *mFrames.end(); return mPixelBuffers[latestBufferId]; } bool isFrameReady() { return !mFrames.empty(); } void markFrameConsumed(int id) { returnFrame(id); } bool isOpen() { return mDeviceFd >= 0; } int setParameter(struct v4l2_control& control); int getParameter(struct v4l2_control& control); std::set enumerateCameraControls(); private: void collectFrames(); bool returnFrame(int id); int mDeviceFd = -1; int mNumBuffers = 0; std::unique_ptr mBufferInfos = nullptr; std::unique_ptr mPixelBuffers = nullptr; __u32 mFormat = 0; __u32 mWidth = 0; __u32 mHeight = 0; __u32 mStride = 0; std::function mCallback; std::thread mCaptureThread; // The thread we'll use to dispatch frames std::atomic mRunMode; // Used to signal the frame loop (see RunModes below) std::set mFrames; // Set of available frame buffers // Careful changing these -- we're using bit-wise ops to manipulate these enum RunModes { STOPPED = 0, RUN = 1, STOPPING = 2, }; }; #endif // CPP_EVS_SAMPLEDRIVER_AIDL_INCLUDE_VIDEOCAPTURE_H