summaryrefslogtreecommitdiffstats
path: root/ppapi/cpp/compositor_layer.cc
diff options
context:
space:
mode:
authorpenghuang@chromium.org <penghuang@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-08-15 21:30:16 +0000
committerpenghuang@chromium.org <penghuang@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-08-15 21:30:16 +0000
commit748e647a09bf44eb993022f31495efd5b58e7d3d (patch)
tree1e6eff45da50fab026a4a6b1ffd33803cd399ad2 /ppapi/cpp/compositor_layer.cc
parent032ed0d7869d3ad0569a2024eaa4946864cc7f9d (diff)
downloadchromium_src-748e647a09bf44eb993022f31495efd5b58e7d3d.zip
chromium_src-748e647a09bf44eb993022f31495efd5b58e7d3d.tar.gz
chromium_src-748e647a09bf44eb993022f31495efd5b58e7d3d.tar.bz2
[PPAPI] Add target param for CompositorLayer::SetTexture().
BUG=403504 Review URL: https://codereview.chromium.org/475123003 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@290016 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ppapi/cpp/compositor_layer.cc')
-rw-r--r--ppapi/cpp/compositor_layer.cc54
1 files changed, 54 insertions, 0 deletions
diff --git a/ppapi/cpp/compositor_layer.cc b/ppapi/cpp/compositor_layer.cc
index cbe823a..d15a673 100644
--- a/ppapi/cpp/compositor_layer.cc
+++ b/ppapi/cpp/compositor_layer.cc
@@ -17,6 +17,10 @@ template <> const char* interface_name<PPB_CompositorLayer_0_1>() {
return PPB_COMPOSITORLAYER_INTERFACE_0_1;
}
+template <> const char* interface_name<PPB_CompositorLayer_0_2>() {
+ return PPB_COMPOSITORLAYER_INTERFACE_0_2;
+}
+
} // namespace
CompositorLayer::CompositorLayer() {
@@ -43,6 +47,10 @@ int32_t CompositorLayer::SetColor(float red,
float blue,
float alpha,
const Size& size) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetColor(
+ pp_resource(), red, green, blue, alpha, &size.pp_size());
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetColor(
pp_resource(), red, green, blue, alpha, &size.pp_size());
@@ -51,10 +59,18 @@ int32_t CompositorLayer::SetColor(float red,
}
int32_t CompositorLayer::SetTexture(const Graphics3D& context,
+ uint32_t target,
uint32_t texture,
const Size& size,
const CompletionCallback& cc) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetTexture(
+ pp_resource(), context.pp_resource(), target, texture, &size.pp_size(),
+ cc.pp_completion_callback());
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
+ if (target != 0x0DE1) // 0x0DE1 GL_TEXTURE_2D
+ return cc.MayForce(PP_ERROR_NOTSUPPORTED);
return get_interface<PPB_CompositorLayer_0_1>()->SetTexture(
pp_resource(), context.pp_resource(), texture, &size.pp_size(),
cc.pp_completion_callback());
@@ -64,6 +80,11 @@ int32_t CompositorLayer::SetTexture(const Graphics3D& context,
int32_t CompositorLayer::SetImage(const ImageData& image,
const CompletionCallback& cc) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetImage(
+ pp_resource(), image.pp_resource(), NULL,
+ cc.pp_completion_callback());
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetImage(
pp_resource(), image.pp_resource(), NULL,
@@ -75,6 +96,11 @@ int32_t CompositorLayer::SetImage(const ImageData& image,
int32_t CompositorLayer::SetImage(const ImageData& image,
const Size& size,
const CompletionCallback& cc) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetImage(
+ pp_resource(), image.pp_resource(), &size.pp_size(),
+ cc.pp_completion_callback());
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetImage(
pp_resource(), image.pp_resource(), &size.pp_size(),
@@ -84,6 +110,10 @@ int32_t CompositorLayer::SetImage(const ImageData& image,
}
int32_t CompositorLayer::SetClipRect(const Rect& rect) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetClipRect(
+ pp_resource(), &rect.pp_rect());
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetClipRect(
pp_resource(), &rect.pp_rect());
@@ -92,6 +122,10 @@ int32_t CompositorLayer::SetClipRect(const Rect& rect) {
}
int32_t CompositorLayer::SetTransform(const float matrix[16]) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetTransform(
+ pp_resource(), matrix);
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetTransform(
pp_resource(), matrix);
@@ -100,6 +134,10 @@ int32_t CompositorLayer::SetTransform(const float matrix[16]) {
}
int32_t CompositorLayer::SetOpacity(float opacity) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetOpacity(
+ pp_resource(), opacity);
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetOpacity(
pp_resource(), opacity);
@@ -108,6 +146,10 @@ int32_t CompositorLayer::SetOpacity(float opacity) {
}
int32_t CompositorLayer::SetBlendMode(PP_BlendMode mode) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetBlendMode(
+ pp_resource(), mode);
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetBlendMode(
pp_resource(), mode);
@@ -116,6 +158,10 @@ int32_t CompositorLayer::SetBlendMode(PP_BlendMode mode) {
}
int32_t CompositorLayer::SetSourceRect(const FloatRect& rect) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetSourceRect(
+ pp_resource(), &rect.pp_float_rect());
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetSourceRect(
pp_resource(), &rect.pp_float_rect());
@@ -124,6 +170,10 @@ int32_t CompositorLayer::SetSourceRect(const FloatRect& rect) {
}
int32_t CompositorLayer::SetPremultipliedAlpha(bool premult) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return get_interface<PPB_CompositorLayer_0_2>()->SetPremultipliedAlpha(
+ pp_resource(), PP_FromBool(premult));
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return get_interface<PPB_CompositorLayer_0_1>()->SetPremultipliedAlpha(
pp_resource(), PP_FromBool(premult));
@@ -132,6 +182,10 @@ int32_t CompositorLayer::SetPremultipliedAlpha(bool premult) {
}
bool CompositorLayer::IsCompositorLayer(const Resource& resource) {
+ if (has_interface<PPB_CompositorLayer_0_2>()) {
+ return PP_ToBool(get_interface<PPB_CompositorLayer_0_2>()->
+ IsCompositorLayer(resource.pp_resource()));
+ }
if (has_interface<PPB_CompositorLayer_0_1>()) {
return PP_ToBool(get_interface<PPB_CompositorLayer_0_1>()->
IsCompositorLayer(resource.pp_resource()));