Added support for showing the Stars on the DiveTable

For the stars on the dive table I had to rework a bit my
StarRating widget, because it used a pixmap for each widget
that were created. Not it uses only 2 pixmaps: the active
and inactive ones.

A new file was created named modeldelegates(h, cpp) that
should hold all delegates of the models. For the GTK / C
folks, a 'Delegate' ia s way to bypass the default behavior
of the view that's displaying the data.

I also added the code to display the stars if no delegate
is set ( good for debugging. )

Signed-off-by: Tomaz Canabrava <tcanabrava@kde.org>
This commit is contained in:
Tomaz Canabrava 2013-04-27 12:27:27 -03:00
parent 1d0d42f861
commit 2f4d6bbe53
9 changed files with 115 additions and 59 deletions

View file

@ -5,32 +5,29 @@
#include <QDebug>
#include <QMouseEvent>
QPixmap* StarWidget::activeStar = 0;
QPixmap* StarWidget::inactiveStar = 0;
QPixmap StarWidget::starActive()
{
return (*activeStar);
}
QPixmap StarWidget::starInactive()
{
return (*inactiveStar);
}
int StarWidget::currentStars() const
{
return current;
}
void StarWidget::enableHalfStars(bool enabled)
{
halfStar = enabled;
update();
}
bool StarWidget::halfStarsEnabled() const
{
return halfStar;
}
int StarWidget::maxStars() const
{
return stars;
}
void StarWidget::mouseReleaseEvent(QMouseEvent* event)
{
int starClicked = event->pos().x() / IMG_SIZE + 1;
if (starClicked > stars)
starClicked = stars;
if (starClicked > TOTALSTARS)
starClicked = TOTALSTARS;
if (current == starClicked)
current -= 1;
@ -45,10 +42,10 @@ void StarWidget::paintEvent(QPaintEvent* event)
QPainter p(this);
for(int i = 0; i < current; i++)
p.drawPixmap(i * IMG_SIZE + SPACING, 0, activeStar);
p.drawPixmap(i * IMG_SIZE + SPACING, 0, starActive());
for(int i = current; i < stars; i++)
p.drawPixmap(i * IMG_SIZE + SPACING, 0, inactiveStar);
for(int i = current; i < TOTALSTARS; i++)
p.drawPixmap(i * IMG_SIZE + SPACING, 0, starInactive());
}
void StarWidget::setCurrentStars(int value)
@ -58,27 +55,25 @@ void StarWidget::setCurrentStars(int value)
Q_EMIT valueChanged(current);
}
void StarWidget::setMaximumStars(int maximum)
{
stars = maximum;
update();
}
StarWidget::StarWidget(QWidget* parent, Qt::WindowFlags f):
QWidget(parent, f),
stars(5),
current(0),
halfStar(false)
current(0)
{
QSvgRenderer render(QString(":star"));
QPixmap renderedStar(IMG_SIZE, IMG_SIZE);
if(!activeStar){
activeStar = new QPixmap();
QSvgRenderer render(QString(":star"));
QPixmap renderedStar(IMG_SIZE, IMG_SIZE);
renderedStar.fill(Qt::transparent);
QPainter painter(&renderedStar);
renderedStar.fill(Qt::transparent);
QPainter painter(&renderedStar);
render.render(&painter, QRectF(0, 0, IMG_SIZE, IMG_SIZE));
activeStar = renderedStar;
inactiveStar = grayImage(&renderedStar);
render.render(&painter, QRectF(0, 0, IMG_SIZE, IMG_SIZE));
(*activeStar) = renderedStar;
}
if(!inactiveStar){
inactiveStar = new QPixmap();
(*inactiveStar) = grayImage(activeStar);
}
}
QPixmap StarWidget::grayImage(QPixmap* coloredImg)
@ -86,17 +81,20 @@ QPixmap StarWidget::grayImage(QPixmap* coloredImg)
QImage img = coloredImg->toImage();
for (int i = 0; i < img.width(); ++i) {
for (int j = 0; j < img.height(); ++j) {
QRgb col = img.pixel(i, j);
if (!col)
QRgb rgb = img.pixel(i, j);
if (!rgb)
continue;
int gray = QColor(Qt::darkGray).rgb();
QColor c(rgb);
int gray = (c.red() + c.green() + c.blue()) / 3;
img.setPixel(i, j, qRgb(gray, gray, gray));
}
}
return QPixmap::fromImage(img);
}
QSize StarWidget::sizeHint() const
{
return QSize(IMG_SIZE * stars + SPACING * (stars-1), IMG_SIZE);
return QSize(IMG_SIZE * TOTALSTARS + SPACING * (TOTALSTARS-1), IMG_SIZE);
}