OLD | NEW |
1 /* | 1 /* |
2 * libjingle | 2 * libjingle |
3 * Copyright 2015 Google Inc. | 3 * Copyright 2015 Google Inc. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions are met: | 6 * modification, are permitted provided that the following conditions are met: |
7 * | 7 * |
8 * 1. Redistributions of source code must retain the above copyright notice, | 8 * 1. Redistributions of source code must retain the above copyright notice, |
9 * this list of conditions and the following disclaimer. | 9 * this list of conditions and the following disclaimer. |
10 * 2. Redistributions in binary form must reproduce the above copyright notice, | 10 * 2. Redistributions in binary form must reproduce the above copyright notice, |
11 * this list of conditions and the following disclaimer in the documentation | 11 * this list of conditions and the following disclaimer in the documentation |
12 * and/or other materials provided with the distribution. | 12 * and/or other materials provided with the distribution. |
13 * 3. The name of the author may not be used to endorse or promote products | 13 * 3. The name of the author may not be used to endorse or promote products |
14 * derived from this software without specific prior written permission. | 14 * derived from this software without specific prior written permission. |
15 * | 15 * |
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED | 16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED |
17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO | 18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO |
19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; | 21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; |
22 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, | 22 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, |
23 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR | 23 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR |
24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF | 24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF |
25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
26 * | |
27 */ | 26 */ |
28 | 27 |
29 #ifndef TALK_APP_WEBRTC_JAVA_JNI_ANDROIDMEDIAENCODER_JNI_H_ | 28 #ifndef TALK_APP_WEBRTC_OBJC_H264_ENCODER_FACTORY_H_ |
30 #define TALK_APP_WEBRTC_JAVA_JNI_ANDROIDMEDIAENCODER_JNI_H_ | 29 #define TALK_APP_WEBRTC_OBJC_H264_ENCODER_FACTORY_H_ |
31 | 30 |
32 #include <vector> | 31 #include <vector> |
33 | 32 |
34 #include "talk/app/webrtc/java/jni/jni_helpers.h" | |
35 #include "talk/media/webrtc/webrtcvideoencoderfactory.h" | 33 #include "talk/media/webrtc/webrtcvideoencoderfactory.h" |
| 34 #include "webrtc/base/constructormagic.h" |
36 | 35 |
37 namespace webrtc_jni { | 36 namespace webrtc { |
38 | 37 |
39 // Implementation of Android MediaCodec based encoder factory. | 38 // This classes is a quick measure for plugging in H264 support and will |
40 class MediaCodecVideoEncoderFactory | 39 // eventually go away once we build H264 support into the video engine. |
41 : public cricket::WebRtcVideoEncoderFactory { | 40 class H264EncoderFactory : public cricket::WebRtcVideoEncoderFactory { |
42 public: | 41 public: |
43 MediaCodecVideoEncoderFactory(); | 42 H264EncoderFactory(); |
44 virtual ~MediaCodecVideoEncoderFactory(); | 43 ~H264EncoderFactory() override {} |
45 | 44 webrtc::VideoEncoder* CreateVideoEncoder( |
46 // WebRtcVideoEncoderFactory implementation. | 45 webrtc::VideoCodecType type) override; |
47 webrtc::VideoEncoder* CreateVideoEncoder(webrtc::VideoCodecType type) | |
48 override; | |
49 const std::vector<VideoCodec>& codecs() const override; | 46 const std::vector<VideoCodec>& codecs() const override; |
50 void DestroyVideoEncoder(webrtc::VideoEncoder* encoder) override; | 47 void DestroyVideoEncoder(webrtc::VideoEncoder* encoder) override; |
51 | 48 |
52 private: | 49 private: |
53 // Empty if platform support is lacking, const after ctor returns. | 50 // On construction we check that we are able to create a H264 encoder. If we |
54 std::vector<VideoCodec> supported_codecs_; | 51 // can then this vector is populated with just the H264 codec, otherwise it |
| 52 // will be empty. This vector is returned in the codecs() method. |
| 53 std::vector<VideoCodec> h264_codec_or_empty_vector_; |
| 54 |
| 55 DISALLOW_COPY_AND_ASSIGN(H264EncoderFactory); |
55 }; | 56 }; |
56 | 57 |
57 } // namespace webrtc_jni | 58 } // namespace webrtc |
58 | 59 |
59 #endif // TALK_APP_WEBRTC_JAVA_JNI_ANDROIDMEDIAENCODER_JNI_H_ | 60 #endif // TALK_APP_WEBRTC_OBJC_H264_ENCODER_FACTORY_H_ |
OLD | NEW |