mirror of
https://github.com/Chatterino/chatterino2.git
synced 2024-11-21 22:24:07 +01:00
made message backgrounds overflow into the scrollbar
This commit is contained in:
parent
416b2d0d74
commit
4f35d8854a
5 changed files with 12 additions and 12 deletions
|
@ -149,8 +149,8 @@ void MessageLayout::actuallyLayout(int width, MessageElement::Flags _flags)
|
|||
}
|
||||
|
||||
// Painting
|
||||
void MessageLayout::paint(QPainter &painter, int y, int messageIndex, Selection &selection,
|
||||
bool isLastReadMessage, bool isWindowFocused)
|
||||
void MessageLayout::paint(QPainter &painter, int width, int y, int messageIndex,
|
||||
Selection &selection, bool isLastReadMessage, bool isWindowFocused)
|
||||
{
|
||||
auto app = getApp();
|
||||
QPixmap *pixmap = this->m_buffer.get();
|
||||
|
@ -158,13 +158,11 @@ void MessageLayout::paint(QPainter &painter, int y, int messageIndex, Selection
|
|||
// create new buffer if required
|
||||
if (!pixmap) {
|
||||
#ifdef Q_OS_MACOS
|
||||
pixmap =
|
||||
new QPixmap(int(this->m_container.getWidth() * painter.device()->devicePixelRatioF()),
|
||||
int(this->m_container.getHeight() * painter.device()->devicePixelRatioF()));
|
||||
pixmap = new QPixmap(int(width * painter.device()->devicePixelRatioF()),
|
||||
int(width * painter.device()->devicePixelRatioF()));
|
||||
pixmap->setDevicePixelRatio(painter.device()->devicePixelRatioF());
|
||||
#else
|
||||
pixmap =
|
||||
new QPixmap(this->m_container.getWidth(), std::max(16, this->m_container.getHeight()));
|
||||
pixmap = new QPixmap(width, std::max(16, this->m_container.getHeight()));
|
||||
#endif
|
||||
|
||||
this->m_buffer = std::shared_ptr<QPixmap>(pixmap);
|
||||
|
|
|
@ -42,7 +42,7 @@ public:
|
|||
bool layout(int width, float m_scale, MessageElement::Flags flags);
|
||||
|
||||
// Painting
|
||||
void paint(QPainter &painter, int y, int messageIndex, Selection &selection,
|
||||
void paint(QPainter &painter, int width, int y, int messageIndex, Selection &selection,
|
||||
bool isLastReadMessage, bool isWindowFocused);
|
||||
void invalidateBuffer();
|
||||
void deleteBuffer();
|
||||
|
|
|
@ -174,7 +174,8 @@ void ThemeManager::actuallyUpdate(double hue, double multiplier)
|
|||
// this->messages.seperatorInner =
|
||||
|
||||
// Scrollbar
|
||||
this->scrollbars.background = getColor(0, sat, 0.94);
|
||||
this->scrollbars.background = splits.background;
|
||||
this->scrollbars.background.setAlphaF(qreal(0.4));
|
||||
this->scrollbars.thumb = getColor(0, sat, 0.80);
|
||||
this->scrollbars.thumbSelected = getColor(0, sat, 0.7);
|
||||
|
||||
|
|
|
@ -27,7 +27,8 @@
|
|||
#include <functional>
|
||||
#include <memory>
|
||||
|
||||
#define LAYOUT_WIDTH (this->width() - (this->scrollBar.isVisible() ? 16 : 4) * this->getScale())
|
||||
#define LAYOUT_WIDTH (this->width() - (this->scrollBar.isVisible() ? 16 : 2) * this->getScale())
|
||||
#define DRAW_WIDTH (this->width())
|
||||
#define SELECTION_RESUME_SCROLLING_MSG_THRESHOLD 3
|
||||
#define CHAT_HOVER_PAUSE_DURATION 400
|
||||
|
||||
|
@ -617,7 +618,7 @@ void ChannelView::drawMessages(QPainter &painter)
|
|||
isLastMessage = this->lastReadMessage.get() == layout;
|
||||
}
|
||||
|
||||
layout->paint(painter, y, i, this->selection, isLastMessage, windowFocused);
|
||||
layout->paint(painter, DRAW_WIDTH, y, i, this->selection, isLastMessage, windowFocused);
|
||||
|
||||
y += layout->getHeight();
|
||||
|
||||
|
|
|
@ -202,7 +202,7 @@ void Scrollbar::paintEvent(QPaintEvent *)
|
|||
int xOffset = mouseOver ? 0 : width() - int(4 * this->getScale());
|
||||
|
||||
QPainter painter(this);
|
||||
// painter.fillRect(rect(), this->themeManager->ScrollbarBG);
|
||||
painter.fillRect(rect(), this->themeManager->scrollbars.background);
|
||||
|
||||
// painter.fillRect(QRect(xOffset, 0, width(), this->buttonHeight),
|
||||
// this->themeManager->ScrollbarArrow);
|
||||
|
|
Loading…
Reference in a new issue