Qt(QLabel)实现滚动字幕

滚动字幕,也叫跑马,就是动态显示一行字符。前面实现是使用QTimer控制,直接在槽函数中截取字符串进行显示,只控制字符串在控件的一端显示,超出控件的部分并没有从控件的另一端循环显示出来。于是我重新实现了一种方法,或者说完善了前面的不足吧。

使用QTimer控制显示的节奏,在paintEvent中进行截取显示。从左端被截掉的部分会从右端显示出来。

难点在于,我们需要依据控件的宽度,控制字符串的显示位置。所以我们还需要知道每个字符的宽度。QWidget提供了方法可以计算字符的宽度,QFontMetrics类可以计算字符或者字符串的宽度,注意是宽度,而不是长度。

实现效果:

计算一个字符所占的宽度:

fontMetrics().width("a");//每个字符的宽度

完整示例代码:

#ifndef TEXTTICKER_H
#define TEXTTICKER_H

#include <QtWidgets/QLabel>

class TextTicker : public QLabel
{
	Q_OBJECT

public:
	TextTicker(QWidget *parent = 0);
	~TextTicker();

protected:
	void paintEvent(QPaintEvent *event);
	void updateIndex();

private:
	int m_charWidth;
	int m_curIndex;
	QString m_showText;
};

#endif // TEXTTICKER_H
#include "textticker.h"
#include <QPainter>
#include <QTimer>

TextTicker::TextTicker(QWidget *parent)
	: QLabel(parent)
{
	setMinimumWidth(200);
	setMinimumHeight(40);

	m_curIndex = 0;//当前角码
	m_showText = "This is a textTicker Text!";//显示的文字
	m_charWidth = fontMetrics().width("a");//每个字符的宽度

	QTimer *timer = new QTimer(this);
	connect(timer, &QTimer::timeout, this, &TextTicker::updateIndex);
	timer->start(100);
}

TextTicker::~TextTicker()
{

}

void TextTicker::paintEvent(QPaintEvent *event)
{
	__super::paintEvent(event);
	QPainter painter(this);
	painter.drawText(0, 30, m_showText.mid(m_curIndex));
	painter.drawText(width() - m_charWidth*m_curIndex, 30, m_showText.left(m_curIndex));
}

void TextTicker::updateIndex()
{
	update();
	m_curIndex++;
	if (m_curIndex*m_charWidth > width())
		m_curIndex = 0;
}

交流QQ:1245178753

本文地址:http://blog.csdn.net/u011417605/article/details/51211853

源码下载:http://download.csdn.net/detail/u011417605/9498424

时间: 2024-10-28 21:13:06

Qt(QLabel)实现滚动字幕的相关文章

滚动字幕

1.Designer.cs代码 namespace FollCaption { partial class Form1 { /// <summary> /// 必需的设计器变量. /// </summary> private System.ComponentModel.IContainer components = null; /// <summary> /// 清理所有正在使用的资源. /// </summary> /// <param name=&

cocos2d-x利用CCClippingNode实现滚动字幕

这周单位要做一个人脸美化的项目,查资料遇到这位大牛的博客,地址如下:点击打开链接 我的代码也是在他的基础上进行修改的,但是他对图像的RGB三个通道平等调节,为了适应我的需求,我改成了针对三个通道分别调节.废话不多说,开始上源码 void ImageAdjust(Mat& src, Mat& dst, vector<double> low_in, vector<double> high_in, vector<double> low_out, vector&

制作由下向上的滚动字幕,字幕内容要求包含网站超级链接和图片超级链接, 使用鼠标移动事件控制字幕运动和停止。 2、在下拉列表框中设置五种以上颜色,选择颜色后, 滚动字幕背景色改变成相应颜色

<!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>    </head>    <!--        时间:2016-12-28        描述:1.制作由下向上的滚动字幕,字幕内容要求包含网站超级链接和图片超级链接,                   使用鼠标移动事件控制

使用UILabel实现滚动字幕移动效果

这个链接中的代码也实现了这种效果 https://github.com/cbpowell/MarqueeLabel 最终效果如下: 原理如下: 1. 获取文本 2. 计算文本宽度 3. 将这个Label放入ScrollView中 4. 将ScrollView的contentSize的宽度设置与文本宽度一致 5. 做动画 *6. 边缘的渐隐效果请使用带透明像素的PNG图片 // // RootViewController.m // // Copyright (c) 2014年 Y.X. All r

02 HTML 列表 块行元素 滚动字幕 文本图片锚点超链接 相对绝对URL 图片标记

定义列表 <div>和<span> 块元素和行内元素 网页颜色表示 滚动字幕标记 计算机进制 计算机编码介绍 超级链接 超级链接的标记<a></a>,双边标记,是行内元素 URL介绍 绝对URL和相对URL地址 相对URL地址:一般是用于链接本网站中的各个文件的路径. 其它常用的链接 锚点链接:实现在一个网页的不同部分进行跳转 图片标记 定义列表 定义列表的格式: <dl>        <dt>定义标题</dt>    

js原生 + jQuery实现页面滚动字幕

js原生/jQuery实现页面滚动字幕效果 17:45:49 在新闻列表或者文章列表信息等页面中很容易要求实现字幕滚动的效果,以下为简单的实现页面中滚动字幕的效果 1.jQuery实现页面滚动字幕效果 代码如下: <div class="box"> <ul class="list"> <li>这是滚动加载的第1条数据</li> <li>你猜猜这是第几条滚动加载的文字</li> <li>

C#-循环滚动字幕,timer,从左至右,从右至左,暂停---ShinePans

Lable的Left属性是可以更改的,但是 Right属性不可以更改,所以我们可以利用 这个特点做自加 自减运算 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using S

Android之如何用TextView实现滚动字幕的效果【跑马灯】

TextView 实现滚动字幕效果[跑马灯效果]: android:ellipsize="marquee"//可滚动,star(头部),middle(中部),end(尾部) 超出显示不下的内容用...代替, 实现条件 1.必须设置为单行显示,且TextView中的内容超过它的容纳范围, 2.TextView本身没有焦点,必须设置成可获取焦点 <TextView android:layout_width="100dp" android:layout_height

让视频编辑软件中的滚动字幕停下来的方法

我们在看电视电影等等影片时,总会看到结尾的字幕都是从下往上滚动,有的滚动到中间会停留一段时间,有的则是直接滚上去消失不见.那么在EDIUS中,如何做出滚动字幕停下来再滚走的效果呢?下面,小编给大家讲讲EDIUS滚动字幕的那些事. EDIUS滚动字幕停下来的方法如下: 1.单击时间线面板上的创建字幕按钮,在字幕轨T轨上输入文字上,字幕类型保持静止,然后单击保存: 2.在特效面板里,单击“字幕混合”前的小加号,显示全部的字幕特效: 3.根据需求选择拖入特效“飞入A”或“飞入B”到字幕上:“飞入A”是