Split decoder and render
decode.* will solely decode the teletext packets into a grid of characters and colours and other attributes stored in an agnostic way, then render.* will read this grid and render the characters onto the screen with the Qt specific methods.
This commit is contained in:
109
mainwidget.cpp
109
mainwidget.cpp
@@ -38,6 +38,7 @@
|
||||
|
||||
#include "mainwidget.h"
|
||||
|
||||
#include "decode.h"
|
||||
#include "document.h"
|
||||
#include "keymap.h"
|
||||
#include "levelonecommands.h"
|
||||
@@ -52,16 +53,18 @@ TeletextWidget::TeletextWidget(QFrame *parent) : QFrame(parent)
|
||||
this->setAttribute(Qt::WA_InputMethodEnabled, true);
|
||||
m_teletextDocument = new TeletextDocument();
|
||||
m_levelOnePage = m_teletextDocument->currentSubPage();
|
||||
m_pageRender.setTeletextPage(m_levelOnePage);
|
||||
m_pageDecode.setTeletextPage(m_levelOnePage);
|
||||
m_pageRender.setDecoder(&m_pageDecode);
|
||||
m_insertMode = false;
|
||||
m_selectionInProgress = false;
|
||||
setFocusPolicy(Qt::StrongFocus);
|
||||
m_flashTiming = m_flashPhase = 0;
|
||||
connect(&m_pageRender, &TeletextPageRender::flashChanged, this, &TeletextWidget::updateFlashTimer);
|
||||
connect(&m_pageRender, &TeletextPageRender::sidePanelsChanged, this, &TeletextWidget::changeSize);
|
||||
connect(&m_pageDecode, &TeletextPageDecode::sidePanelsChanged, this, &TeletextWidget::changeSize);
|
||||
connect(m_teletextDocument, &TeletextDocument::subPageSelected, this, &TeletextWidget::subPageSelected);
|
||||
connect(m_teletextDocument, &TeletextDocument::contentsChange, this, &TeletextWidget::refreshRow);
|
||||
connect(m_teletextDocument, &TeletextDocument::refreshNeeded, this, &TeletextWidget::refreshPage);
|
||||
connect(m_teletextDocument, &TeletextDocument::colourChanged, &m_pageRender, &TeletextPageRender::colourChanged);
|
||||
}
|
||||
|
||||
TeletextWidget::~TeletextWidget()
|
||||
@@ -85,20 +88,21 @@ void TeletextWidget::inputMethodEvent(QInputMethodEvent* event)
|
||||
void TeletextWidget::subPageSelected()
|
||||
{
|
||||
m_levelOnePage = m_teletextDocument->currentSubPage();
|
||||
m_pageRender.setTeletextPage(m_levelOnePage);
|
||||
refreshPage();
|
||||
m_pageDecode.setTeletextPage(m_levelOnePage);
|
||||
m_pageDecode.decodePage();
|
||||
m_pageRender.renderPage(true);
|
||||
update();
|
||||
}
|
||||
|
||||
void TeletextWidget::refreshRow(int rowChanged)
|
||||
{
|
||||
m_pageRender.renderPage(rowChanged);
|
||||
m_pageDecode.decodeRow(rowChanged);
|
||||
update();
|
||||
}
|
||||
|
||||
void TeletextWidget::refreshPage()
|
||||
{
|
||||
m_pageRender.decodePage();
|
||||
m_pageRender.renderPage();
|
||||
m_pageDecode.decodePage();
|
||||
update();
|
||||
}
|
||||
|
||||
@@ -107,11 +111,12 @@ void TeletextWidget::paintEvent(QPaintEvent *event)
|
||||
Q_UNUSED(event);
|
||||
QPainter widgetPainter(this);
|
||||
|
||||
widgetPainter.drawPixmap(m_pageRender.leftSidePanelColumns()*12, 0, *m_pageRender.pagePixmap(m_flashPhase), 0, 0, 480, 250);
|
||||
if (m_pageRender.leftSidePanelColumns())
|
||||
widgetPainter.drawPixmap(0, 0, *m_pageRender.pagePixmap(m_flashPhase), 864-m_pageRender.leftSidePanelColumns()*12, 0, m_pageRender.leftSidePanelColumns()*12, 250);
|
||||
if (m_pageRender.rightSidePanelColumns())
|
||||
widgetPainter.drawPixmap(480+m_pageRender.leftSidePanelColumns()*12, 0, *m_pageRender.pagePixmap(m_flashPhase), 480, 0, m_pageRender.rightSidePanelColumns()*12, 250);
|
||||
m_pageRender.renderPage();
|
||||
widgetPainter.drawPixmap(m_pageDecode.leftSidePanelColumns()*12, 0, *m_pageRender.pagePixmap(m_flashPhase), 0, 0, 480, 250);
|
||||
if (m_pageDecode.leftSidePanelColumns())
|
||||
widgetPainter.drawPixmap(0, 0, *m_pageRender.pagePixmap(m_flashPhase), 864-m_pageDecode.leftSidePanelColumns()*12, 0, m_pageDecode.leftSidePanelColumns()*12, 250);
|
||||
if (m_pageDecode.rightSidePanelColumns())
|
||||
widgetPainter.drawPixmap(480+m_pageDecode.leftSidePanelColumns()*12, 0, *m_pageRender.pagePixmap(m_flashPhase), 480, 0, m_pageDecode.rightSidePanelColumns()*12, 250);
|
||||
}
|
||||
|
||||
void TeletextWidget::updateFlashTimer(int newFlashTimer)
|
||||
@@ -155,25 +160,29 @@ void TeletextWidget::setInsertMode(bool insertMode)
|
||||
m_insertMode = insertMode;
|
||||
}
|
||||
|
||||
void TeletextWidget::toggleReveal(bool revealOn)
|
||||
void TeletextWidget::setReveal(bool reveal)
|
||||
{
|
||||
m_pageRender.setReveal(revealOn);
|
||||
m_pageRender.setReveal(reveal);
|
||||
update();
|
||||
}
|
||||
|
||||
void TeletextWidget::toggleMix(bool mixOn)
|
||||
void TeletextWidget::setMix(bool mix)
|
||||
{
|
||||
m_pageRender.setMix(mixOn);
|
||||
m_pageRender.setMix(mix);
|
||||
update();
|
||||
}
|
||||
|
||||
void TeletextWidget::setShowControlCodes(bool showControlCodes)
|
||||
{
|
||||
m_pageRender.setShowControlCodes(showControlCodes);
|
||||
update();
|
||||
}
|
||||
|
||||
void TeletextWidget::setControlBit(int bitNumber, bool active)
|
||||
{
|
||||
m_levelOnePage->setControlBit(bitNumber, active);
|
||||
if (bitNumber == 1 || bitNumber == 2) {
|
||||
m_pageRender.decodePage();
|
||||
m_pageRender.renderPage();
|
||||
}
|
||||
if (bitNumber == 1 || bitNumber == 2)
|
||||
m_pageDecode.decodePage();
|
||||
}
|
||||
|
||||
void TeletextWidget::setDefaultCharSet(int newDefaultCharSet)
|
||||
@@ -189,31 +198,27 @@ void TeletextWidget::setDefaultNOS(int newDefaultNOS)
|
||||
void TeletextWidget::setDefaultScreenColour(int newColour)
|
||||
{
|
||||
m_levelOnePage->setDefaultScreenColour(newColour);
|
||||
m_pageRender.decodePage();
|
||||
m_pageRender.renderPage();
|
||||
m_pageDecode.decodePage();
|
||||
}
|
||||
|
||||
void TeletextWidget::setDefaultRowColour(int newColour)
|
||||
{
|
||||
m_levelOnePage->setDefaultRowColour(newColour);
|
||||
m_pageRender.decodePage();
|
||||
m_pageRender.renderPage();
|
||||
m_pageDecode.decodePage();
|
||||
update();
|
||||
}
|
||||
|
||||
void TeletextWidget::setColourTableRemap(int newMap)
|
||||
{
|
||||
m_levelOnePage->setColourTableRemap(newMap);
|
||||
m_pageRender.decodePage();
|
||||
m_pageRender.renderPage();
|
||||
m_pageDecode.decodePage();
|
||||
update();
|
||||
}
|
||||
|
||||
void TeletextWidget::setBlackBackgroundSubst(bool substOn)
|
||||
{
|
||||
m_levelOnePage->setBlackBackgroundSubst(substOn);
|
||||
m_pageRender.decodePage();
|
||||
m_pageRender.renderPage();
|
||||
m_pageDecode.decodePage();
|
||||
update();
|
||||
}
|
||||
|
||||
@@ -225,18 +230,18 @@ void TeletextWidget::setSidePanelWidths(int newLeftSidePanelColumns, int newRigh
|
||||
m_levelOnePage->setSidePanelColumns((newLeftSidePanelColumns == 16) ? 0 : newLeftSidePanelColumns);
|
||||
else
|
||||
m_levelOnePage->setSidePanelColumns((newRightSidePanelColumns == 0) ? 0 : 16-newRightSidePanelColumns);
|
||||
m_pageRender.updateSidePanels();
|
||||
m_pageDecode.updateSidePanels();
|
||||
}
|
||||
|
||||
void TeletextWidget::setSidePanelAtL35Only(bool newSidePanelAtL35Only)
|
||||
{
|
||||
m_levelOnePage->setSidePanelStatusL25(!newSidePanelAtL35Only);
|
||||
m_pageRender.updateSidePanels();
|
||||
m_pageDecode.updateSidePanels();
|
||||
}
|
||||
|
||||
void TeletextWidget::changeSize()
|
||||
{
|
||||
setFixedSize(QSize(480+(pageRender()->leftSidePanelColumns()+pageRender()->rightSidePanelColumns())*12, 250));
|
||||
setFixedSize(QSize(480+(pageDecode()->leftSidePanelColumns()+pageDecode()->rightSidePanelColumns())*12, 250));
|
||||
emit sizeChanged();
|
||||
}
|
||||
|
||||
@@ -245,14 +250,14 @@ void TeletextWidget::keyPressEvent(QKeyEvent *event)
|
||||
if (event->key() < 0x01000000) {
|
||||
// A character-typing key was pressed
|
||||
// Try to keymap it, if not keymapped then plain ASCII code (may be) returned
|
||||
char mappedKeyPress = keymapping[m_pageRender.level1CharSet(m_teletextDocument->cursorRow(), m_teletextDocument->cursorColumn())].value(event->text().at(0), *qPrintable(event->text()));
|
||||
char mappedKeyPress = keymapping[m_pageDecode.level1CharSet(m_teletextDocument->cursorRow(), m_teletextDocument->cursorColumn())].value(event->text().at(0), *qPrintable(event->text()));
|
||||
if (mappedKeyPress < 0x20)
|
||||
return;
|
||||
// If outside ASCII map then the character can't be represented by current Level 1 character set
|
||||
// Map it to block character so it doesn't need to be inserted-between later on
|
||||
if (mappedKeyPress & 0x80)
|
||||
mappedKeyPress = 0x7f;
|
||||
if (m_pageRender.level1MosaicAttribute(m_teletextDocument->cursorRow(), m_teletextDocument->cursorColumn()) && (mappedKeyPress < 0x40 || mappedKeyPress > 0x5f)) {
|
||||
if (m_pageDecode.level1MosaicAttribute(m_teletextDocument->cursorRow(), m_teletextDocument->cursorColumn()) && (mappedKeyPress < 0x40 || mappedKeyPress > 0x5f)) {
|
||||
// We're on a mosaic and a blast-through character was NOT pressed
|
||||
if (event->key() >= Qt::Key_1 && event->key() <= Qt::Key_9 && event->modifiers() & Qt::KeypadModifier) {
|
||||
switch (event->key()) {
|
||||
@@ -382,8 +387,8 @@ void TeletextWidget::keyPressEvent(QKeyEvent *event)
|
||||
m_teletextDocument->selectSubPagePrevious();
|
||||
break;
|
||||
case Qt::Key_F5:
|
||||
m_pageRender.decodePage();
|
||||
m_pageRender.renderPage();
|
||||
m_pageDecode.decodePage();
|
||||
m_pageRender.renderPage(true);
|
||||
update();
|
||||
break;
|
||||
default:
|
||||
@@ -420,7 +425,7 @@ void TeletextWidget::selectionToClipboard()
|
||||
nativeData[i++] = m_teletextDocument->currentSubPage()->character(r, c);
|
||||
|
||||
if (m_teletextDocument->currentSubPage()->character(r, c) >= 0x20)
|
||||
plainTextData.append(keymapping[m_pageRender.level1CharSet(r, c)].key(m_teletextDocument->currentSubPage()->character(r, c), m_teletextDocument->currentSubPage()->character(r, c)));
|
||||
plainTextData.append(keymapping[m_pageDecode.level1CharSet(r, c)].key(m_teletextDocument->currentSubPage()->character(r, c), m_teletextDocument->currentSubPage()->character(r, c)));
|
||||
else
|
||||
plainTextData.append(' ');
|
||||
}
|
||||
@@ -453,13 +458,13 @@ void TeletextWidget::copy()
|
||||
|
||||
void TeletextWidget::paste()
|
||||
{
|
||||
m_teletextDocument->undoStack()->push(new PasteCommand(m_teletextDocument, m_pageRender.level1CharSet(m_teletextDocument->cursorRow(), m_teletextDocument->cursorColumn())));
|
||||
m_teletextDocument->undoStack()->push(new PasteCommand(m_teletextDocument, m_pageDecode.level1CharSet(m_teletextDocument->cursorRow(), m_teletextDocument->cursorColumn())));
|
||||
}
|
||||
|
||||
QPair<int, int> TeletextWidget::mouseToRowAndColumn(const QPoint &mousePosition)
|
||||
{
|
||||
int row = mousePosition.y() / 10;
|
||||
int column = mousePosition.x() / 12 - m_pageRender.leftSidePanelColumns();
|
||||
int column = mousePosition.x() / 12 - m_pageDecode.leftSidePanelColumns();
|
||||
if (row < 1)
|
||||
row = 1;
|
||||
if (row > 24)
|
||||
@@ -655,6 +660,22 @@ void LevelOneScene::updateSelection()
|
||||
m_selectionRectItem->setVisible(true);
|
||||
}
|
||||
|
||||
void LevelOneScene::setMix(bool mix)
|
||||
{
|
||||
if (mix) {
|
||||
m_fullScreenTopRectItem->setBrush(Qt::transparent);
|
||||
m_fullScreenBottomRectItem->setBrush(Qt::transparent);
|
||||
for (int r=0; r<25; r++) {
|
||||
m_fullRowLeftRectItem[r]->setBrush(Qt::transparent);
|
||||
m_fullRowRightRectItem[r]->setBrush(Qt::transparent);
|
||||
}
|
||||
} else {
|
||||
setFullScreenColour(static_cast<TeletextWidget *>(m_levelOneProxyWidget->widget())->pageDecode()->fullScreenQColor());
|
||||
for (int r=0; r<25; r++)
|
||||
setFullRowColour(r, static_cast<TeletextWidget *>(m_levelOneProxyWidget->widget())->pageDecode()->fullRowQColor(r));
|
||||
}
|
||||
}
|
||||
|
||||
void LevelOneScene::toggleGrid(bool gridOn)
|
||||
{
|
||||
m_grid = gridOn;
|
||||
@@ -700,12 +721,16 @@ bool LevelOneScene::eventFilter(QObject *object, QEvent *event)
|
||||
|
||||
void LevelOneScene::setFullScreenColour(const QColor &newColor)
|
||||
{
|
||||
m_fullScreenTopRectItem->setBrush(QBrush(newColor));
|
||||
m_fullScreenBottomRectItem->setBrush(QBrush(newColor));
|
||||
if (!static_cast<TeletextWidget *>(m_levelOneProxyWidget->widget())->pageRender()->mix()) {
|
||||
m_fullScreenTopRectItem->setBrush(newColor);
|
||||
m_fullScreenBottomRectItem->setBrush(newColor);
|
||||
}
|
||||
}
|
||||
|
||||
void LevelOneScene::setFullRowColour(int row, const QColor &newColor)
|
||||
{
|
||||
m_fullRowLeftRectItem[row]->setBrush(QBrush(newColor));
|
||||
m_fullRowRightRectItem[row]->setBrush(QBrush(newColor));
|
||||
if (!static_cast<TeletextWidget *>(m_levelOneProxyWidget->widget())->pageRender()->mix()) {
|
||||
m_fullRowLeftRectItem[row]->setBrush(newColor);
|
||||
m_fullRowRightRectItem[row]->setBrush(newColor);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user