std::string files;
char* configFile = getenv("YOINKRC");
+ char* dataDir = getenv("YOINK_DATADIR");
if (configFile)
{
files += ":";
}
+ // add the colon-delimited paths from configure
files += YOINK_CONFIGFILES;
+ if (dataDir)
+ {
+ // if another data directory is set in the environment, look for a
+ // config file there
+ files += ":";
+ files += dataDir;
+ files += "/yoinkrc";
+ }
+
+ // look in the configured data directory last of all
+ files += ":";
+ files += (dataDir ? dataDir : YOINK_DATADIR);
+ files += "/yoinkrc";
+
return files;
}
-
-YoinkApp::YoinkApp(int argc, char* argv[]) :
- Mf::Engine(PACKAGE_STRING, argc, argv, configFiles())
+static std::string iconFile()
{
- std::cout << PACKAGE_STRING << std::endl
- << "Compiled " << __TIME__ " " __DATE__ << std::endl
- << "Send requests, patches, and bug reports to <"
- PACKAGE_BUGREPORT << ">." << std::endl << std::endl;
-
char* dataDir = getenv("YOINK_DATADIR");
+ // first set up the search paths so we can find the icon and other resources
if (dataDir)
{
+ // look first in the data directory specified by the environment
Mf::Resource::addSearchPath(dataDir);
}
+ // then look in the configured data directory
Mf::Resource::addSearchPath(YOINK_DATADIR);
+ return Mf::Resource::getPathToResource("yoink.png");
+}
+
+
+YoinkApp::YoinkApp(int argc, char* argv[]) :
+ Mf::Engine(argc, argv, configFiles(), PACKAGE_STRING, iconFile())
+{
Mf::Dispatcher::instance().addHandler("video.context_recreated",
boost::bind(&YoinkApp::contextRecreated, this, _1), this);
setupGL();
fadeIn.init(coeff, 0.5f);
testScene = new Mf::Scene("Test");
+
+ x = y = z = 0.0;
}
YoinkApp::~YoinkApp()
{
delete someChar;
delete font;
+ delete testScene;
Mf::Dispatcher::instance().removeHandler(this);
-
- std::cout << "Goodbye..." << std::endl;
}
void YoinkApp::setupGL()
{
glEnable(GL_TEXTURE_2D);
+
//glEnable(GL_CULL_FACE);
glEnable(GL_DEPTH_TEST);
glShadeModel(GL_SMOOTH);
+ //glEnable(GL_POLYGON_SMOOTH);
+
+ //int texSize;
+ //glGetIntegerv(GL_MAX_TEXTURE_SIZE, &texSize);
+ //std::cout << "texture size: " << texSize << std::endl;
//glEnable(GL_BLEND);
//glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
glEnable(GL_ALPHA_TEST);
glAlphaFunc(GL_GREATER, 0.0);
- glClearColor(0.0, 0.0, 1.0, 1.0);
+ glClearColor(1.0, 0.0, 0.0, 1.0);
+
+ //glMatrixMode(GL_PROJECTION);
+ //glLoadIdentity();
+ //gluPerspective(60.0, 1.33333, 1.0, 2500.0);
+ camera.setProjection(cml::rad(60.0), 1.33333, 32.0, 2500.0);
+ camera.uploadProjectionToGL();
+ //glMatrixMode(GL_MODELVIEW);
+
//glLineWidth(10.0f);
}
fadeIn.update(dt);
+ camera.update(t, dt);
+
someChar->getAnimation().update(t, dt);
interp.update(dt);
void YoinkApp::draw(Mf::Scalar alpha)
{
- //Mf::vector4 meh;
+ //Mf::Vector4 meh;
//meh.random(0.0, 1.0);
- //static Mf::vector4 c1(meh);
+ //static Mf::Vector4 c1(meh);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
//Mf::Scalar cosstate = std::cos(drawstate);
- glMatrixMode(GL_PROJECTION);
- glLoadIdentity();
- gluPerspective(60.0, 1.33333, 1.0, 2000.0);
-
+
glMatrixMode(GL_MODELVIEW);
- glLoadIdentity();
+ //glLoadIdentity();
glBindTexture(GL_TEXTURE_2D, 0);
//glRotatef(drawstate*15.0f, 0.0, 1.0, 0.0);
- glTranslatef(x, y, z);
+ //glTranslatef(x, y, z);
+ glLoadMatrix(camera.getModelviewMatrix().data());
// DRAW THE SCENE
- testScene->draw(alpha);
+ testScene->draw(alpha, camera);
/*
+ glLoadIdentity();
+
someChar->getTilemap().bind();
glColor3f(1.0, 1.0, 1.0);
- unsigned heroFrame = someChar->getAnimation().getFrame();
+ Mf::Tilemap::Index heroFrame = someChar->getAnimation().getFrame();
- float coords[8];
+ Mf::Scalar coords[8];
someChar->getTilemap().getTileCoords(heroFrame, coords);
glBegin(GL_QUADS);
someChar->getTilemap().getTileCoords(heroFrame, coords,
- Mf::tilemap::reverse);
+ Mf::Tilemap::REVERSE);
glBegin(GL_QUADS);
glTexCoord2f(coords[0], coords[1]);
glColor4f(1.0,0.0,0.0,0.5);
glBindTexture(GL_TEXTURE_2D, 0);
- glColor4fv(c1.data());
+ glColor4v(c1.data());
glRectd(-cosstate, -sinstate, sinstate, cosstate);
glRectf(0.0f, 0.0f, sinstate, cosstate);
glBegin(GL_QUADS);
glTexCoord2f(coords[0], coords[1]);
- glVertex3f(0.0, -1.0, 0.0);
+ glVertex3(0.0, -1.0, 0.0);
glTexCoord2f(coords[2], coords[3]);
- glVertex3f(1.0, -1.0, 0.0);
+ glVertex3(1.0, -1.0, 0.0);
glTexCoord2f(coords[4], coords[5]);
- glVertex3f(1.0, 0.0, 0.0);
+ glVertex3(1.0, 0.0, 0.0);
glTexCoord2f(coords[6], coords[7]);
- glVertex3f(0.0, 0.0, 0.0);
+ glVertex3(0.0, 0.0, 0.0);
glEnd();
glEnable(GL_BLEND);
glBegin(GL_LINES);
glVertex2f(0.0f, 0.0f);
- glVertex2fv(interp.getState(alpha).data());
+ glVertex2v(interp.getState(alpha).data());
glEnd();
glColor4f(0.0f, 0.0f, 0.0f, fadeIn.getState(alpha));
{
someChar->getAnimation().startSequence("Punch");
}
- else if (event.key.keysym.sym == SDLK_RIGHT)
- {
- x -= 50.0;
- }
- else if (event.key.keysym.sym == SDLK_LEFT)
- {
- x += 50.0;
- }
- else if (event.key.keysym.sym == SDLK_UP)
- {
- y -= 50.0;
- }
- else if (event.key.keysym.sym == SDLK_DOWN)
+ else if (event.key.keysym.sym == SDLK_r)
{
- y += 50.0;
+ testScene->refresh();
}
- else if (event.key.keysym.sym == SDLK_PAGEUP)
+ else if (event.key.keysym.sym == SDLK_l)
{
- z += 50.0;
- }
- else if (event.key.keysym.sym == SDLK_PAGEDOWN)
- {
- z -= 50.0;
+ getVideo().toggleCursorGrab();
+ getVideo().toggleCursorVisible();
}
+ //else if (event.key.keysym.sym == SDLK_RIGHT)
+ //{
+ //x -= 50.0;
+ //}
+ //else if (event.key.keysym.sym == SDLK_LEFT)
+ //{
+ //x += 50.0;
+ //}
+ //else if (event.key.keysym.sym == SDLK_UP)
+ //{
+ //y -= 50.0;
+ //}
+ //else if (event.key.keysym.sym == SDLK_DOWN)
+ //{
+ //y += 50.0;
+ //}
+ //else if (event.key.keysym.sym == SDLK_PAGEUP)
+ //{
+ //z += 50.0;
+ //}
+ //else if (event.key.keysym.sym == SDLK_PAGEDOWN)
+ //{
+ //z -= 50.0;
+ //}
+
+ case SDL_MOUSEMOTION:
+ case SDL_MOUSEBUTTONDOWN:
+ camera.adjustFromInput(event);
break;
case SDL_QUIT:
case SDL_VIDEORESIZE:
glViewport(0, 0, event.resize.w, event.resize.h);
+ camera.setProjection(cml::rad(60.0), double(event.resize.w / event.resize.h), 32.0, 2500.0);
+ camera.uploadProjectionToGL();
break;
}
}
+#include <Moof/Tree.hh>
+
int main(int argc, char* argv[])
{
- YoinkApp app(argc, argv);
- return app.run();
+ std::cout << PACKAGE_STRING << std::endl
+ << "Compiled " << __TIME__ " " __DATE__ << std::endl
+ << "Send requests, patches, and bug reports to <"
+ PACKAGE_BUGREPORT << ">." << std::endl << std::endl;
+
+ int status = 0;
+
+ //Mf::Tree<int>::Ptr rootNode;
+ //Mf::Tree<int>::Ptr temp, temp2, temp3;
+
+ //rootNode = Mf::Tree<int>::Ptr(Mf::Tree<int>::createNewNode(1));
+
+ //temp = Mf::Tree<int>::Ptr(Mf::Tree<int>::createNewNode(2));
+ //temp3 = temp;
+ //rootNode->addChild(temp);
+
+ //temp = Mf::Tree<int>::Ptr(Mf::Tree<int>::createNewNode(3));
+ //temp2 = temp;
+ //rootNode->addChild(temp);
+
+ //temp = Mf::Tree<int>::Ptr(Mf::Tree<int>::createNewNode(4));
+ //rootNode->addChild(temp);
+
+ //temp = Mf::Tree<int>::Ptr(Mf::Tree<int>::createNewNode(5));
+ //temp2->addChild(temp);
+
+ //temp = Mf::Tree<int>::Ptr(Mf::Tree<int>::createNewNode(6));
+ //temp2->addChild(temp);
+
+ //temp = Mf::Tree<int>::Ptr(Mf::Tree<int>::createNewNode(7));
+ //temp3->addChild(temp);
+
+ //temp = rootNode;
+ //while (temp)
+ //{
+ //temp->print();
+ //temp = temp->getNext();
+ //}
+ //return 0;
+
+ try
+ {
+ YoinkApp app(argc, argv);
+ status = app.run();
+ }
+ catch (Mf::Engine::Exception e)
+ {
+ std::cerr << "Unhandled exception: " << e.what() << std::endl;
+ status = 1;
+ }
+
+ std::cout << "Goodbye..." << std::endl;
+ return status;
}
/** vim: set ts=4 sw=4 tw=80: *************************************************/