diff options
Diffstat (limited to 'lyt')
-rw-r--r-- | lyt/common.h | 14 | ||||
-rw-r--r-- | lyt/materials/alphacompare.cpp | 52 | ||||
-rw-r--r-- | lyt/materials/alphacompare.h | 40 | ||||
-rw-r--r-- | lyt/materials/blendmode.cpp | 47 | ||||
-rw-r--r-- | lyt/materials/blendmode.h | 39 | ||||
-rw-r--r-- | lyt/materials/material.cpp | 21 | ||||
-rw-r--r-- | lyt/materials/material.h | 21 | ||||
-rw-r--r-- | lyt/materials/tevstage.cpp | 72 |
8 files changed, 285 insertions, 21 deletions
diff --git a/lyt/common.h b/lyt/common.h index 2cddffd..c75813b 100644 --- a/lyt/common.h +++ b/lyt/common.h @@ -49,6 +49,20 @@ inline quint32 BitExtract(quint32 value, int count, int start) { return (value & mask) >> (32 - (start + count)); } +inline quint32 BitInsert(quint32 value, int newValue, int count, int start) { + quint32 mask = 0; + for (int i = start; i < start+count; i++) { + mask |= (0x80000000 >> i); + } + + value &= ~mask; + value |= (newValue << (32 - (start + count))) & mask; + return value; +} + + + + QByteArray PadByteArray(QByteArray original, int newLength, char padWith='\0'); diff --git a/lyt/materials/alphacompare.cpp b/lyt/materials/alphacompare.cpp new file mode 100644 index 0000000..a0e2f0f --- /dev/null +++ b/lyt/materials/alphacompare.cpp @@ -0,0 +1,52 @@ +/******************************************************************************* + This file is part of LayoutStudio (http://github.com/Treeki/LayoutStudio) + Copyright (c) 2010 Treeki (treeki@gmail.com) + + This program 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, version 2.0. + + 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 2.0 for more details. + + You should have received a copy of the GNU General Public License 2.0 + along with this program. If not, see <http://www.gnu.org/licenses/>. +*******************************************************************************/ + +#include "alphacompare.h" +#include "../layout.h" + +LYTAlphaCompare::LYTAlphaCompare() { +} + +void LYTAlphaCompare::dumpToDebug() { + qDebug() << "LYTAlphaCompare @" << (void*)this; + qDebug() << "Comp0:" << comp0 << "- Ref0:" << ref0; + qDebug() << "Comp1:" << comp1 << "- Ref1:" << ref1; + qDebug() << "Op:" << op; +} + + +void LYTAlphaCompare::writeToDataStream(QDataStream &out) { + out << (quint8)(comp0 | (comp1 << 4)); + out << (quint8)op; + out << (quint8)ref0; + out << (quint8)ref1; +} + + +void LYTAlphaCompare::readFromDataStream(QDataStream &in) { + quint8 value; + + in >> (quint8&)value; + comp0 = BitExtract(value, 4, 32 - 4); + comp1 = BitExtract(value, 4, 32 - 8); + + in >> (quint8&)op; + in >> (quint8&)ref0; + in >> (quint8&)ref1; +} + + diff --git a/lyt/materials/alphacompare.h b/lyt/materials/alphacompare.h new file mode 100644 index 0000000..0287252 --- /dev/null +++ b/lyt/materials/alphacompare.h @@ -0,0 +1,40 @@ +/******************************************************************************* + This file is part of LayoutStudio (http://github.com/Treeki/LayoutStudio) + Copyright (c) 2010 Treeki (treeki@gmail.com) + + This program 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, version 2.0. + + 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 2.0 for more details. + + You should have received a copy of the GNU General Public License 2.0 + along with this program. If not, see <http://www.gnu.org/licenses/>. +*******************************************************************************/ + +#ifndef LYTALPHACOMPARE_H +#define LYTALPHACOMPARE_H + +#include "../common.h" +#include "QtCore/QDataStream" + +class LYTAlphaCompare { +public: + LYTAlphaCompare(); + + void writeToDataStream(QDataStream &out); + void readFromDataStream(QDataStream &in); + + void dumpToDebug(); + + quint8 comp0; + quint8 ref0; + quint8 op; + quint8 comp1; + quint8 ref1; +}; + +#endif // LYTALPHACOMPARE_H diff --git a/lyt/materials/blendmode.cpp b/lyt/materials/blendmode.cpp new file mode 100644 index 0000000..d02cd9b --- /dev/null +++ b/lyt/materials/blendmode.cpp @@ -0,0 +1,47 @@ +/******************************************************************************* + This file is part of LayoutStudio (http://github.com/Treeki/LayoutStudio) + Copyright (c) 2010 Treeki (treeki@gmail.com) + + This program 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, version 2.0. + + 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 2.0 for more details. + + You should have received a copy of the GNU General Public License 2.0 + along with this program. If not, see <http://www.gnu.org/licenses/>. +*******************************************************************************/ + +#include "blendmode.h" +#include "../layout.h" + +LYTBlendMode::LYTBlendMode() { +} + +void LYTBlendMode::dumpToDebug() { + qDebug() << "LYTBlendMode @" << (void*)this; + qDebug() << "srcFactor:" << srcFactor << "- destFactor:" << destFactor; + qDebug() << "op:" << op << "- type:" << type; +} + + +void LYTBlendMode::writeToDataStream(QDataStream &out) { + out << (quint8)type; + out << (quint8)srcFactor; + out << (quint8)destFactor; + out << (quint8)op; +} + + +void LYTBlendMode::readFromDataStream(QDataStream &in) { + in >> (quint8&)type; + in >> (quint8&)srcFactor; + in >> (quint8&)destFactor; + in >> (quint8&)op; +} + + + diff --git a/lyt/materials/blendmode.h b/lyt/materials/blendmode.h new file mode 100644 index 0000000..5f5847f --- /dev/null +++ b/lyt/materials/blendmode.h @@ -0,0 +1,39 @@ +/******************************************************************************* + This file is part of LayoutStudio (http://github.com/Treeki/LayoutStudio) + Copyright (c) 2010 Treeki (treeki@gmail.com) + + This program 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, version 2.0. + + 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 2.0 for more details. + + You should have received a copy of the GNU General Public License 2.0 + along with this program. If not, see <http://www.gnu.org/licenses/>. +*******************************************************************************/ + +#ifndef LYTBLENDMODE_H +#define LYTBLENDMODE_H + +#include "../common.h" +#include "QtCore/QDataStream" + +class LYTBlendMode { +public: + LYTBlendMode(); + + void writeToDataStream(QDataStream &out); + void readFromDataStream(QDataStream &in); + + void dumpToDebug(); + + quint8 type; + quint8 srcFactor; + quint8 destFactor; + quint8 op; +}; + +#endif // LYTBLENDMODE_H diff --git a/lyt/materials/material.cpp b/lyt/materials/material.cpp index 1c89ae8..f79fd08 100644 --- a/lyt/materials/material.cpp +++ b/lyt/materials/material.cpp @@ -114,7 +114,7 @@ void LYTMaterial::readFromDataStream(QDataStream &in) { this->readIndirectStage(in); } - /*// TevStage + // TevStage tevStages.clear(); for (int i = 0; i < resourceNum.getTevStageNum(); i++) { @@ -135,7 +135,7 @@ void LYTMaterial::readFromDataStream(QDataStream &in) { this->readBlendMode(in); } else { this->hasBlendMode = false; - }*/ + } } @@ -183,3 +183,20 @@ void LYTMaterial::readIndirectStage(QDataStream &in) { this->indTexStages.last().readFromDataStream(in); this->indTexStages.last().dumpToDebug(); } + +void LYTMaterial::readTevStage(QDataStream &in) { + this->tevStages.append(LYTTevStage()); + this->tevStages.last().readFromDataStream(in); + this->tevStages.last().dumpToDebug(); +} + +void LYTMaterial::readAlphaCompare(QDataStream &in) { + this->alphaCompare.readFromDataStream(in); + this->alphaCompare.dumpToDebug(); +} + +void LYTMaterial::readBlendMode(QDataStream &in) { + this->blendMode.readFromDataStream(in); + this->blendMode.dumpToDebug(); +} + diff --git a/lyt/materials/material.h b/lyt/materials/material.h index 43eb62f..bfdf80b 100644 --- a/lyt/materials/material.h +++ b/lyt/materials/material.h @@ -31,6 +31,8 @@ #include "tevswaptable.h" #include "indirectstage.h" #include "tevstage.h" +#include "alphacompare.h" +#include "blendmode.h" class LYTLayout; @@ -55,25 +57,6 @@ public: -class LYTAlphaCompare { -public: - void writeToDataStream(QDataStream &out); - void readFromDataStream(QDataStream &in); - - void dumpToDebug(); - -}; - -class LYTBlendMode { -public: - void writeToDataStream(QDataStream &out); - void readFromDataStream(QDataStream &in); - - void dumpToDebug(); - -}; - - class LYTMaterial { diff --git a/lyt/materials/tevstage.cpp b/lyt/materials/tevstage.cpp index 31e55b1..7244e4e 100644 --- a/lyt/materials/tevstage.cpp +++ b/lyt/materials/tevstage.cpp @@ -23,10 +23,82 @@ LYTTevStage::LYTTevStage() { void LYTTevStage::dumpToDebug() { qDebug() << "LYTTevStage @" << (void*)this; + qDebug() << "TEV order: texCoord" << texCoord << ", colour" << colour << ", texMap" << texMap; + qDebug() << "SwapMode: ras" << rasSwapMode << ", tex" << texSwapMode; + + qDebug() << "Colour In:" << colourInA << colourInB << colourInC << colourInD; + qDebug() << "Op:" << colourOp << ", Bias:" << colourBias << ", Scale:" << colourScale; + qDebug() << "Clamp:" << colourClamp << ", OutReg:" << colourOutReg; + + qDebug() << "Alpha In:" << alphaInA << alphaInB << alphaInC << alphaInD; + qDebug() << "Op:" << alphaOp << ", Bias:" << alphaBias << ", Scale:" << alphaScale; + qDebug() << "Clamp:" << alphaClamp << ", OutReg:" << alphaOutReg; + + qDebug() << "Colour Const:" << colourConst << ", Alpha Const:" << alphaConst; + + qDebug() << "Indirect Stage:" << indStage << ", Format:" << indFormat; + qDebug() << "Bias:" << indBias << ", Matrix:" << indMatrix; + qDebug() << "WrapS:" << indWrapS << ", WrapT:" << indWrapT << ", AddPrev:" << indAddPrev; + qDebug() << "UtcLod:" << indUtcLod << ", AlphaSel:" << indAlphaSel; } void LYTTevStage::writeToDataStream(QDataStream &out) { + char data[0x10]; + qMemSet(data, 0, 0x10); + + // TEV order: + data[0] = texCoord; + colour = data[1]; + data[2] = texMap & 0xFF; + data[3] = BitInsert(data[3], texMap >> 8, 1, 32 - 1); + + // SwapMode: + data[3] = BitInsert(data[3], rasSwapMode, 2, 32 - 3); + data[3] = BitInsert(data[3], texSwapMode, 2, 32 - 5); + + // Colour In: + data[4] = BitInsert(data[4], colourInA, 4, 32 - 4); + data[4] = BitInsert(data[4], colourInB, 4, 32 - 8); + data[5] = BitInsert(data[5], colourInC, 4, 32 - 4); + data[5] = BitInsert(data[5], colourInD, 4, 32 - 8); + + // Colour Op: + data[6] = BitInsert(data[6], colourOp, 4, 32 - 4); + data[6] = BitInsert(data[6], colourBias, 2, 32 - 6); + data[6] = BitInsert(data[6], colourScale, 2, 32 - 8); + data[7] = BitInsert(data[7], colourClamp, 1, 32 - 1); + data[7] = BitInsert(data[7], colourOutReg, 2, 32 - 3); + + // Alpha In: + data[8] = BitInsert(data[8], alphaInA, 4, 32 - 4); + data[8] = BitInsert(data[8], alphaInB, 4, 32 - 8); + data[9] = BitInsert(data[9], alphaInC, 4, 32 - 4); + data[9] = BitInsert(data[9], alphaInD, 4, 32 - 8); + + // Alpha Op: + data[10] = BitInsert(data[10], alphaOp, 4, 32 - 4); + data[10] = BitInsert(data[10], alphaBias, 2, 32 - 6); + data[10] = BitInsert(data[10], alphaScale, 2, 32 - 8); + data[11] = BitInsert(data[11], alphaClamp, 1, 32 - 1); + data[11] = BitInsert(data[11], alphaOutReg, 2, 32 - 3); + + // Constants: + data[7] = BitInsert(data[7], colourConst, 5, 32 - 8); + data[11] = BitInsert(data[11], alphaConst, 5, 32 - 8); + + // Indirect: + data[12] = indStage; + data[15] = BitInsert(data[15], indFormat, 2, 32 - 2); + data[13] = BitInsert(data[13], indBias, 3, 32 - 3); + data[13] = BitInsert(data[13], indMatrix, 4, 32 - 7); + data[14] = BitInsert(data[14], indWrapS, 3, 32 - 3); + data[14] = BitInsert(data[14], indWrapT, 3, 32 - 6); + data[15] = BitInsert(data[15], indAddPrev, 1, 32 - 3); + data[15] = BitInsert(data[15], indUtcLod, 1, 32 - 4); + data[15] = BitInsert(data[15], indAlphaSel, 2, 32 - 6); + + out.writeRawData(data, 0x10); } |