Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add 'kvs_gstreamer_webcam.cpp' source code for webcam streaming #1171

Open
wants to merge 1 commit into
base: develop-pre-3.4.1
Choose a base branch
from

Conversation

ivanstanislavov
Copy link

Issue #, if available:
Not an issue but this is a newer version of a previous pull request (#1168) that I deleted (made a new fork because I had forked only the master branch by accident) so I can create a branch off the "develop" branch and merge into it.
Description of changes:
Added "kvs_gstreamer_webcam.cpp" source code file inside the "samples" directory. It provides a straightforward way to create a video stream from your built-in webcam to kinesis video streams that is tagged with event metadata for automatic image generation and suitable for use in an image generation configuration.
The code builds the following pipeline: "gst-launch-1.0 autovideosrc ! videoconvert ! video/x-raw, format=I420,width=640,height=480,framerate=30/1 ! vtenc_h264_hw allow-frame-reordering=FALSE realtime=TRUE max-keyframe-interval=45 bitrate=500 ! h264parse ! video/x-h264,stream format=avc,alignment=au,profile=baseline ! appsink".
The stream is also tagged with the appropriate metadata (as already mentioned).
I also modified the "CMakeLists.txt" to compile the file into executables in the "build" folder with the rest of the sample ".cpp" files. It works great and is a straight-forward out-of-the-box solution to spin up a stream from your webcam to KVS and have it tagged with the appropriate metadata as well.

Recently I was creating a prototype for recognizing periodical screenshots from video stream data in KVS with Amazon Rekognition. I really needed to test the accuracy of the model and the only way I could test it into the dev stage was to use the web camera of my Mac. However, starting a stream through the command did not allow me to tag the frame with metadata for image generation. I could not find a trivial solution so I spent a few days on creating the "kvs_gstreamer_webcam.cpp" source code to solve my needs. While developing it I made sure to follow the structure of the rest of the "sample" files. It works great and is a straight-forward solution for anyone struggling with the same problems as I did for a long time.

By submitting this pull request, I confirm that you can use, modify, copy, and redistribute this contribution, under the terms of your choice.

@sirknightj
Copy link
Contributor

Hi, thanks for your contribution.

I was trying to build it to confirm it works, but encountered this:

[ 95%] Building CXX object CMakeFiles/kvs_gstreamer_webcam.dir/samples/kvs_gstreamer_webcam.cpp.o
/Users/me/Downloads/amazon-kinesis-video-streams-producer-sdk-cpp/samples/kvs_gstreamer_webcam.cpp:298:41: error: no member named 'putEventMetadata' in 'com::amazonaws::kinesis::video::KinesisVideoStream'
            data->kinesis_video_stream->putEventMetadata(STREAM_EVENT_TYPE_NOTIFICATION | STREAM_EVENT_TYPE_IMAGE_GENERATION, NULL);
            ~~~~~~~~~~~~~~~~~~~~~~~~~~~~^
1 error generated.
make[2]: *** [CMakeFiles/kvs_gstreamer_webcam.dir/samples/kvs_gstreamer_webcam.cpp.o] Error 1
make[1]: *** [CMakeFiles/kvs_gstreamer_webcam.dir/all] Error 2
make: *** [all] Error 2

@sirknightj sirknightj added the Samples Related to the sample applications label Jun 8, 2024
@stefankiesz
Copy link
Contributor

Hi @ivanstanislavov, thank you for your contribution.

I'm reviewing it now and thinking it might be better if I modify one of our existing samples to allow the user to more easily configure the source. The kvs_gstreamer_sample already adds image metadata tags, and it does support webcam sources, but it is not super clear how users can specify to use such sources. The GStreamer source element to use for using the webcam also differs based on platform, so we should make this user-configurable.

I'd like to confirm, were there any issues other than selecting the webcam source that you ran into, such as how image tagging is done in the available sample?

Also, I'm curious how has the use of this SDK been going for your use case? Any other issues/frustrations along the way we can address?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Samples Related to the sample applications
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants