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

Side by Side Diff: chromecast/public/osd_plane.h

Issue 2184933003: [Chromecast] Include output screen resolution in OSD rect info (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 4 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
« no previous file with comments | « chromecast/graphics/osd_plane_default.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2015 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2015 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 CHROMECAST_PUBLIC_OSD_PLANE_H_ 5 #ifndef CHROMECAST_PUBLIC_OSD_PLANE_H_
6 #define CHROMECAST_PUBLIC_OSD_PLANE_H_ 6 #define CHROMECAST_PUBLIC_OSD_PLANE_H_
7 7
8 namespace chromecast { 8 namespace chromecast {
9 9
10 class OsdSurface; 10 class OsdSurface;
11 struct Rect; 11 struct Rect;
12 struct Size; 12 struct Size;
13 13
14 // Abstract graphics plane for OSD, to be implemented in platform-specific way. 14 // Abstract graphics plane for OSD, to be implemented in platform-specific way.
15 // Platform must composite this plane on top of main (GL-based) graphics plane. 15 // Platform must composite this plane on top of main (GL-based) graphics plane.
16 class OsdPlane { 16 class OsdPlane {
17 public: 17 public:
18 virtual ~OsdPlane() {} 18 virtual ~OsdPlane() {}
19 19
20 // Creates a surface for offscreen drawing. 20 // Creates a surface for offscreen drawing.
21 virtual OsdSurface* CreateSurface(const Size& size) = 0; 21 virtual OsdSurface* CreateSurface(const Size& size) = 0;
22 22
23 // Sets a clip rectangle, client should call before drawing to back buffer 23 // Sets a clip rectangle, client should call before drawing to back buffer
24 // to specify the area they intend to draw on. Platforms may reduce memory 24 // to specify the area they intend to draw on. Platforms may reduce memory
25 // usage by only allocating back buffer to cover this area. Areas outside 25 // usage by only allocating back buffer to cover this area. Areas outside
26 // clip rectangle must display as fully transparent. In particular, setting 26 // clip rectangle must display as fully transparent. In particular, setting
27 // an empty clip rectangle and calling Flip should clear the plane. 27 // an empty clip rectangle and calling Flip should clear the plane.
28 virtual void SetClipRectangle(const Rect& rect) = 0; 28 // |osd_res| gives the resolution of the full OSD plane, i.e. |rect| is
29 // a subrectangle of this area. |output_scale| specifies the current scaling
30 // from |osd_res| to output screen resolution.
31 virtual void SetClipRectangle(const Rect& rect,
32 const Size& osd_res,
33 float output_scale) = 0;
29 34
30 // Gets the current back buffer surface. Valid until next call to Flip or 35 // Gets the current back buffer surface. Valid until next call to Flip or
31 // SetClipRectangle. 36 // SetClipRectangle.
32 virtual OsdSurface* GetBackBuffer() = 0; 37 virtual OsdSurface* GetBackBuffer() = 0;
33 38
34 // Presents current back buffer to screen. 39 // Presents current back buffer to screen.
35 virtual void Flip() = 0; 40 virtual void Flip() = 0;
36 }; 41 };
37 42
38 } // namespace chromecast 43 } // namespace chromecast
39 44
40 #endif // CHROMECAST_PUBLIC_OSD_PLANE_H 45 #endif // CHROMECAST_PUBLIC_OSD_PLANE_H
OLDNEW
« no previous file with comments | « chromecast/graphics/osd_plane_default.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698