1 实现效果:
2 实现原理
代码主要参考自《Qt(QLabel)实现滚动字幕》 http://blog.csdn.net/u011417605/article/details/51211853
但这个实现方式只能以一个英文字母的宽度进行步进,不适用文字为中文的情况,于是我修改了一下:
qtextscroll.h:
class QTextScroll : public QLabel
{
Q_OBJECT
public:
QTextScroll(QWidget* parent);
void showScrollText(QString text);
private:
int stepWidth;
int stepTime;
int curIndex;
QString showText;
QTimer *scrollTimer;
private slots:
void updateIndex();
protected:
void paintEvent(QPaintEvent *event);
};
qtextscroll.cpp:
QTextScroll::QTextScroll(QWidget *parent):
QLabel(parent)
{
stepTime = 20;
stepWidth = 1;
curIndex = 0;
scrollTimer = new QTimer();
connect(scrollTimer, SIGNAL(timeout()), this, SLOT(updateIndex()));
}
void QTextScroll::showScrollText(QString text)
{
if(scrollTimer->isActive())
scrollTimer->stop();
showText = text;
scrollTimer->start(stepTime);
}
void QTextScroll::updateIndex()
{
update();
curIndex++;
if (curIndex*stepWidth > width())
curIndex = 0;
}
void QTextScroll::paintEvent(QPaintEvent *event)
{
QWidget::paintEvent(event);
QPainter painter(this);
painter.drawText(0-stepWidth*curIndex, 100, showText);
painter.drawText(width() - stepWidth*curIndex, 100, showText.left(curIndex));
}
在原博主的基础上进行了细微修改,基本原理:painter的坐标可以超出控件边缘,而超出边缘的文字,界面上是看不到的,从而实现这样一个滚动字幕的效果。
实现方式我全都放在上面啦,另写了个实现demo供小伙伴们研究。
http://download.csdn.net/download/birdman_1992/10003611