Added query creation methods to Renderer.

TRAC #22418 Signed-off-by: Nicolas Capens Signed-off-by: Shannon Woods Author: Geoff Lang git-svn-id: https://angleproject.googlecode.com/svn/branches/dx11proto@1839 736b8ea6-26fd-11df-bfd4-992fa37f6226
parent 23f3332a
...@@ -56,6 +56,7 @@ class TextureStorageInterface2D; ...@@ -56,6 +56,7 @@ class TextureStorageInterface2D;
class TextureStorageInterfaceCube; class TextureStorageInterfaceCube;
class VertexBuffer; class VertexBuffer;
class IndexBuffer; class IndexBuffer;
class QueryImpl;
class Blit; class Blit;
struct TranslatedIndexData; struct TranslatedIndexData;
...@@ -208,6 +209,9 @@ class Renderer ...@@ -208,6 +209,9 @@ class Renderer
virtual VertexBuffer *createVertexBuffer() = 0; virtual VertexBuffer *createVertexBuffer() = 0;
virtual IndexBuffer *createIndexBuffer() = 0; virtual IndexBuffer *createIndexBuffer() = 0;
// Query creation
virtual QueryImpl *createQuery(GLenum type) = 0;
protected: protected:
bool initializeCompiler(); bool initializeCompiler();
ID3DBlob *compileToBinary(gl::InfoLog &infoLog, const char *hlsl, const char *profile, bool alternateFlags); ID3DBlob *compileToBinary(gl::InfoLog &infoLog, const char *hlsl, const char *profile, bool alternateFlags);
......
...@@ -2547,6 +2547,13 @@ VertexBuffer *Renderer11::createVertexBuffer() ...@@ -2547,6 +2547,13 @@ VertexBuffer *Renderer11::createVertexBuffer()
IndexBuffer *Renderer11::createIndexBuffer() IndexBuffer *Renderer11::createIndexBuffer()
{ {
return new IndexBuffer11(this); return new IndexBuffer11(this);
}
QueryImpl *Renderer11::createQuery(GLenum type)
{
// TODO
UNIMPLEMENTED();
return NULL;
} }
bool Renderer11::getRenderTargetResource(gl::Framebuffer *framebuffer, unsigned int *subresourceIndex, ID3D11Texture2D **resource) bool Renderer11::getRenderTargetResource(gl::Framebuffer *framebuffer, unsigned int *subresourceIndex, ID3D11Texture2D **resource)
......
...@@ -164,6 +164,9 @@ class Renderer11 : public Renderer ...@@ -164,6 +164,9 @@ class Renderer11 : public Renderer
virtual VertexBuffer *createVertexBuffer(); virtual VertexBuffer *createVertexBuffer();
virtual IndexBuffer *createIndexBuffer(); virtual IndexBuffer *createIndexBuffer();
// Query creation
virtual QueryImpl *createQuery(GLenum type);
// D3D11-renderer specific methods // D3D11-renderer specific methods
ID3D11Device *getDevice() { return mDevice; } ID3D11Device *getDevice() { return mDevice; }
ID3D11DeviceContext *getDeviceContext() { return mDeviceContext; }; ID3D11DeviceContext *getDeviceContext() { return mDeviceContext; };
......
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#include "libGLESv2/renderer/RenderTarget9.h" #include "libGLESv2/renderer/RenderTarget9.h"
#include "libGLESv2/renderer/VertexBuffer9.h" #include "libGLESv2/renderer/VertexBuffer9.h"
#include "libGLESv2/renderer/IndexBuffer9.h" #include "libGLESv2/renderer/IndexBuffer9.h"
#include "libGLESv2/renderer/Query9.h"
#include <sstream> #include <sstream>
...@@ -705,6 +706,11 @@ IndexBuffer *Renderer9::createIndexBuffer() ...@@ -705,6 +706,11 @@ IndexBuffer *Renderer9::createIndexBuffer()
return new IndexBuffer9(this); return new IndexBuffer9(this);
} }
QueryImpl *Renderer9::createQuery(GLenum type)
{
return new Query9(this, type);
}
void Renderer9::setSamplerState(gl::SamplerType type, int index, const gl::SamplerState &samplerState) void Renderer9::setSamplerState(gl::SamplerType type, int index, const gl::SamplerState &samplerState)
{ {
bool *forceSetSamplers = (type == gl::SAMPLER_PIXEL) ? mForceSetPixelSamplerStates : mForceSetVertexSamplerStates; bool *forceSetSamplers = (type == gl::SAMPLER_PIXEL) ? mForceSetPixelSamplerStates : mForceSetVertexSamplerStates;
......
...@@ -194,6 +194,9 @@ class Renderer9 : public Renderer ...@@ -194,6 +194,9 @@ class Renderer9 : public Renderer
virtual VertexBuffer *createVertexBuffer(); virtual VertexBuffer *createVertexBuffer();
virtual IndexBuffer *createIndexBuffer(); virtual IndexBuffer *createIndexBuffer();
// Query creation
virtual QueryImpl *createQuery(GLenum type);
// D3D9-renderer specific methods // D3D9-renderer specific methods
bool boxFilter(IDirect3DSurface9 *source, IDirect3DSurface9 *dest); bool boxFilter(IDirect3DSurface9 *source, IDirect3DSurface9 *dest);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment