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

Unified Diff: chrome/browser/android/vr_shell/ui_elements/textured_element.cc

Issue 2834543006: Hook up insecure content warnings for http webVR presentation. (Closed)
Patch Set: rebase Created 3 years, 8 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/android/vr_shell/ui_elements/textured_element.cc
diff --git a/chrome/browser/android/vr_shell/ui_elements/textured_element.cc b/chrome/browser/android/vr_shell/ui_elements/textured_element.cc
new file mode 100644
index 0000000000000000000000000000000000000000..b16b409d4cb710b753fc7fc5da5e2d8c096af9c5
--- /dev/null
+++ b/chrome/browser/android/vr_shell/ui_elements/textured_element.cc
@@ -0,0 +1,57 @@
+// Copyright 2017 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.
+
+#include "chrome/browser/android/vr_shell/ui_elements/textured_element.h"
+
+#include "cc/paint/skia_paint_canvas.h"
+#include "chrome/browser/android/vr_shell/textures/ui_texture.h"
+#include "chrome/browser/android/vr_shell/vr_shell_renderer.h"
+#include "third_party/skia/include/core/SkSurface.h"
+
+namespace vr_shell {
+
+TexturedElement::TexturedElement(int maximum_width)
+ : texture_handle_(-1), maximum_width_(maximum_width) {}
+
+TexturedElement::~TexturedElement() = default;
+
+void TexturedElement::Initialize() {
+ glGenTextures(1, &texture_handle_);
+ DCHECK(GetTexture() != nullptr);
+ texture_size_ = GetTexture()->GetPreferredTextureSize(maximum_width_);
+ sk_sp<SkSurface> surface = SkSurface::MakeRasterN32Premul(
+ texture_size_.width(), texture_size_.height());
+ GetTexture()->DrawAndLayout(surface->getCanvas(), texture_size_);
+ Flush(surface.get());
+ fill = Fill::SELF;
+ gfx::SizeF drawn_size = GetTexture()->GetDrawnSize();
+ float y = drawn_size.height() / drawn_size.width() * size.x();
+ size = {size.x(), y, 1};
+}
+
+void TexturedElement::Render(VrShellRenderer* renderer,
+ vr::Mat4f view_proj_matrix) const {
+ gfx::SizeF drawn_size = GetTexture()->GetDrawnSize();
+ gfx::RectF copy_rect(0, 0, drawn_size.width() / texture_size_.width(),
+ drawn_size.height() / texture_size_.height());
+ renderer->GetTexturedQuadRenderer()->AddQuad(
+ texture_handle_, view_proj_matrix, copy_rect, opacity);
+}
+
+void TexturedElement::Flush(SkSurface* surface) {
+ cc::SkiaPaintCanvas paint_canvas(surface->getCanvas());
+ paint_canvas.flush();
+ SkPixmap pixmap;
+ CHECK(surface->peekPixels(&pixmap));
+
+ glBindTexture(GL_TEXTURE_2D, texture_handle_);
+ glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
+ glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
+ glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
+ glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
+ glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, pixmap.width(), pixmap.height(), 0,
+ GL_RGBA, GL_UNSIGNED_BYTE, pixmap.addr());
+}
+
+} // namespace vr_shell

Powered by Google App Engine
This is Rietveld 408576698