forked from mia/Aegisub
Few more changes, still very glitchy
Originally committed to SVN as r278.
This commit is contained in:
parent
02cfa685fc
commit
ba2af9505e
4 changed files with 44 additions and 21 deletions
|
@ -70,12 +70,14 @@ DrawPRS::~DrawPRS() {
|
||||||
/////////////
|
/////////////
|
||||||
// Get frame
|
// Get frame
|
||||||
PVideoFrame __stdcall DrawPRS::GetFrame(int n, IScriptEnvironment* env) {
|
PVideoFrame __stdcall DrawPRS::GetFrame(int n, IScriptEnvironment* env) {
|
||||||
// Get frame
|
// Avisynth frame
|
||||||
//PVideoFrame avsFrame = child->GetFrame(n,env);
|
PVideoFrame avsFrame = child->GetFrame(n,env);
|
||||||
PVideoFrame avsFrame = env->NewVideoFrame(vi);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
// Check if there is anything to be drawn
|
||||||
|
if (file.HasDataAtFrame(n)) {
|
||||||
// Create the PRSFrame structure
|
// Create the PRSFrame structure
|
||||||
|
env->MakeWritable(&avsFrame);
|
||||||
PRSVideoFrame frame;
|
PRSVideoFrame frame;
|
||||||
frame.data[0] = (char*) avsFrame->GetWritePtr();
|
frame.data[0] = (char*) avsFrame->GetWritePtr();
|
||||||
frame.w = avsFrame->GetRowSize()/4;
|
frame.w = avsFrame->GetRowSize()/4;
|
||||||
|
@ -86,6 +88,7 @@ PVideoFrame __stdcall DrawPRS::GetFrame(int n, IScriptEnvironment* env) {
|
||||||
// Draw into the frame
|
// Draw into the frame
|
||||||
file.DrawFrame(n,&frame);
|
file.DrawFrame(n,&frame);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Catch exception
|
// Catch exception
|
||||||
catch (std::exception e) {
|
catch (std::exception e) {
|
||||||
|
|
|
@ -287,6 +287,25 @@ void PRSFile::GetDisplayBlocksAtFrame(int n,std::vector<PRSDisplay*> &blocks) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////
|
||||||
|
// Checks if there is anything at the frame
|
||||||
|
bool PRSFile::HasDataAtFrame(int n) {
|
||||||
|
// Find all blocks that match
|
||||||
|
unsigned int fn = n;
|
||||||
|
std::list<PRSEntry*>::iterator cur;
|
||||||
|
PRSDisplay *display;
|
||||||
|
for (cur=entryList.begin();cur!=entryList.end();cur++) {
|
||||||
|
display = PRSEntry::GetDisplay(*cur);
|
||||||
|
if (display) {
|
||||||
|
if (display->startFrame <= fn && display->endFrame >= fn) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////
|
||||||
// Gets a PRSImage by its ID, returns NULL if it doesn't exist
|
// Gets a PRSImage by its ID, returns NULL if it doesn't exist
|
||||||
PRSImage *PRSFile::GetImageByID(int id) {
|
PRSImage *PRSFile::GetImageByID(int id) {
|
||||||
|
|
|
@ -68,6 +68,7 @@ public:
|
||||||
void Load(std::string path,bool reset=true);
|
void Load(std::string path,bool reset=true);
|
||||||
|
|
||||||
void GetDisplayBlocksAtFrame(int n,std::vector<PRSDisplay*> &blocks);
|
void GetDisplayBlocksAtFrame(int n,std::vector<PRSDisplay*> &blocks);
|
||||||
|
bool HasDataAtFrame(int n);
|
||||||
void DrawFrame(int n,PRSVideoFrame *frame);
|
void DrawFrame(int n,PRSVideoFrame *frame);
|
||||||
PRSImage *GetImageByID(int id);
|
PRSImage *GetImageByID(int id);
|
||||||
|
|
||||||
|
|
|
@ -103,24 +103,24 @@ void PRSVideoFrame::Overlay(PRSVideoFrame *dstFrame,int x,int y,unsigned char al
|
||||||
|
|
||||||
// Draw the row
|
// Draw the row
|
||||||
for (int i=0;i<rowLen;i++) {
|
for (int i=0;i<rowLen;i++) {
|
||||||
// Read alpha
|
|
||||||
a = *src++;
|
|
||||||
da = *dst;
|
|
||||||
ia = 255-a;
|
|
||||||
|
|
||||||
// Read colors
|
// Read colors
|
||||||
sc1 = *src++;
|
sc1 = *src++;
|
||||||
dc1 = *(dst+1);
|
dc1 = *(dst);
|
||||||
sc2 = *src++;
|
sc2 = *src++;
|
||||||
dc2 = *(dst+2);
|
dc2 = *(dst+1);
|
||||||
sc3 = *src++;
|
sc3 = *src++;
|
||||||
dc3 = *(dst+3);
|
dc3 = *(dst+2);
|
||||||
|
|
||||||
|
// Read alpha
|
||||||
|
a = *src++;
|
||||||
|
da = *(dst+3);
|
||||||
|
ia = 255-a;
|
||||||
|
|
||||||
// Write colors
|
// Write colors
|
||||||
*dst++ = 255-(ia*(255-da)/255);
|
|
||||||
*dst++ = (sc1*a + dc1*ia)/255;
|
*dst++ = (sc1*a + dc1*ia)/255;
|
||||||
*dst++ = (sc2*a + dc2*ia)/255;
|
*dst++ = (sc2*a + dc2*ia)/255;
|
||||||
*dst++ = (sc3*a + dc3*ia)/255;
|
*dst++ = (sc3*a + dc3*ia)/255;
|
||||||
|
*dst++ = 255-(ia*(255-da)/255);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue