1 /* Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 * Use of this source code is governed by a BSD-style license that can be
3 * found in the LICENSE file.
7 * This file contains the <code>PPB_Flash</code> interface.
18 enum PP_FlashLSORestrictions
{
20 * No restrictions on Flash LSOs.
22 PP_FLASHLSORESTRICTIONS_NONE
= 1,
25 * Don't allow access to Flash LSOs.
27 PP_FLASHLSORESTRICTIONS_BLOCK
= 2,
30 * Store Flash LSOs in memory only.
32 PP_FLASHLSORESTRICTIONS_IN_MEMORY
= 3
36 enum PP_FlashSetting
{
38 * Specifies if the system likely supports 3D hardware acceleration.
40 * The result is a boolean PP_Var, depending on the supported nature of 3D
41 * acceleration. If querying this function returns true, the 3D system will
42 * normally use the native hardware for rendering which will be much faster.
44 * Having this set to true only means that 3D should be used to draw 2D and
45 * video elements. PP_FLASHSETTING_STAGE3D_ENABLED should be checked to
46 * determine if it's ok to use 3D for arbitrary content.
48 * In rare cases (depending on the platform) this value will be true but a
49 * created 3D context will use emulation because context initialization
52 PP_FLASHSETTING_3DENABLED
= 1,
55 * Specifies if the given instance is in private/inconito/off-the-record mode
56 * (returns true) or "regular" mode (returns false). Returns an undefined
57 * PP_Var on invalid instance.
59 PP_FLASHSETTING_INCOGNITO
= 2,
62 * Specifies if arbitrary 3d commands are supported (returns true), or if 3d
63 * should only be used for drawing 2d and video (returns false).
65 * This should only be enabled if PP_FLASHSETTING_3DENABLED is true.
67 PP_FLASHSETTING_STAGE3DENABLED
= 3,
70 * Specifies the string for the language code of the UI of the browser.
72 * For example: "en-US" or "de".
74 * Returns an undefined PP_Var on invalid instance.
76 PP_FLASHSETTING_LANGUAGE
= 4,
79 * Specifies the number of CPU cores that are present on the system.
81 PP_FLASHSETTING_NUMCORES
= 5,
84 * Specifies restrictions on how flash should handle LSOs. The result is an
85 * int from <code>PP_FlashLSORestrictions</code>.
87 PP_FLASHSETTING_LSORESTRICTIONS
= 6
91 * This enum provides keys for setting breakpad crash report data.
94 enum PP_FlashCrashKey
{
96 * Specifies the document URL which contains the flash instance.
98 PP_FLASHCRASHKEY_URL
= 1
102 * The <code>PPB_Flash</code> interface contains pointers to various functions
103 * that are only needed to support Pepper Flash.
105 interface PPB_Flash
{
107 * Sets or clears the rendering hint that the given plugin instance is always
108 * on top of page content. Somewhat more optimized painting can be used in
111 void SetInstanceAlwaysOnTop
(
112 [in] PP_Instance instance
,
113 [in] PP_Bool on_top
);
116 * Draws the given pre-laid-out text. It is almost equivalent to Windows'
117 * ExtTextOut with the addition of the transformation (a 3x3 matrix given the
118 * transform to apply before drawing). It also adds the allow_subpixel_aa
119 * flag which when true, will use subpixel antialiasing if enabled in the
120 * system settings. For this to work properly, the graphics layer that the
121 * text is being drawn into must be opaque.
124 [in] PP_Instance instance
,
125 [in] PP_Resource pp_image_data
,
126 [in] PP_BrowserFont_Trusted_Description font_desc
,
128 [in] PP_Point position
,
130 [in] float_t
[3][3] transformation
,
131 [in] PP_Bool allow_subpixel_aa
,
132 [in] uint32_t glyph_count
,
133 [in, size_is(glyph_count
)] uint16_t
[] glyph_indices
,
134 [in, size_is(glyph_count
)] PP_Point
[] glyph_advances
);
137 * Retrieves the proxy that will be used for the given URL. The result will
138 * be a string in PAC format, or an undefined var on error.
140 PP_Var GetProxyForURL
(
141 [in] PP_Instance instance
,
145 * Navigate to the URL given by the given URLRequestInfo. (This supports GETs,
146 * POSTs, and javascript: URLs.) May open a new tab if target is not "_self".
149 [in] PP_Resource request_info
,
151 [in] PP_Bool from_user_action
);
154 * Deprecated. Does nothing. Use PPB_Flash_MessageLoop.
158 [in] PP_Instance instance
);
161 * Deprecated. Does nothing. Use PPB_Flash_MessageLoop.
164 void QuitMessageLoop
(
165 [in] PP_Instance instance
);
168 * Retrieves the local time zone offset from GM time for the given UTC time.
170 double_t GetLocalTimeZoneOffset
(
171 [in] PP_Instance instance
,
175 * Gets a (string) with "command-line" options for Flash; used to pass
176 * run-time debugging parameters, etc.
178 PP_Var GetCommandLineArgs
(
179 [in] PP_Module
module);
182 * Loads the given font in a more priviledged process on Windows. Call this if
183 * Windows is giving errors for font calls. See
184 * content/renderer/font_cache_dispatcher_win.cc
186 * The parameter is a pointer to a LOGFONTW structure.
188 * On non-Windows platforms, this function does nothing.
191 [in] mem_t logfontw
);
194 * Returns whether the given rectangle (in the plugin) is topmost, i.e., above
195 * all other web content.
197 PP_Bool IsRectTopmost
(
198 [in] PP_Instance instance
,
202 * Deprecated. Does nothing. Use PPB_Flash_Print.
205 int32_t InvokePrinting
(
206 [in] PP_Instance instance
);
209 * Indicates that there's activity and, e.g., the screensaver shouldn't kick
213 [in] PP_Instance instance
);
216 * Deprecated. Does nothing.
219 PP_Var GetDeviceID
([in] PP_Instance instance
);
222 * Deprecated. Does nothing. See GetSetting().
225 int32_t GetSettingInt
([in] PP_Instance instance
,
226 [in] PP_FlashSetting setting
);
229 * Returns the value associated with the given setting. Invalid enums will
230 * result in an undefined PP_Var return value.
232 PP_Var GetSetting
(PP_Instance instance
, PP_FlashSetting setting
);
235 * Allows setting breakpad crash data which will be included in plugin crash
236 * reports. Returns PP_FALSE if crash data could not be set.
239 PP_Bool SetCrashData
([in] PP_Instance instance
,
240 [in] PP_FlashCrashKey key
,
244 * Enumerates video capture devices. |video_capture| is a valid
245 * PPB_VideoCapture_Dev resource. Once the operation has completed
246 * successfully, |devices| will be set up with an array of
247 * PPB_DeviceRef_Dev resources.
249 * PP_OK is returned on success and different pepper error code on failure.
250 * The ref count of the returned |devices| has already been increased by 1 for
253 * NOTE: This method is a synchronous version of |EnumerateDevices| in
254 * PPB_VideoCapture_Dev.
257 int32_t EnumerateVideoCaptureDevices
(
258 [in] PP_Instance instance
,
259 [in] PP_Resource video_capture
,
260 [in] PP_ArrayOutput devices
);