Compare commits
5 Commits
77a9144837
...
5312071d1c
Author | SHA1 | Date | |
---|---|---|---|
|
5312071d1c | ||
|
432ccdca90 | ||
|
252e97f139 | ||
|
711e8dee5b | ||
|
8ff6e5811e |
@ -34,7 +34,7 @@ The device will scan for WiFi networks on boot. Once the list is displayed, you
|
||||
###### IRC commands
|
||||
| Command | Description |
|
||||
| --------------- | --------------------------- |
|
||||
| `/debug` | Show hardware information |
|
||||
| `/info` | Show hardware information |
|
||||
| `/me <message>` | Send an ACTION message |
|
||||
| `/nick <new>` | Change your NICK on IRC |
|
||||
| `/raw <data>` | Send RAW data to the server |
|
||||
@ -98,4 +98,4 @@ The device will scan for WiFi networks on boot. Once the list is displayed, you
|
||||
|
||||
___
|
||||
|
||||
###### Mirrors for this repository: [acid.vegas](https://git.acid.vegas/acid-drop) • [SuperNETs](https://git.supernets.org/acidvegas/acid-drop) • [GitHub](https://github.com/acidvegas/acid-drop) • [GitLab](https://gitlab.com/acidvegas/acid-drop) • [Codeberg](https://codeberg.org/acidvegas/acid-drop)
|
||||
###### Mirrors for this repository: [acid.vegas](https://git.acid.vegas/acid-drop) • [SuperNETs](https://git.supernets.org/acidvegas/acid-drop) • [GitHub](https://github.com/acidvegas/acid-drop) • [GitLab](https://gitlab.com/acidvegas/acid-drop) • [Codeberg](https://codeberg.org/acidvegas/acid-drop)
|
||||
|
46
src/main.ino
46
src/main.ino
@ -555,18 +555,31 @@ int calculateLinesRequired(String message) {
|
||||
int linesRequired = 1;
|
||||
int lineWidth = 0;
|
||||
|
||||
for (char c : message) {
|
||||
lineWidth += tft.textWidth(String(c));
|
||||
if (lineWidth > SCREEN_WIDTH) {
|
||||
linesRequired++;
|
||||
lineWidth = tft.textWidth(String(c));
|
||||
for (unsigned int i = 0; i < message.length(); i++) {
|
||||
char c = message[i];
|
||||
if (c == '\x03') {
|
||||
// Skip color code sequences from calculate instead of render to solve nick overlay issue
|
||||
while (i < message.length() && (isdigit(message[i + 1]) || message[i + 1] == ',')) {
|
||||
i++;
|
||||
if (isdigit(message[i + 1])) {
|
||||
i++;
|
||||
}
|
||||
if (message[i] == ',' && isdigit(message[i + 1])) {
|
||||
i++;
|
||||
}
|
||||
}
|
||||
} else if (c != '\x02' && c != '\x0F' && c != '\x1F') { // Ignore other formatting codes as they are not as prevalent
|
||||
lineWidth += tft.textWidth(String(c));
|
||||
if (lineWidth > SCREEN_WIDTH) {
|
||||
linesRequired++;
|
||||
lineWidth = tft.textWidth(String(c));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return linesRequired;
|
||||
}
|
||||
|
||||
|
||||
void displayCenteredText(String text) {
|
||||
tft.fillScreen(TFT_BLACK);
|
||||
tft.setTextDatum(MC_DATUM);
|
||||
@ -872,10 +885,29 @@ void displayLines() {
|
||||
tft.fillRect(0, STATUS_BAR_HEIGHT, SCREEN_WIDTH, SCREEN_HEIGHT - STATUS_BAR_HEIGHT - INPUT_LINE_HEIGHT, TFT_BLACK);
|
||||
|
||||
int cursorY = STATUS_BAR_HEIGHT;
|
||||
int totalLinesHeight = 0;
|
||||
std::vector<int> lineHeights;
|
||||
|
||||
// Calculate total height needed for all lines
|
||||
for (const String& line : lines) {
|
||||
int lineHeight = calculateLinesRequired(line) * CHAR_HEIGHT;
|
||||
lineHeights.push_back(lineHeight);
|
||||
totalLinesHeight += lineHeight;
|
||||
}
|
||||
|
||||
// Remove lines from the top if they exceed the screen height
|
||||
while (totalLinesHeight > SCREEN_HEIGHT - STATUS_BAR_HEIGHT - INPUT_LINE_HEIGHT) {
|
||||
totalLinesHeight -= lineHeights.front();
|
||||
lines.erase(lines.begin());
|
||||
mentions.erase(mentions.begin());
|
||||
lineHeights.erase(lineHeights.begin());
|
||||
}
|
||||
|
||||
// Render each line
|
||||
for (size_t i = 0; i < lines.size(); ++i) {
|
||||
const String& line = lines[i];
|
||||
bool mention = mentions[i];
|
||||
|
||||
|
||||
tft.setCursor(0, cursorY);
|
||||
|
||||
if (line.startsWith("JOIN ")) {
|
||||
|
Loading…
Reference in New Issue
Block a user