Format: Buffer to pti, Save renderer
This commit is contained in:
parent
9b4f710e28
commit
e08bc6680b
@ -71,6 +71,21 @@ std::string format::UnixtimeToDateMini(time_t unixtime)
|
||||
}
|
||||
}
|
||||
|
||||
std::vector<char> format::VideoBufferToPTI(const VideoBuffer & vidBuf)
|
||||
{
|
||||
std::vector<char> data;
|
||||
int dataSize = 0;
|
||||
char * buffer = (char*)Graphics::ptif_pack(vidBuf.Buffer, vidBuf.Width, vidBuf.Height, &dataSize);
|
||||
|
||||
if(buffer)
|
||||
{
|
||||
data.insert(data.end(), buffer, buffer+dataSize);
|
||||
free(buffer);
|
||||
}
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
std::vector<char> format::VideoBufferToPPM(const VideoBuffer & vidBuf)
|
||||
{
|
||||
std::vector<char> data;
|
||||
|
@ -28,5 +28,6 @@ namespace format
|
||||
std::string UnixtimeToDateMini(time_t unixtime);
|
||||
std::vector<char> VideoBufferToPNG(const VideoBuffer & vidBuf);
|
||||
std::vector<char> VideoBufferToPPM(const VideoBuffer & vidBuf);
|
||||
std::vector<char> VideoBufferToPTI(const VideoBuffer & vidBuf);
|
||||
unsigned long CalculateCRC(unsigned char * data, int length);
|
||||
}
|
118
src/PowderToyRenderer.cpp
Normal file
118
src/PowderToyRenderer.cpp
Normal file
@ -0,0 +1,118 @@
|
||||
#if defined(RENDERER)
|
||||
|
||||
#include <time.h>
|
||||
#include <iostream>
|
||||
#include <sstream>
|
||||
#include <string>
|
||||
#include <fstream>
|
||||
#include <vector>
|
||||
|
||||
#include "Config.h"
|
||||
#include "Format.h"
|
||||
#include "interface/Engine.h"
|
||||
#include "graphics/Graphics.h"
|
||||
#include "graphics/Renderer.h"
|
||||
|
||||
#include "client/GameSave.h"
|
||||
#include "simulation/Simulation.h"
|
||||
|
||||
|
||||
void readFile(std::string filename, std::vector<char> & storage)
|
||||
{
|
||||
std::ifstream fileStream;
|
||||
fileStream.open(std::string(filename).c_str(), std::ios::binary);
|
||||
if(fileStream.is_open())
|
||||
{
|
||||
fileStream.seekg(0, std::ios::end);
|
||||
size_t fileSize = fileStream.tellg();
|
||||
fileStream.seekg(0);
|
||||
|
||||
unsigned char * tempData = new unsigned char[fileSize];
|
||||
fileStream.read((char *)tempData, fileSize);
|
||||
fileStream.close();
|
||||
|
||||
std::vector<unsigned char> fileData;
|
||||
storage.clear();
|
||||
storage.insert(storage.end(), tempData, tempData+fileSize);
|
||||
delete[] tempData;
|
||||
}
|
||||
}
|
||||
|
||||
void writeFile(std::string filename, std::vector<char> & fileData)
|
||||
{
|
||||
std::ofstream fileStream;
|
||||
fileStream.open(std::string(filename).c_str(), std::ios::binary);
|
||||
if(fileStream.is_open())
|
||||
{
|
||||
fileStream.write(&fileData[0], fileData.size());
|
||||
fileStream.close();
|
||||
}
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
ui::Engine * engine;
|
||||
std::string outputPrefix, inputFilename;
|
||||
std::vector<char> inputFile;
|
||||
std::string ppmFilename, ptiFilename, ptiSmallFilename, pngFilename, pngSmallFilename;
|
||||
std::vector<char> ppmFile, ptiFile, ptiSmallFile, pngFile, pngSmallFile;
|
||||
|
||||
inputFilename = std::string(argv[1]);
|
||||
outputPrefix = std::string(argv[2]);
|
||||
|
||||
ppmFilename = outputPrefix+".ppm";
|
||||
ptiFilename = outputPrefix+".pti";
|
||||
ptiSmallFilename = outputPrefix+"-small.pti";
|
||||
pngFilename = outputPrefix+".png";
|
||||
pngSmallFilename = outputPrefix+"-small.png";
|
||||
|
||||
readFile(inputFilename, inputFile);
|
||||
|
||||
ui::Engine::Ref().g = new Graphics();
|
||||
|
||||
engine = &ui::Engine::Ref();
|
||||
engine->Begin(XRES+BARSIZE, YRES+MENUSIZE);
|
||||
|
||||
GameSave * gameSave = new GameSave(inputFile);
|
||||
|
||||
Simulation * sim = new Simulation();
|
||||
Renderer * ren = new Renderer(ui::Engine::Ref().g, sim);
|
||||
|
||||
sim->Load(gameSave);
|
||||
|
||||
|
||||
//Render save
|
||||
ren->decorations_enable = true;
|
||||
ren->blackDecorations = true;
|
||||
|
||||
int frame = 15;
|
||||
while(frame)
|
||||
{
|
||||
frame--;
|
||||
ren->render_parts();
|
||||
ren->render_fire();
|
||||
ren->clearScreen(1.0f);
|
||||
}
|
||||
|
||||
ren->RenderBegin();
|
||||
ren->RenderEnd();
|
||||
|
||||
VideoBuffer screenBuffer = ren->DumpFrame();
|
||||
//ppmFile = format::VideoBufferToPPM(screenBuffer);
|
||||
ptiFile = format::VideoBufferToPTI(screenBuffer);
|
||||
pngFile = format::VideoBufferToPNG(screenBuffer);
|
||||
|
||||
screenBuffer.Resize(1.0f/3.0f, true);
|
||||
ptiSmallFile = format::VideoBufferToPTI(screenBuffer);
|
||||
pngSmallFile = format::VideoBufferToPNG(screenBuffer);
|
||||
|
||||
|
||||
|
||||
//writeFile(ppmFilename, ppmFile);
|
||||
writeFile(ptiFilename, ptiFile);
|
||||
writeFile(ptiSmallFilename, ptiSmallFile);
|
||||
writeFile(pngFilename, pngFile);
|
||||
writeFile(pngSmallFilename, pngSmallFile);
|
||||
}
|
||||
|
||||
#endif
|
@ -32,6 +32,25 @@ VideoBuffer::VideoBuffer(VideoBuffer * old):
|
||||
std::copy(old->Buffer, old->Buffer+(old->Width*old->Height), Buffer);
|
||||
};
|
||||
|
||||
void VideoBuffer::Resize(float factor, bool resample)
|
||||
{
|
||||
int newWidth = ((float)Width)*factor;
|
||||
int newHeight = ((float)Height)*factor;
|
||||
pixel * newBuffer;
|
||||
if(resample)
|
||||
newBuffer = Graphics::resample_img(Buffer, Width, Height, newWidth, newHeight);
|
||||
else
|
||||
newBuffer = Graphics::resample_img_nn(Buffer, Width, Height, newWidth, newHeight);
|
||||
|
||||
if(newBuffer)
|
||||
{
|
||||
delete[] Buffer;
|
||||
Buffer = newBuffer;
|
||||
Width = newWidth;
|
||||
Height = newHeight;
|
||||
}
|
||||
}
|
||||
|
||||
int VideoBuffer::SetCharacter(int x, int y, int c, int r, int g, int b, int a)
|
||||
{
|
||||
int i, j, w, bn = 0, ba = 0;
|
||||
|
@ -109,6 +109,7 @@ public:
|
||||
VideoBuffer(const VideoBuffer & old);
|
||||
VideoBuffer(VideoBuffer * old);
|
||||
VideoBuffer(int width, int height);
|
||||
void Resize(float factor, bool resample = false);
|
||||
TPT_INLINE void BlendPixel(int x, int y, int r, int g, int b, int a)
|
||||
{
|
||||
#ifdef PIX32OGL
|
||||
|
Reference in New Issue
Block a user