#include "V2SvkModel.h" V2SvkModel::V2SvkModel(QObject *parent) : CheckableTestModel(parent) { m_tests = { {"W-Frage", {"Affe", "Affe", "Affe", "Affe", "Schwein", "Schwein", "Schwein", "Schwein", "Gans", "Gans", "Gans", "Gans"}}, {"Verbtrennung", {"", "Affe", "", "", "", "", "", "Schwein", "", "", "Gans", ""}}, {"SVK: /-st/", {"Affe", "Affe", "Affe", "Affe", "Schwein", "Schwein", "Schwein", "Schwein", "Gans", "Gans", "Gans", "Gans"}}, {"Objekt-Topikalisierung", {"Affe", "Affe", "Affe", "Affe", "Schwein", "Schwein", "Schwein", "Schwein", "Gans", "Gans", "Gans", "Gans"}}, {"SVK: Stamm", {"Affe", "Affe", "Affe", "Affe", "Schwein", "Schwein", "Schwein", "Schwein", "Gans", "Gans", "Gans", "Gans"}}, {"Temporaladverb Präsens", {"Affe", "Affe", "Schwein", "Schwein", "Gans", "Gans"}}, {"SKV: /-e/ o. Stamm", {"Affe", "Affe", "Schwein", "Schwein", "Gans", "Gans"}}, {"Temporaladverb Perfekt", {"Affe", "Affe", "Schwein", "Schwein", "Gans", "Gans"}}, {"Verbtrennung", {"Affe", "Affe", "Schwein", "Schwein", "Gans", "Gans"}}, {"SVK: /-e/ o. Stamm", {"Affe", "Affe", "Schwein", "Schwein", "Gans", "Gans"}}, {"Partizip", {"Affe", "Affe", "Schwein", "Schwein", "Gans", "Gans"}}, }; } unsigned int V2SvkModel::getV2Points() const { unsigned int points = 0; for (auto testIndex : {0, 1, 3, 5, 7, 8}) { const auto &test = m_tests.at(testIndex); for (const auto &item : test.items()) { if (item.isChecked()) { points++; } } } return points; } unsigned int V2SvkModel::getSvkPoints() const { unsigned int points = 0; for (auto testIndex : {2, 4, 6, 9, 10}) { const auto &test = m_tests.at(testIndex); for (const auto &item : test.items()) { if (item.isChecked()) { points++; } } } return points; } bool V2SvkModel::isValidIndex(const QModelIndex &index) const { switch (index.row()) { case 1: return index.column() == 1 || index.column() == 7 || index.column() == 10; case 5: case 6: case 7: case 8: case 9: case 10: return index.column() < 6; default: return CheckableTestModel::isValidIndex(index); } } void V2SvkModel::write(ESGRAF48::V2SvkModel &model) const { auto writeOneVal = [&](ESGRAF48::V2SvkModel::OneEach *modelData, int testIndex) { if (modelData != nullptr) { const auto &testItems = m_tests.at(testIndex).items(); modelData->set_affe(testItems[1].isChecked()); modelData->set_schwein(testItems[7].isChecked()); modelData->set_gans(testItems[10].isChecked()); } }; auto writeTwoVals = [&](ESGRAF48::V2SvkModel::TwoEach *modelData, int testIndex) { if (modelData != nullptr) { const auto &testItems = m_tests.at(testIndex).items(); modelData->set_affe1(testItems[0].isChecked()); modelData->set_affe2(testItems[1].isChecked()); modelData->set_schwein1(testItems[2].isChecked()); modelData->set_schwein2(testItems[3].isChecked()); modelData->set_gans1(testItems[4].isChecked()); modelData->set_gans2(testItems[5].isChecked()); } }; auto writeFourVals = [&](ESGRAF48::V2SvkModel::FourEach *modelData, int testIndex) { if (modelData != nullptr) { const auto &testItems = m_tests.at(testIndex).items(); modelData->set_affe1(testItems[0].isChecked()); modelData->set_affe2(testItems[1].isChecked()); modelData->set_affe3(testItems[2].isChecked()); modelData->set_affe4(testItems[3].isChecked()); modelData->set_schwein1(testItems[4].isChecked()); modelData->set_schwein2(testItems[5].isChecked()); modelData->set_schwein3(testItems[6].isChecked()); modelData->set_schwein4(testItems[7].isChecked()); modelData->set_gans1(testItems[8].isChecked()); modelData->set_gans2(testItems[9].isChecked()); modelData->set_gans3(testItems[10].isChecked()); modelData->set_gans4(testItems[11].isChecked()); } }; writeFourVals(model.mutable_wfrage(), 0); writeOneVal(model.mutable_verbtrennung1(), 1); writeFourVals(model.mutable_svkst(), 2); writeFourVals(model.mutable_objtop(), 3); writeFourVals(model.mutable_svkstamm(), 4); writeTwoVals(model.mutable_temppraes(), 5); writeTwoVals(model.mutable_svke1(), 6); writeTwoVals(model.mutable_tempperf(), 7); writeTwoVals(model.mutable_verbtrennung2(), 8); writeTwoVals(model.mutable_svke2(), 9); writeTwoVals(model.mutable_partizip(), 10); } void V2SvkModel::read(const ESGRAF48::V2SvkModel &model) { auto readOneVal = [&](const ESGRAF48::V2SvkModel::OneEach &modelData, int testIndex) { auto &testItems = m_tests.at(testIndex).items(); testItems[1].setState(modelData.affe()); testItems[7].setState(modelData.schwein()); testItems[10].setState(modelData.gans()); }; auto readTwoVals = [&](const ESGRAF48::V2SvkModel::TwoEach &modelData, int testIndex) { auto &testItems = m_tests.at(testIndex).items(); testItems[0].setState(modelData.affe1()); testItems[1].setState(modelData.affe2()); testItems[2].setState(modelData.schwein1()); testItems[3].setState(modelData.schwein2()); testItems[4].setState(modelData.gans1()); testItems[5].setState(modelData.gans2()); }; auto readFourVals = [&](const ESGRAF48::V2SvkModel::FourEach &modelData, int testIndex) { auto &testItems = m_tests.at(testIndex).items(); testItems[0].setState(modelData.affe1()); testItems[1].setState(modelData.affe2()); testItems[2].setState(modelData.affe3()); testItems[3].setState(modelData.affe4()); testItems[4].setState(modelData.schwein1()); testItems[5].setState(modelData.schwein2()); testItems[6].setState(modelData.schwein3()); testItems[7].setState(modelData.schwein4()); testItems[8].setState(modelData.gans1()); testItems[9].setState(modelData.gans2()); testItems[10].setState(modelData.gans3()); testItems[11].setState(modelData.gans4()); }; readFourVals(model.wfrage(), 0); readOneVal(model.verbtrennung1(), 1); readFourVals(model.svkst(), 2); readFourVals(model.objtop(), 3); readFourVals(model.svkstamm(), 4); readTwoVals(model.temppraes(), 5); readTwoVals(model.svke1(), 6); readTwoVals(model.tempperf(), 7); readTwoVals(model.verbtrennung2(), 8); readTwoVals(model.svke2(), 9); readTwoVals(model.partizip(), 10); emit dataChanged(index(0, 0), index(rowCount() - 1, columnCount() - 1)); } void V2SvkModel::printTo(QPainter &painter) const { painter.setFont(h2Font()); painter.drawText( 0, 0, "Subtest 1: Verbzweitstellungsregel (V2) und Subjekt-Verb-Kontrollregel (SVK)"); painter.setFont(tableFont()); painter.setPen(tablePen()); auto width = painter.device()->width(); auto height = 1.5 * painter.fontMetrics().lineSpacing(); auto drawTextSquare = [&](double left, double top, double width, double height, const QString &text) { painter.drawText(left, top, width, height, Qt::AlignCenter, text); painter.drawLine(left, top, left + width, top); painter.drawLine(left + width, top, left + width, top + height); painter.drawLine(left + width, top + height, left, top + height); painter.drawLine(left, top + height, left, top); }; auto drawCheckSquare = [&](double left, double top, double width, double height, bool checked) { drawTextSquare(left, top, width, height, checked ? "\u2612" : "\u2610"); }; auto drawResultSquare = [&](bool right, unsigned int value, double y) { double cellWidth = 0.03 * width; double x = width - cellWidth - (right ? 0 : 0.04 * width); drawTextSquare(x, y, cellWidth, height, QString::number(value)); }; auto drawGreySquare = [&](double left, double top, double width, double height) { auto prevBrush = painter.brush(); auto prevPen = painter.pen(); painter.setBrush(QBrush(QColor(224, 224, 224))); painter.setPen(QPen(Qt::NoPen)); QPointF points[4] = {{left, top}, {left + width, top}, {left + width, top + height}, {left, top + height}}; painter.drawPolygon(points, 4); painter.setPen(tablePen()); painter.drawLine(left, top, left + width, top); painter.drawLine(left + width, top, left + width, top + height); painter.drawLine(left + width, top + height, left, top + height); painter.drawLine(left, top + height, left, top); painter.setBrush(prevBrush); painter.setPen(prevPen); }; std::set blockStarters = {0, 3, 5, 7}; std::set v2Tests = {0, 1, 3, 5, 7, 8}; std::set svkTests = {2, 4, 6, 9, 10}; double x = 0; double y = 0; auto testIndex = 0; for (const auto &test : m_tests) { double rowHeaderWidth = 0.2 * width; double resultCellWidth = test.size() > 8 ? 0.05 * width : 0.1 * width; double rowHeight = height; if (blockStarters.find(testIndex) != blockStarters.end()) { y += rowHeight; drawTextSquare(x, y, rowHeaderWidth, 2 * rowHeight, test.name()); x += rowHeaderWidth; std::vector> columnHeaders; for (const auto &item : test.items()) { const auto &itemText = item.getText(); if (!columnHeaders.empty() && columnHeaders.back().first == itemText) { columnHeaders.back().second++; } else { columnHeaders.emplace_back(itemText, 1); } } for (const auto &columnHeader : columnHeaders) { double cellWidth = columnHeader.second * resultCellWidth; drawTextSquare(x, y, cellWidth, rowHeight, columnHeader.first.c_str()); x += cellWidth; } x = rowHeaderWidth; y += rowHeight; } else { drawTextSquare(x, y, rowHeaderWidth, rowHeight, test.name()); x += rowHeaderWidth; } unsigned int emptyItemsStack = 0; for (const auto &item : test.items()) { if (item.getText().empty()) { emptyItemsStack++; } else { if (emptyItemsStack > 0) { drawGreySquare(x - emptyItemsStack * resultCellWidth, y, emptyItemsStack * resultCellWidth, rowHeight); emptyItemsStack = 0; } drawCheckSquare(x, y, resultCellWidth, rowHeight, item.isChecked()); } x += resultCellWidth; } if (emptyItemsStack > 0) { drawGreySquare(x - emptyItemsStack * resultCellWidth, y, emptyItemsStack * resultCellWidth, rowHeight); emptyItemsStack = 0; } if (v2Tests.find(testIndex) != v2Tests.end()) { drawResultSquare(false, test.getPoints(), y); } if (svkTests.find(testIndex) != svkTests.end()) { drawResultSquare(true, test.getPoints(), y); } x = 0; y += rowHeight; testIndex++; } x = 0; y += height; painter.drawText(x, y, 0.85 * width, height, Qt::AlignRight | Qt::AlignVCenter, "Rohwertpunkte Total:"); drawResultSquare(false, getV2Points(), y); drawResultSquare(true, getSvkPoints(), y); }