/* Copyright (c) 2012 The Chromium Authors. All rights reserved. * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ /** * This file defines the PPB_View struct representing the state * of the view of an instance. */ [generate_thunk] label Chrome { M18 = 1.0, M28 = 1.1, [channel=dev] M37 = 1.2 }; /** * PPB_View represents the state of the view of an instance. * You will receive new view information using * PPP_Instance.DidChangeView. */ [macro="PPB_VIEW_INTERFACE"] interface PPB_View { /** * IsView() determines if the given resource is a valid * PPB_View resource. Note that PPB_ViewChanged * resources derive from PPB_View and will return true here * as well. * * @param resource A PP_Resource corresponding to a * PPB_View resource. * * @return PP_TRUE if the given resource supports * PPB_View or PP_FALSE if it is an invalid * resource or is a resource of another type. */ PP_Bool IsView([in] PP_Resource resource); /** * GetRect() retrieves the rectangle of the module instance associated * with a view changed notification relative to the upper-left of the browser * viewport. This position changes when the page is scrolled. * * The returned rectangle may not be inside the visible portion of the * viewport if the module instance is scrolled off the page. Therefore, the * position may be negative or larger than the size of the page. The size will * always reflect the size of the module were it to be scrolled entirely into * view. * * In general, most modules will not need to worry about the position of the * module instance in the viewport, and only need to use the size. * * @param resource A PP_Resource corresponding to a * PPB_View resource. * * @param rect A PP_Rect receiving the rectangle on success. * * @return Returns PP_TRUE if the resource was valid and the * viewport rectangle was filled in, PP_FALSE if not. */ PP_Bool GetRect([in] PP_Resource resource, [out] PP_Rect rect); /** * IsFullscreen() returns whether the instance is currently * displaying in fullscreen mode. * * @param resource A PP_Resource corresponding to a * PPB_View resource. * * @return PP_TRUE if the instance is in full screen mode, * or PP_FALSE if it's not or the resource is invalid. */ PP_Bool IsFullscreen([in] PP_Resource resource); /** * IsVisible() determines whether the module instance might be visible to * the user. For example, the Chrome window could be minimized or another * window could be over it. In both of these cases, the module instance * would not be visible to the user, but IsVisible() will return true. * * Use the result to speed up or stop updates for invisible module * instances. * * This function performs the duties of GetRect() (determining whether the * module instance is scrolled into view and the clip rectangle is nonempty) * and IsPageVisible() (whether the page is visible to the user). * * @param resource A PP_Resource corresponding to a * PPB_View resource. * * @return PP_TRUE if the instance might be visible to the * user, PP_FALSE if it is definitely not visible. */ PP_Bool IsVisible([in] PP_Resource resource); /** * IsPageVisible() determines if the page that contains the module instance * is visible. The most common cause of invisible pages is that * the page is in a background tab in the browser. * * Most applications should use IsVisible() instead of this function since * the module instance could be scrolled off of a visible page, and this * function will still return true. However, depending on how your module * interacts with the page, there may be certain updates that you may want to * perform when the page is visible even if your specific module instance is * not visible. * * @param resource A PP_Resource corresponding to a * PPB_View resource. * * @return PP_TRUE if the instance is plausibly visible to the * user, PP_FALSE if it is definitely not visible. */ PP_Bool IsPageVisible([in] PP_Resource resource); /** * GetClipRect() returns the clip rectangle relative to the upper-left corner * of the module instance. This rectangle indicates the portions of the module * instance that are scrolled into view. * * If the module instance is scrolled off the view, the return value will be * (0, 0, 0, 0). This clip rectangle does not take into account page * visibility. Therefore, if the module instance is scrolled into view, but * the page itself is on a tab that is not visible, the return rectangle will * contain the visible rectangle as though the page were visible. Refer to * IsPageVisible() and IsVisible() if you want to account for page * visibility. * * Most applications will not need to worry about the clip rectangle. The * recommended behavior is to do full updates if the module instance is * visible, as determined by IsVisible(), and do no updates if it is not * visible. * * However, if the cost for computing pixels is very high for your * application, or the pages you're targeting frequently have very large * module instances with small visible portions, you may wish to optimize * further. In this case, the clip rectangle will tell you which parts of * the module to update. * * Note that painting of the page and sending of view changed updates * happens asynchronously. This means when the user scrolls, for example, * it is likely that the previous backing store of the module instance will * be used for the first paint, and will be updated later when your * application generates new content with the new clip. This may cause * flickering at the boundaries when scrolling. If you do choose to do * partial updates, you may want to think about what color the invisible * portions of your backing store contain (be it transparent or some * background color) or to paint a certain region outside the clip to reduce * the visual distraction when this happens. * * @param resource A PP_Resource corresponding to a * PPB_View resource. * * @param clip Output argument receiving the clip rect on success. * * @return Returns PP_TRUE if the resource was valid and the * clip rect was filled in, PP_FALSE if not. */ PP_Bool GetClipRect([in] PP_Resource resource, [out] PP_Rect clip); /** * GetDeviceScale returns the scale factor between device pixels and Density * Independent Pixels (DIPs, also known as logical pixels or UI pixels on * some platforms). This allows the developer to render their contents at * device resolution, even as coordinates / sizes are given in DIPs through * the API. * * Note that the coordinate system for Pepper APIs is DIPs. Also note that * one DIP might not equal one CSS pixel - when page scale/zoom is in effect. * * @param[in] resource A PP_Resource corresponding to a * PPB_View resource. * * @return A float value representing the number of device pixels * per DIP. If the resource is invalid, the value will be 0.0. */ [version=1.1] float_t GetDeviceScale([in] PP_Resource resource); /** * GetCSSScale returns the scale factor between DIPs and CSS pixels. This * allows proper scaling between DIPs - as sent via the Pepper API - and CSS * pixel coordinates used for Web content. * * @param[in] resource A PP_Resource corresponding to a * PPB_View resource. * * @return css_scale A float value representing the number of * DIPs per CSS pixel. If the resource is invalid, the value will be 0.0. */ [version=1.1] float_t GetCSSScale([in] PP_Resource resource); /** * GetScrollOffset returns the scroll offset of the window containing the * plugin. * * @param[in] resource A PP_Resource corresponding to a * PPB_View resource. * * @param[out] offset A PP_Point which will be set to the value * of the scroll offset in CSS pixels. * * @return Returns PP_TRUE if the resource was valid and the * offset was filled in, PP_FALSE if not. */ [version=1.2] PP_Bool GetScrollOffset([in] PP_Resource resource, [out] PP_Point offset); };