summaryrefslogtreecommitdiff
path: root/lyt/picture.cpp
diff options
context:
space:
mode:
authorTreeki <treeki@gmail.com>2010-10-07 15:56:13 +0200
committerTreeki <treeki@gmail.com>2010-10-07 15:56:13 +0200
commit5f6dad55d75cbe146ff7fefc899a02ccd39078ba (patch)
tree0822df14cc6d2c0329810c9ae7b4a4a638fe82b1 /lyt/picture.cpp
downloadLayoutStudio-5f6dad55d75cbe146ff7fefc899a02ccd39078ba.tar.gz
LayoutStudio-5f6dad55d75cbe146ff7fefc899a02ccd39078ba.zip
initial commit -- everything compiles except for material.cpp. the material system still needs quite a bit of work; this will come in due time
Diffstat (limited to 'lyt/picture.cpp')
-rw-r--r--lyt/picture.cpp73
1 files changed, 73 insertions, 0 deletions
diff --git a/lyt/picture.cpp b/lyt/picture.cpp
new file mode 100644
index 0000000..33b2461
--- /dev/null
+++ b/lyt/picture.cpp
@@ -0,0 +1,73 @@
+#include "picture.h"
+#include "layout.h"
+#include "common.h"
+
+
+LYTPicture::LYTPicture(LYTLayout &layout) : LYTPane(layout) {
+}
+
+
+void LYTPicture::dumpToDebug(bool showHeading) {
+ if (showHeading)
+ qDebug() << "LYTPicture" << name << "@" << (void*)this;
+
+ LYTPane::dumpToDebug(false);
+
+ qDebug() << "- Vertex Colours:" << vtxColours[0] << "-" << vtxColours[1];
+ qDebug() << " " << vtxColours[2] << "-" << vtxColours[3];
+ qDebug() << "- Material:" << materialName;
+ qDebug() << "- Tex Coords:" << texCoords.count();
+
+ foreach (LYTTexCoords texCoord, texCoords) {
+ qDebug() << "----" << texCoord.coord[0] << "-" << texCoord.coord[1] << "-" << texCoord.coord[2] << "-" << texCoord.coord[3];
+ }
+}
+
+
+
+
+void LYTPicture::writeToDataStream(QDataStream &out) {
+ LYTPane::writeToDataStream(out);
+
+ for (int i = 0; i < 4; i++)
+ WriteRGBA8Color(vtxColours[i], out);
+
+ // calculate the material number
+ int materialNum = m_layout.materials.keys().indexOf(materialName);
+ out << (quint16)materialNum;
+
+ // write texcoords
+ out << (quint8)texCoords.count();
+ out.skipRawData(1); // padding
+
+ foreach (LYTTexCoords texCoord, texCoords) {
+ for (int i = 0; i < 4; i++)
+ WritePointF(out, texCoord.coord[i]);
+ }
+}
+
+
+void LYTPicture::readFromDataStream(QDataStream &in) {
+ LYTPane::readFromDataStream(in);
+
+ for (int i = 0; i < 4; i++)
+ ReadRGBA8Color(vtxColours[i], in);
+
+ // read the material name
+ quint16 materialNum;
+ in >> (quint16&)materialNum;
+
+ materialName = m_layout.materials.keys().at(materialNum);
+
+ // read texcoords
+ quint8 texCoordNum;
+ in >> (quint8&)texCoordNum;
+ in.skipRawData(1); // padding
+
+ texCoords.resize(texCoordNum);
+
+ foreach (LYTTexCoords texCoord, texCoords) {
+ for (int i = 0; i < 4; i++)
+ ReadPointF(in, texCoord.coord[i]);
+ }
+}