[Qt/qml]程序之外显示的弹幕

/ 44,273评论 / 217472阅读 / 4点赞

前几天课设做个聊天系统,顺便实现了这个在程序外显示弹幕作为消息提示的功能,这里记录一下怎么搞。

效果

思路

实操

import QtQuick 2.3
import QtQuick.Controls 2.5
//窗口
ApplicationWindow  {
    id:root
    property string str: "我的洛天依"  //弹幕文本内容
    width: 300
    height: 40

    flags:  Qt.FramelessWindowHint  //去掉窗口标题栏
    color:"#00000000"   //设置背景透明

    Rectangle {     //使用矩形包裹Text是为了在Text外面可以增加圆角矩形边框效果
        anchors.fill: parent
        border.width: 1     //设置边框
        border.color: "#66ccff"
        color:"#00000000"
        radius: 20          //边框圆角
        clip: true          //超出矩形范围的内容隐藏

        Text {      //弹幕文本
            anchors.fill: parent
            text: str
            font.bold: true
            font.pointSize: 15
            color: "#66ccff"
            style: Text.Outline     //设置文本样式,在字体轮廓加一层styleColor指定的颜色边缘,防止背景导致文本不明显
            styleColor: "#fff"
            horizontalAlignment: Text.AlignHCenter  //居中
            verticalAlignment:   Text.AlignVCenter
            clip: true
        }
    }
}
import QtQuick
import QtQuick.Window 2.3
import QtQuick.Controls 2.5

Window {
    id:mainWin
    width: 700
    height: 500
    visible: true
    title: qsTr("MimicryChat")

    //添加弹幕
    function addBarrage(in_str) {
        var newCom = Qt.createComponent("Barrage.qml");   //创建弹幕窗口
        var newWin = newCom.createObject();
        newWin.x   = 200;
        newWin.y   = Math.random() * 900;   //随机竖直位置
        newWin.str = in_str;   //设置弹幕文本
        newWin.show();         //显示弹幕窗口

        //设置定时控制器
        let timer = Qt.createQmlObject("import QtQuick 2.14; Timer {}", mainWin);
        timer.interval = 20;    //执行间隔时间(单位ms)
        timer.repeat = true;    //重复执行
        timer.triggered.connect(function() {  //执行内容
            if(newWin.x < 1700) {  //如果没到右边缘就移动2个像素点
                newWin.x += 2;
            } else {
                timer.stop();      //到达右边缘,则停止定时控制器,并销毁弹幕
                newWin.close();
            }
        });
        timer.start();   //启动定时器
    }
    Rectangle {   //主窗口背景颜色
        anchors.fill: parent
        color: "#dde8fc"
        radius: 20
    }
    Button {
        width:100
        height: 40
        text:"发送弹幕"
        anchors.bottom: parent.bottom
        anchors.bottomMargin: 10
        //水平居中
        anchors.horizontalCenter: parent.horizontalCenter
        onClicked: {
            addBarrage("嘿嘿,我的洛天依");
        }
    }
}

问题

  1. Danrxxu说道:

    Привет, друзья!
    Мы изготавливаем дипломы психологов, юристов, экономистов и прочих профессий.
    hpconsultants.nl/2024/07/08/купить-диплом-фельдшера
    Окажем помощь!.

  2. DominicHOr说道:

    pharmacies in mexico that ship to usa: mexican drugstore online – mexico drug stores pharmacies

  3. RichardMonge说道:

    http://mexicandeliverypharma.com/# pharmacies in mexico that ship to usa

  4. Oh my goodness! Awesome article dude! Thanks, However I am having troubles with your RSS.
    I don’t know the reason why I can’t subscribe to it.

    Is there anyone else getting the same RSS problems?
    Anybody who knows the answer can you kindly respond? Thanks!!

  5. NelsonSaIlk说道:

    mexican online pharmacies prescription drugs: best online pharmacies in mexico – mexican pharmaceuticals online

  6. Lazrbal说道:

    Здравствуйте!
    Мы изготавливаем дипломы любой профессии по приятным ценам.
    formulaf1.ru/kupit-diplom-bez-posrednikov-legko-i-bezopasno

  7. IgnacioWease说道:

    Platini is a legendary Juventus https://juventus.michel-platini.com playmaker who won the Golden Boot three times.

  8. ManuelReuro说道:

    Karim Benzema https://al-ittihad.karim-benzema-fr.net has left Real Madrid to join Al Ittihad for a record fee of €100 million – the biggest transfer in the history of the Saudi Premier League.

  9. Justindwels说道:

    You’ll learn about Duncan’s https://san-antonio-spurs.timduncan-fr.com contributions to establishing the Spurs as one of the greatest franchises in NBA history.

  10. Waynetar说道:

    п»їbest mexican online pharmacies: buying prescription drugs in mexico online – purple pharmacy mexico price list

  11. Dnrtmvl说道:

    Добрый день!
    Заказать документ ВУЗа вы имеете возможность у нас в столице.
    ast-diplom24.ru/kupit-diplom-vracha
    Успешной учебы!

  12. DominicHOr说道:

    mexican border pharmacies shipping to usa: п»їbest mexican online pharmacies – mexico drug stores pharmacies

  13. Arnoldscava说道:

    medication from mexico pharmacy buying from online mexican pharmacy mexican pharmacy

  14. BomesMix说道:

    Lorem Ipsum has been the industry’s standard dummy text https://march.cl/finox of type and scrambled it to make a type specimen book.

  15. RichardMonge说道:

    https://mexicandeliverypharma.online/# buying prescription drugs in mexico online

  16. NelsonSaIlk说道:

    reputable mexican pharmacies online: mexico drug stores pharmacies – buying prescription drugs in mexico

  17. Sazrbps说道:

    Привет!
    Мы изготавливаем дипломы любых профессий по выгодным ценам. Цена зависит от выбранной специальности, года выпуска и образовательного учреждения. Стараемся поддерживать для клиентов адекватную политику тарифов. Для нас важно, чтобы документы были доступны для подавляющей массы наших граждан.
    easiestbookmarks.com/story17167626/купить-диплом-парикмахера

  18. Waynetar说道:

    purple pharmacy mexico price list: pharmacies in mexico that ship to usa – п»їbest mexican online pharmacies

  19. DominicHOr说道:

    mexican mail order pharmacies: pharmacies in mexico that ship to usa – reputable mexican pharmacies online

  20. NelsonSaIlk说道:

    п»їbest mexican online pharmacies: mexican mail order pharmacies – mexican border pharmacies shipping to usa

  21. DominicHOr说道:

    pharmacies in mexico that ship to usa: mexico drug stores pharmacies – buying prescription drugs in mexico online

  22. Lazradg说道:

    Привет, друзья!
    Мы изготавливаем дипломы психологов, юристов, экономистов и любых других профессий по выгодным ценам.
    make-coin.ru/legkiy-sposob-poluchit-diplom-onlayn

  23. Trefmae说道:

    Привет!
    Всё о покупке аттестата о среднем образовании: полезные советы
    theplaygamepicks.com/диплом-техникума-где-и-как-купить
    Рады оказать помощь!.

  24. Stevenelogy说道:

    Strasbourg FC is a famous French https://strasbourg.patrick-vieira.com football club whose history is closely linked to the legendary footballer Patrick Vieira.

  25. RandyThorn说道:

    Find out how Jude Bellingham https://real-madrid.jude-bellingham.net became a key player for Real Madrid, moving from Birmingham City’s academy to the prominence of world football.

  26. PabloClogy说道:

    Discover the history https://france.volleyball-fr.com the achievements and prospects for the development of volleyball in France, from the first steps to international triumphs and plans for the future.

  27. Trefmza说道:

    Здравствуйте!
    Узнайте стоимость диплома высшего и среднего образования и процесс получения
    theplaygamepicks.com/диплом-техникума-где-и-как-купить
    Поможем вам всегда!.

  28. Waynetar说道:

    mexico drug stores pharmacies: best online pharmacies in mexico – best online pharmacies in mexico

  29. RichardMonge说道:

    https://mexicandeliverypharma.online/# mexico drug stores pharmacies

  30. BomesMix说道:

    Lorem Ipsum has been the industry’s standard dummy text https://tascaisa.es/kmugu of type and scrambled it to make a type specimen book.

  31. Waynetar说道:

    best online pharmacies in mexico: mexican online pharmacies prescription drugs – medicine in mexico pharmacies

  32. DominicHOr说道:

    best online pharmacies in mexico: best online pharmacies in mexico – mexican online pharmacies prescription drugs

  33. Mazrgix说道:

    Привет!
    Диплом вуза купить официально с упрощенным обучением в Москве
    mandiplomik.ru

  34. RichardMonge说道:

    https://mexicandeliverypharma.com/# buying prescription drugs in mexico

  35. RichardMonge说道:

    https://mexicandeliverypharma.com/# mexican border pharmacies shipping to usa

  36. DominicHOr说道:

    mexican online pharmacies prescription drugs: mexican pharmaceuticals online – mexican online pharmacies prescription drugs

  37. Uazrslr说道:

    Привет, друзья!
    Где приобрести диплом специалиста?
    http://www.dizalty.com/read-blog/67606

  38. NelsonSaIlk说道:

    buying prescription drugs in mexico: medication from mexico pharmacy – buying from online mexican pharmacy

  39. Lazralm说道:

    Здравствуйте!
    Мы изготавливаем дипломы любой профессии по выгодным ценам.
    newsbig.raidersfanteamshop.com/poleznye-sovety-po-priobreteniu-diploma-v-internete

  40. Tooft说道:

    Many organizations have IT departments that need in-house web designers and developers to design the layout of websites using HTML and other types of code, conduct website testing, and ensure websites are up to date and accessible. If you’re interested in being your own boss, freelance web design may be a rewarding option. Webflow is another website designer tool that doesn’t require coding to build websites. If you don’t want to get involved in coding, Webflow is one of the tremendous website-building platforms. Also, you can add site elements using the drag-and-drop feature to make a customized design layout. Below, we’ve listed the 8 best project management software for web designers after thorough research. And we made sure to choose the software that is easy to use, takes less time to learn, and will not come in the way of the designing process.
    https://urlscan.io/result/36e4141b-4e0d-4b64-8d64-7d85ee2709a5/loading
    Mountain IT (MIT) Solutions is a leading U.S Information Technology and management consulting firm that partners with some of the world’s most successful companies to achieve their strategic. We value honesty, integrity, and enthusiasm and we care about our community. We tailor the documents closely with the industry standards for quality such as Software Engineering Institute (SEI) and ISO standards. We helped Springer Publishing optimize their operations with a 5 year IT strategy that saw return in their first 6 months with Power Consulting. Springer Publishing’s rapid business success needed an IT operation that was scalable to their growth. In our partnership with Springer, we helped them with location moves, IT strategy, and managing downtime. If you are dedicated to your work and committed to continuous learning and growth you will feel right at home with us. We offer a unique work environment that promotes individual growth and rewards individual and team performance.

  41. Dnrtsfe说道:

    Добрый день!
    Купить документ института вы имеете возможность у нас.
    asxdiplomik.com/kupit-diplom-o-srednem-obrazovanii
    Успешной учебы!

  42. Manrzoe说道:

    Добрый день!
    Заказать документ университета
    ast-diploms24.ru/kupit-diplom-krasnoyarsk

  43. Xazrgev说道:

    Привет, друзья!
    Узнайте стоимость диплома высшего и среднего образования и процесс получения
    arusak-diploms-srednee.ru/svidetelstvo-o-brake

  44. DominicHOr说道:

    mexico drug stores pharmacies: medicine in mexico pharmacies – mexico drug stores pharmacies

  45. Waynetar说道:

    buying prescription drugs in mexico online: mexican drugstore online – buying prescription drugs in mexico online

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注