2008-06-22 18:32:58 +00:00
|
|
|
/*
|
|
|
|
OpenMW - The completely unofficial reimplementation of Morrowind
|
|
|
|
Copyright (C) 2008 Nicolay Korslund
|
|
|
|
Email: < korslund@gmail.com >
|
|
|
|
WWW: http://openmw.snaptoad.com/
|
|
|
|
|
|
|
|
This file (bindings.d) is part of the OpenMW package.
|
|
|
|
|
|
|
|
OpenMW is distributed as free software: you can redistribute it
|
|
|
|
and/or modify it under the terms of the GNU General Public License
|
|
|
|
version 3, as published by the Free Software Foundation.
|
|
|
|
|
|
|
|
This program 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.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
version 3 along with this program. If not, see
|
|
|
|
http://www.gnu.org/licenses/ .
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
module ogre.bindings;
|
|
|
|
|
|
|
|
import nif.misc; // for Transformation
|
|
|
|
import ogre.ogre; // for Placement
|
|
|
|
|
|
|
|
import core.resource;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This module is the interface to OGRE from D. Since OGRE is written
|
|
|
|
* in C++, all the code that deals directly with the graphics engine
|
|
|
|
* is packaged in a bunch of C++ functions. These functions are
|
|
|
|
* exported from C++ through the C calling convention, and imported
|
|
|
|
* here.
|
|
|
|
*
|
|
|
|
* Note that the C calling convension is not in any way type
|
|
|
|
* safe. This is convenient, as it allows us to send pointers as one
|
|
|
|
* type and recieve them as another, without casting, but also
|
|
|
|
* dangerous since it opens for some nasty bugs.
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Represents a pointer to a Node in the OGRE engine. We never use
|
|
|
|
// these directly in D code, only pass them back to the C++ code.
|
|
|
|
typedef void* NodePtr;
|
|
|
|
|
|
|
|
extern(C):
|
|
|
|
|
|
|
|
// Do engine configuration. Returns 0 if we should continue, 1 if
|
2008-07-06 17:03:52 +00:00
|
|
|
// not.
|
2008-09-30 18:14:39 +00:00
|
|
|
int ogre_configure(int showConfig, // Do we show the config dialogue?
|
2009-05-09 16:08:00 +00:00
|
|
|
char *plugincfg,// Name of 'plugin.cfg' file
|
|
|
|
int debutOut); // Enable or disable debug output
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Sets up the window
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_initWindow();
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Set up an empty scene.
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_makeScene();
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Set the ambient light and "sunlight"
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_setAmbient(float r, float g, float b,
|
2008-06-22 18:32:58 +00:00
|
|
|
float rs, float gs, float bs);
|
|
|
|
|
|
|
|
// Set fog color and view distance
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_setFog(float rf, float gf, float bf,
|
2008-06-22 18:32:58 +00:00
|
|
|
float flow, float fhigh);
|
|
|
|
|
|
|
|
// Create a simple sky dome
|
2008-09-30 18:14:39 +00:00
|
|
|
int ogre_makeSky();
|
2008-06-22 18:32:58 +00:00
|
|
|
|
2008-10-02 13:28:09 +00:00
|
|
|
// Toggle full ambient lighting on and off
|
|
|
|
void ogre_toggleLight();
|
|
|
|
|
2008-06-22 18:32:58 +00:00
|
|
|
// Enter main rendering loop
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_startRendering();
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Cleans up after ogre
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_cleanup();
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Gets a child SceneNode from the root node, then detatches it to
|
|
|
|
// hide it from view. Used for creating the "template" node associated
|
|
|
|
// with a NIF mesh.
|
2008-09-30 18:14:39 +00:00
|
|
|
NodePtr ogre_getDetachedNode();
|
|
|
|
|
|
|
|
// Convert a Morrowind rotation (3 floats) to a quaternion (4 floats)
|
|
|
|
void ogre_mwToQuaternion(float *mw, float *quat);
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Create a copy of the given scene node, with the given coordinates
|
2008-09-30 18:14:39 +00:00
|
|
|
// and rotation (as a quaternion.)
|
|
|
|
NodePtr ogre_insertNode(NodePtr base, char* name,
|
|
|
|
float *pos, float *quat, float scale);
|
|
|
|
|
|
|
|
// Get the world transformation of a node, returned as a translation
|
|
|
|
// and a matrix. The matrix includes both rotation and scaling. The
|
|
|
|
// buffers given must be large enough to store the result (3 and 9
|
|
|
|
// floats respectively.)
|
|
|
|
void ogre_getWorldTransform(NodePtr node, float *trans, float *matrix);
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Create a (very crappy looking) plane to simulate the water level
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_createWater(float level);
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Creates a scene node as a child of 'parent', then translates and
|
|
|
|
// rotates it according to the data in 'trafo'.
|
2008-09-30 18:14:39 +00:00
|
|
|
NodePtr ogre_createNode(
|
2008-06-22 18:32:58 +00:00
|
|
|
char *name, // Name to give the node
|
|
|
|
Transformation *trafo, // Transformation
|
|
|
|
NodePtr parent, // Parent node
|
|
|
|
int noRot); // If 1, don't rotate node
|
|
|
|
|
|
|
|
// Create a light with the given diffuse color. Attach it to SceneNode
|
|
|
|
// 'parent'.
|
2008-09-30 18:14:39 +00:00
|
|
|
NodePtr ogre_attachLight(char* name, NodePtr parent,
|
|
|
|
float r, float g, float b,
|
|
|
|
float radius);
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Create the specified material
|
2009-05-09 16:08:00 +00:00
|
|
|
void ogre_createMaterial(char *name, // Name to give resource
|
|
|
|
float *ambient, // Ambient RBG value
|
2008-09-30 18:14:39 +00:00
|
|
|
float *diffuse,
|
|
|
|
float *specular,
|
2009-05-09 16:08:00 +00:00
|
|
|
float *emissive, // Self illumination
|
2008-09-30 18:14:39 +00:00
|
|
|
float glossiness,// Same as shininess?
|
2009-05-09 16:08:00 +00:00
|
|
|
float alpha, // Reflection alpha?
|
|
|
|
char *texture, // Texture name
|
|
|
|
int alphaFlags, // Alpha settings (see
|
|
|
|
ubyte alphaTest);// NiAlphaProperty in nif/)
|
2008-06-22 18:32:58 +00:00
|
|
|
|
|
|
|
// Creates a mesh and gives it a bounding box. Also creates an entity
|
|
|
|
// and attached it to the given SceneNode 'owner'.
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_createMesh(
|
2008-06-22 18:32:58 +00:00
|
|
|
char* name, // Name of the mesh
|
|
|
|
int numVerts, // Number of vertices
|
|
|
|
float* vertices, // Vertex list
|
|
|
|
float* normals, // Normal list
|
|
|
|
float* colors, // Vertex colors
|
|
|
|
float* uvs, // Texture coordinates
|
|
|
|
int numFaces, // Number of faces*3
|
|
|
|
short* faces, // Faces
|
|
|
|
float radius, // Bounding sphere
|
|
|
|
char* material, // Material name, if any
|
|
|
|
|
|
|
|
// Bounding box
|
|
|
|
float minX,float minY,float minZ,
|
|
|
|
float maxX,float maxY,float maxZ,
|
|
|
|
|
|
|
|
NodePtr owner // Scene node to attach to.
|
|
|
|
);
|
|
|
|
|
2008-07-16 21:33:08 +00:00
|
|
|
// Toggle fullscreen mode
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_toggleFullscreen();
|
2008-07-16 21:33:08 +00:00
|
|
|
|
2008-06-22 18:32:58 +00:00
|
|
|
// Save a screen shot to the given file name
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_screenshot(char *filename);
|
2008-06-22 18:32:58 +00:00
|
|
|
|
2008-07-12 09:43:38 +00:00
|
|
|
// Camera control and information
|
2008-09-30 18:14:39 +00:00
|
|
|
void ogre_rotateCamera(float x, float y);
|
|
|
|
void ogre_moveCamera(float x, float y, float z);
|
|
|
|
void ogre_setCameraRotation(float r1, float r2, float r3);
|
|
|
|
void ogre_getCameraPos(float *x, float *y, float *z);
|
|
|
|
void ogre_getCameraOrientation(float *fx, float *fy, float *fz, float *ux, float *uy, float *uz);
|
|
|
|
void ogre_moveCameraRel(float x, float y, float z);
|
2008-06-22 18:32:58 +00:00
|
|
|
|
2009-02-02 13:07:38 +00:00
|
|
|
// Insert a raw RGBA image into the texture system.
|
|
|
|
//void ogre_insertTexture(char *name, int width, int height, void *data);
|