mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-09 13:25:00 +00:00
f2786d3f9f
The only user is in layers/opengl. This is needed to do better state tracking in the compositor. --HG-- rename : gfx/gl/GLBlitTextureImageHelper.cpp => gfx/layers/opengl/GLBlitTextureImageHelper.cpp rename : gfx/gl/GLBlitTextureImageHelper.h => gfx/layers/opengl/GLBlitTextureImageHelper.h extra : rebase_source : bba00cbfac9253ca933721659dadbda2bfbe65c5
73 lines
2.2 KiB
C++
73 lines
2.2 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/* vim: set ts=8 sts=4 et sw=4 tw=80: */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#ifndef GLBLITTEXTUREIMAGEHELPER_H_
|
|
#define GLBLITTEXTUREIMAGEHELPER_H_
|
|
|
|
#include "mozilla/Attributes.h"
|
|
#include "GLContextTypes.h"
|
|
#include "GLConsts.h"
|
|
|
|
struct nsIntRect;
|
|
|
|
namespace mozilla {
|
|
namespace gl {
|
|
class GLContext;
|
|
class TextureImage;
|
|
}
|
|
namespace layers {
|
|
|
|
class CompositorOGL;
|
|
|
|
class GLBlitTextureImageHelper MOZ_FINAL
|
|
{
|
|
// The GLContext is the sole owner of the GLBlitTextureImageHelper.
|
|
CompositorOGL* mCompositor;
|
|
|
|
// lazy-initialized things
|
|
GLuint mBlitProgram, mBlitFramebuffer;
|
|
void UseBlitProgram();
|
|
void SetBlitFramebufferForDestTexture(GLuint aTexture);
|
|
|
|
public:
|
|
|
|
explicit GLBlitTextureImageHelper(CompositorOGL *gl);
|
|
~GLBlitTextureImageHelper();
|
|
|
|
/**
|
|
* Copy a rectangle from one TextureImage into another. The
|
|
* source and destination are given in integer coordinates, and
|
|
* will be converted to texture coordinates.
|
|
*
|
|
* For the source texture, the wrap modes DO apply -- it's valid
|
|
* to use REPEAT or PAD and expect appropriate behaviour if the source
|
|
* rectangle extends beyond its bounds.
|
|
*
|
|
* For the destination texture, the wrap modes DO NOT apply -- the
|
|
* destination will be clipped by the bounds of the texture.
|
|
*
|
|
* Note: calling this function will cause the following OpenGL state
|
|
* to be changed:
|
|
*
|
|
* - current program
|
|
* - framebuffer binding
|
|
* - viewport
|
|
* - blend state (will be enabled at end)
|
|
* - scissor state (will be enabled at end)
|
|
* - vertex attrib 0 and 1 (pointer and enable state [enable state will be disabled at exit])
|
|
* - array buffer binding (will be 0)
|
|
* - active texture (will be 0)
|
|
* - texture 0 binding
|
|
*/
|
|
void BlitTextureImage(gl::TextureImage *aSrc, const nsIntRect& aSrcRect,
|
|
gl::TextureImage *aDst, const nsIntRect& aDstRect);
|
|
};
|
|
|
|
}
|
|
}
|
|
|
|
#endif // GLBLITTEXTUREIMAGEHELPER_H_
|