Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(287)

Side by Side Diff: remoting/client/jni/jni_frame_consumer.h

Issue 19967007: Various improvements to the Chromoting Android app (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Add comments to clarify ChromotingJniRuntime pointer lifetimes Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
OLDNEW
« no previous file with comments | « remoting/client/jni/chromoting_jni_runtime.cc ('k') | remoting/client/jni/jni_frame_consumer.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698