openspades/Sources/Client/IRenderer.h

144 lines
4.4 KiB
C
Raw Normal View History

2013-08-29 11:45:22 +09:00
/*
Copyright (c) 2013 yvt
2013-08-29 11:45:22 +09:00
This file is part of OpenSpades.
2013-08-29 11:45:22 +09:00
OpenSpades is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
2013-08-29 11:45:22 +09:00
OpenSpades is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
2013-08-29 11:45:22 +09:00
You should have received a copy of the GNU General Public License
along with OpenSpades. If not, see <http://www.gnu.org/licenses/>.
2013-08-29 11:45:22 +09:00
*/
2013-08-18 16:18:06 +09:00
#pragma once
#include <array>
#include <Core/Math.h>
#include "IImage.h"
2013-08-18 16:18:06 +09:00
#include "IModel.h"
#include "SceneDefinition.h"
#include <Core/RefCountedObject.h>
2013-08-18 16:18:06 +09:00
namespace spades {
class Bitmap;
class VoxelModel;
2013-08-18 16:18:06 +09:00
namespace client {
2013-08-18 16:18:06 +09:00
class GameMap;
2013-08-18 16:18:06 +09:00
struct ModelRenderParam {
2019-05-25 12:39:06 +09:00
/** The transformatrix matrix applied on the model. */
Matrix4 matrix = Matrix4::Identity();
2019-05-25 12:39:06 +09:00
/** Voxels having a color value `(0, 0, 0)` are replaced with
* this color. */
Vector3 customColor = MakeVector3(0, 0, 0);
2019-05-25 12:39:06 +09:00
/** Specifies to render the model in front of other non-depth-hack
* models. Useful for first-person models. */
bool depthHack = false;
2019-05-25 12:39:06 +09:00
/** Specifies whether the model casts a shadow. */
bool castShadow = true;
2013-08-18 16:18:06 +09:00
};
enum DynamicLightType { DynamicLightTypePoint, DynamicLightTypeSpotlight };
2013-08-18 16:18:06 +09:00
struct DynamicLightParam {
DynamicLightType type = DynamicLightTypePoint;
2019-05-25 12:39:06 +09:00
/** The position of the light. */
2013-08-18 16:18:06 +09:00
Vector3 origin;
2019-05-25 12:39:06 +09:00
/** The effective radius of the light. Objects outside this radius
* is unaffected by the light. */
2013-08-18 16:18:06 +09:00
float radius;
Vector3 color;
2019-05-25 12:39:06 +09:00
/** The basis vectors specifying the orientation of a spotlight.
* See the existing code for usage. */
std::array<Vector3, 3> spotAxis;
2019-05-25 12:39:06 +09:00
/** The projected image for a spotlight. */
IImage *image = nullptr;
float spotAngle = 0.0f;
2019-05-25 12:39:06 +09:00
/** When set to `true`, the lens flare post-effect is enabled for
* the light. */
bool useLensFlare = false;
2013-08-18 16:18:06 +09:00
};
class IRenderer : public RefCountedObject {
protected:
virtual ~IRenderer() {}
2013-08-18 16:18:06 +09:00
public:
IRenderer() {}
virtual void Init() = 0;
2013-09-14 13:36:05 +09:00
virtual void Shutdown() = 0;
2013-08-18 16:18:06 +09:00
virtual IImage *RegisterImage(const char *filename) = 0;
virtual IModel *RegisterModel(const char *filename) = 0;
2013-08-18 16:18:06 +09:00
virtual IImage *CreateImage(Bitmap *) = 0;
virtual IModel *CreateModel(VoxelModel *) = 0;
2013-08-18 16:18:06 +09:00
virtual void SetGameMap(GameMap *) = 0;
2013-08-18 16:18:06 +09:00
virtual void SetFogDistance(float) = 0;
virtual void SetFogColor(Vector3) = 0;
2013-08-18 16:18:06 +09:00
/** Starts rendering a scene and waits for additional objects. */
virtual void StartScene(const SceneDefinition &) = 0;
virtual void AddLight(const client::DynamicLightParam &light) = 0;
virtual void RenderModel(IModel *, const ModelRenderParam &) = 0;
2013-08-18 16:18:06 +09:00
virtual void AddDebugLine(Vector3 a, Vector3 b, Vector4 color) = 0;
2013-08-18 16:18:06 +09:00
virtual void AddSprite(IImage *, Vector3 center, float radius, float rotation) = 0;
2013-08-30 21:05:51 +09:00
virtual void AddLongSprite(IImage *, Vector3 p1, Vector3 p2, float radius) = 0;
2013-08-18 16:18:06 +09:00
/** Finalizes a scene. 2D drawing follows. */
virtual void EndScene() = 0;
2013-08-18 16:18:06 +09:00
virtual void MultiplyScreenColor(Vector3) = 0;
/** Sets color for image drawing. Deprecated because
* some methods treats this as an alpha premultiplied, while
* others treats this as an alpha non-premultiplied.
* @deprecated */
2013-08-18 16:18:06 +09:00
virtual void SetColor(Vector4) = 0;
/** Sets color for image drawing. Always alpha premultiplied. */
virtual void SetColorAlphaPremultiplied(Vector4) = 0;
virtual void DrawImage(IImage *, const Vector2 &outTopLeft) = 0;
virtual void DrawImage(IImage *, const AABB2 &outRect) = 0;
virtual void DrawImage(IImage *, const Vector2 &outTopLeft, const AABB2 &inRect) = 0;
virtual void DrawImage(IImage *, const AABB2 &outRect, const AABB2 &inRect) = 0;
virtual void DrawImage(IImage *, const Vector2 &outTopLeft, const Vector2 &outTopRight,
const Vector2 &outBottomLeft, const AABB2 &inRect) = 0;
virtual void DrawFlatGameMap(const AABB2 &outRect, const AABB2 &inRect) = 0;
2013-08-18 16:18:06 +09:00
/** Finalizes a frame. */
virtual void FrameDone() = 0;
2013-08-18 16:18:06 +09:00
/** displays a rendered image to the screen. */
virtual void Flip() = 0;
2013-08-18 16:18:06 +09:00
/** get a rendered image. */
virtual Bitmap *ReadBitmap() = 0;
2013-08-18 16:18:06 +09:00
virtual float ScreenWidth() = 0;
virtual float ScreenHeight() = 0;
};
}
}