diff options
author | José Ávila <linux@javila.net> | 2005-07-03 02:52:20 +0000 |
---|---|---|
committer | José Ávila <linux@javila.net> | 2005-07-03 02:52:20 +0000 |
commit | a3beebb0a5b900d70e44b96e4679621dc9fd95f5 (patch) | |
tree | 80e307a7d2c0a0963f3344495cf40bdca3cd3d3c | |
parent | 675348d7e62292ed01175b8b001c6a99b207da53 (diff) | |
download | Mana-a3beebb0a5b900d70e44b96e4679621dc9fd95f5.tar.gz Mana-a3beebb0a5b900d70e44b96e4679621dc9fd95f5.tar.bz2 Mana-a3beebb0a5b900d70e44b96e4679621dc9fd95f5.tar.xz Mana-a3beebb0a5b900d70e44b96e4679621dc9fd95f5.zip |
Fix bug in showing links and user defined colors in chat box
-rw-r--r-- | src/gui/browserbox.cpp | 191 | ||||
-rw-r--r-- | src/gui/browserbox.h | 6 | ||||
-rw-r--r-- | src/gui/chat.cpp | 1 |
3 files changed, 113 insertions, 85 deletions
diff --git a/src/gui/browserbox.cpp b/src/gui/browserbox.cpp index 51cc7fb3..168708ad 100644 --- a/src/gui/browserbox.cpp +++ b/src/gui/browserbox.cpp @@ -34,6 +34,7 @@ BrowserBox::BrowserBox(unsigned int mode): mMode = mode; setOpaque(true); setHighlightMode(BOTH); + mUseLinksAndUserColors = true; mSelectedLink = -1; setFocusable(true); addMouseListener(this); @@ -80,6 +81,11 @@ void BrowserBox::setHighlightMode(unsigned int highMode) { mHighMode = highMode; } + +void BrowserBox::disableLinksAndUserColors() +{ + mUseLinksAndUserColors = false; +} void BrowserBox::addRow(const std::string& row) { @@ -87,43 +93,55 @@ void BrowserBox::addRow(const std::string& row) std::string newRow; BROWSER_LINK bLink; int idx1, idx2, idx3; - - // Check for links in format "@@link|Caption@@" - idx1 = tmp.find("@@"); - while (idx1 >= 0) - { - idx2 = tmp.find("|", idx1); - idx3 = tmp.find("@@", idx2); - bLink.link = tmp.substr(idx1 + 2, idx2 - (idx1 + 2)); - bLink.caption = tmp.substr(idx2 + 1, idx3 - (idx2 + 1)); - bLink.y1 = mTextRows.size() * browserFont->getHeight(); - bLink.y2 = bLink.y1 + browserFont->getHeight(); - - newRow += tmp.substr(0, idx1); - - std::string tmp2 = newRow; - idx1 = tmp2.find("##"); + + // Use links and user defined colors + if (mUseLinksAndUserColors) + { + // Check for links in format "@@link|Caption@@" + idx1 = tmp.find("@@"); while (idx1 >= 0) { - tmp2.erase(idx1, 3); + idx2 = tmp.find("|", idx1); + idx3 = tmp.find("@@", idx2); + bLink.link = tmp.substr(idx1 + 2, idx2 - (idx1 + 2)); + bLink.caption = tmp.substr(idx2 + 1, idx3 - (idx2 + 1)); + bLink.y1 = mTextRows.size() * browserFont->getHeight(); + bLink.y2 = bLink.y1 + browserFont->getHeight(); + + newRow += tmp.substr(0, idx1); + + std::string tmp2 = newRow; idx1 = tmp2.find("##"); - } - bLink.x1 = browserFont->getWidth(tmp2) - 1; - bLink.x2 = bLink.x1 + browserFont->getWidth(bLink.caption) + 1; + while (idx1 >= 0) + { + tmp2.erase(idx1, 3); + idx1 = tmp2.find("##"); + } + bLink.x1 = browserFont->getWidth(tmp2) - 1; + bLink.x2 = bLink.x1 + browserFont->getWidth(bLink.caption) + 1; - mLinks.push_back(bLink); + mLinks.push_back(bLink); - newRow += "##L" + bLink.caption; + newRow += "##L" + bLink.caption; - tmp.erase(0, idx3 + 2); - if(tmp != "") - { - newRow += "##P"; + tmp.erase(0, idx3 + 2); + if(tmp != "") + { + newRow += "##P"; + } + idx1 = tmp.find("@@"); } - idx1 = tmp.find("@@"); + + newRow += tmp; + } + + // Don't use links and user defined colors + else + { + newRow = row; } - newRow += tmp; + newRow == (newRow == "" ? " " : newRow); mTextRows.push_back(newRow); // Auto size mode @@ -132,7 +150,7 @@ void BrowserBox::addRow(const std::string& row) std::string plain = newRow; for (idx1 = plain.find("##"); idx1 >= 0; idx1 = plain.find("##")) plain.erase(idx1, 3); - + // Adjust the BrowserBox size int w = browserFont->getWidth(plain); if (w > getWidth()) @@ -225,67 +243,70 @@ void BrowserBox::draw(gcn::Graphics* graphics) for (j = 0; j < row.size(); j++) { - // Check for color change in format "##x", x = [L,P,0..9] - if ((row.at(j) == '#') && (row.at(j + 1) == '#')) + if (mUseLinksAndUserColors || (!mUseLinksAndUserColors && (j == 0))) { - switch (row.at(j + 2)) + // Check for color change in format "##x", x = [L,P,0..9] + if ((row.at(j) == '#') && (row.at(j + 1) == '#')) { - case 'L': // Link color - prevColor = selColor; - selColor = LINK; - break; - case 'P': // Previous color - selColor = prevColor; - break; - case '1': - prevColor = selColor; - selColor = RED; - break; - case '2': - prevColor = selColor; - selColor = GREEN; - break; - case '3': - prevColor = selColor; - selColor = BLUE; - break; - case '4': - prevColor = selColor; - selColor = ORANGE; - break; - case '5': - prevColor = selColor; - selColor = YELLOW; - break; - case '6': - prevColor = selColor; - selColor = PINK; - break; - case '7': - prevColor = selColor; - selColor = PURPLE; - break; - case '8': - prevColor = selColor; - selColor = GRAY; - break; - case '9': - prevColor = selColor; - selColor = BROWN; - break; - case '0': - default: - prevColor = selColor; - selColor = BLACK; - } - j += 3; + switch (row.at(j + 2)) + { + case 'L': // Link color + prevColor = selColor; + selColor = LINK; + break; + case 'P': // Previous color + selColor = prevColor; + break; + case '1': + prevColor = selColor; + selColor = RED; + break; + case '2': + prevColor = selColor; + selColor = GREEN; + break; + case '3': + prevColor = selColor; + selColor = BLUE; + break; + case '4': + prevColor = selColor; + selColor = ORANGE; + break; + case '5': + prevColor = selColor; + selColor = YELLOW; + break; + case '6': + prevColor = selColor; + selColor = PINK; + break; + case '7': + prevColor = selColor; + selColor = PURPLE; + break; + case '8': + prevColor = selColor; + selColor = GRAY; + break; + case '9': + prevColor = selColor; + selColor = BROWN; + break; + case '0': + default: + prevColor = selColor; + selColor = BLACK; + } + j += 3; - if (j == row.size()) - { - break; + if (j == row.size()) + { + break; + } } + graphics->setColor(gcn::Color(selColor)); } - graphics->setColor(gcn::Color(selColor)); // Check for line separators in format "---" if ((j <= 3) && (row.at(j) == '-') && (row.at(j + 1) == '-') && diff --git a/src/gui/browserbox.h b/src/gui/browserbox.h index 45f5b25f..81771289 100644 --- a/src/gui/browserbox.h +++ b/src/gui/browserbox.h @@ -67,6 +67,11 @@ class BrowserBox : public gcn::Widget, public gcn::MouseListener void setHighlightMode(unsigned int highMode); /** + * Disable links & user defined colors to be used in chat input. + */ + void disableLinksAndUserColors(); + + /** * Adds a text row to the browser. */ void addRow(const std::string& row); @@ -138,6 +143,7 @@ class BrowserBox : public gcn::Widget, public gcn::MouseListener unsigned int mMode; unsigned int mHighMode; bool mOpaque; + bool mUseLinksAndUserColors; int mSelectedLink; static int instances; /**< Number of Window instances */ diff --git a/src/gui/chat.cpp b/src/gui/chat.cpp index c02f5160..b3e072a2 100644 --- a/src/gui/chat.cpp +++ b/src/gui/chat.cpp @@ -46,6 +46,7 @@ ChatWindow::ChatWindow(const std::string &logfile): textOutput = new BrowserBox(BrowserBox::AUTO_WRAP); textOutput->setOpaque(false); + textOutput->disableLinksAndUserColors(); scrollArea = new ScrollArea(textOutput); scrollArea->setPosition( scrollArea->getBorderSize(), scrollArea->getBorderSize()); |