OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef REMOTING_CLIENT_JNI_JNI_FRAME_CONSUMER_H_ | 5 #ifndef REMOTING_CLIENT_JNI_JNI_FRAME_CONSUMER_H_ |
6 #define REMOTING_CLIENT_JNI_JNI_FRAME_CONSUMER_H_ | 6 #define REMOTING_CLIENT_JNI_JNI_FRAME_CONSUMER_H_ |
7 | 7 |
8 #include "remoting/client/frame_consumer.h" | 8 #include "remoting/client/frame_consumer.h" |
9 | 9 |
10 #include "base/compiler_specific.h" | 10 #include "base/compiler_specific.h" |
11 | 11 |
12 namespace webrtc { | 12 namespace webrtc { |
13 class DesktopFrame; | 13 class DesktopFrame; |
14 } // namespace webrtc | 14 } // namespace webrtc |
15 | 15 |
16 namespace remoting { | 16 namespace remoting { |
17 class ChromotingJni; | 17 class ChromotingJniRuntime; |
18 class FrameProducer; | 18 class FrameProducer; |
19 | 19 |
20 // FrameConsumer implementation that draws onto a JNI direct byte buffer. | 20 // FrameConsumer implementation that draws onto a JNI direct byte buffer. |
21 class JniFrameConsumer : public FrameConsumer { | 21 class JniFrameConsumer : public FrameConsumer { |
22 public: | 22 public: |
23 JniFrameConsumer(); | 23 // The instance does not take ownership of |jni_runtime|. |
| 24 explicit JniFrameConsumer(ChromotingJniRuntime* jni_runtime); |
| 25 |
24 virtual ~JniFrameConsumer(); | 26 virtual ~JniFrameConsumer(); |
25 | 27 |
26 // This must be called once before the producer's source size is set. | 28 // This must be called once before the producer's source size is set. |
27 void set_frame_producer(FrameProducer* producer); | 29 void set_frame_producer(FrameProducer* producer); |
28 | 30 |
29 // FrameConsumer implementation. | 31 // FrameConsumer implementation. |
30 virtual void ApplyBuffer(const SkISize& view_size, | 32 virtual void ApplyBuffer(const SkISize& view_size, |
31 const SkIRect& clip_area, | 33 const SkIRect& clip_area, |
32 webrtc::DesktopFrame* buffer, | 34 webrtc::DesktopFrame* buffer, |
33 const SkRegion& region) OVERRIDE; | 35 const SkRegion& region) OVERRIDE; |
34 virtual void ReturnBuffer(webrtc::DesktopFrame* buffer) OVERRIDE; | 36 virtual void ReturnBuffer(webrtc::DesktopFrame* buffer) OVERRIDE; |
35 virtual void SetSourceSize(const SkISize& source_size, | 37 virtual void SetSourceSize(const SkISize& source_size, |
36 const SkIPoint& dpi) OVERRIDE; | 38 const SkIPoint& dpi) OVERRIDE; |
37 | 39 |
38 private: | 40 private: |
39 // Variables are to be used from the display thread. | 41 // Variables are to be used from the display thread. |
40 | 42 |
41 // Whether to allocate/provide the producer with a buffer when able. This | 43 // Used to obtain task runner references and make calls to Java methods. |
42 // goes to false during destruction so that we don't leak memory. | 44 ChromotingJniRuntime* jni_runtime_; |
43 bool provide_buffer_; | 45 |
| 46 // Whether we're currently in the constructor, and should deallocate the |
| 47 // buffer instead of passing it back to the producer. |
| 48 bool in_dtor_; |
44 | 49 |
45 FrameProducer* frame_producer_; | 50 FrameProducer* frame_producer_; |
46 SkISize view_size_; | 51 SkISize view_size_; |
47 SkIRect clip_area_; | 52 SkIRect clip_area_; |
48 | 53 |
49 // If |provide_buffer_|, allocates a new buffer of |view_size_|, informs | 54 // If |provide_buffer_|, allocates a new buffer of |view_size_|, informs |
50 // Java about it, and tells the producer to draw onto it. Otherwise, no-op. | 55 // Java about it, and tells the producer to draw onto it. Otherwise, no-op. |
51 void AllocateBuffer(); | 56 void AllocateBuffer(); |
52 | 57 |
53 DISALLOW_COPY_AND_ASSIGN(JniFrameConsumer); | 58 DISALLOW_COPY_AND_ASSIGN(JniFrameConsumer); |
54 }; | 59 }; |
55 | 60 |
56 } // namespace remoting | 61 } // namespace remoting |
57 | 62 |
58 #endif | 63 #endif |
OLD | NEW |