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

/ 44,197评论 / 216891阅读 / 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. Jamesjer说道:

    doxycycline rx: doxycycline 100mg coupon – doxycycline tablet price in india

  2. Jamesjer说道:

    can i buy amoxicillin over the counter: amoxicillin 500 mg capsule – how to get amoxicillin over the counter

  3. Dnrtnot说道:

    Привет, друзья!
    Заказать документ ВУЗа вы имеете возможность в нашей компании в Москве.
    diploms-x.com/kupit-diplom-rostov-na-donu
    Успешной учебы!

  4. Биоптрон说道:

    Just want to say your article is as surprising.
    The clarity in your post is simply excellent and i could assume you’re
    knowledgeable on this subject. Fine along with your permission allow me to grasp your feed to keep up to date with imminent post.

    Thank you a million and please carry on the rewarding work.

  5. MichaelDrare说道:

    The fascinating story of Ja Morant’s https://spain.atletico-madrid-ar.com meteoric rise, from status from rookie to leader of the Memphis Grizzlies and rising NBA superstar.

  6. DavidFex说道:

    The future football star Shabab Al-Ahly https://dubai.shabab-al-ahli-ar.com was born in Dubai in 2000. From a young age, he showed exceptional football abilities and joined the youth academy of one of the UAE’s leading clubs, Shabab Al-Ahly.

  7. JamesUname说道:

    Galatasaray https://turkey.galatasaray-ar.com is one of the most famous football clubs in Turkiye, with a glorious and eventful history.

  8. BomesMix说道:

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

  9. GeorgeViarl说道:

    In the world of football, Atletico Madrid https://spain.atletico-madrid-ar.com has long been considered the second most important club in Spain after the dominant, Real Madrid.

  10. Uazrspq说道:

    Привет!
    Где купить диплом по необходимой специальности?
    usa.life/read-blog/62808

  11. Diplomi_xrol说道:

    Здравствуйте!
    Приобрести документ ВУЗа вы имеете возможность у нас в Москве.
    diplomasx.com/kupit-diplom-bakalavra-ili-specialista 

  12. Lazrxuj说道:

    Здравствуйте!
    Мы изготавливаем дипломы любой профессии по приятным ценам.
    good-serial.ru/2024/06/poluchite-diplom-bez-lishnih-ozhidaniy/

  13. Mazrchn说道:

    Привет, друзья!
    Вопросы и ответы: можно ли быстро купить диплом старого образца?
    pumasoccershoesfans.com/read-blog/2126_pravilno-pokupaem-diplom-v-internete-avtorskij-obzor.html?mode=day

  14. Dnrtdxy说道:

    Привет, друзья!
    Приобрести документ института можно у нас.
    diploms-x24.ru/kupit-diplom-magistra
    Хорошей учебы!

  15. Jamesjer说道:

    cost of amoxicillin 30 capsules: generic amoxicillin cost – purchase amoxicillin 500 mg

  16. Mazrrmq说道:

    Привет!
    Официальная покупка диплома вуза с сокращенной программой в Москве
    http://www.manchestercityclubs.com/read-blog/256_kak-kupit-nedorogo-neotlichimyj-ot-podlinnika-diplom-v-internete.html?mode=night

  17. 슬롯说道:

    피망 뉴 베가스
    Hongzhi 황제는 그의 행정에 부지런했지만 대부분 공무원의 영향을 받았습니다.

  18. Dnrtinp说道:

    Здравствуйте!
    Приобрести документ о получении высшего образования вы сможете у нас.
    asxdiplomik24.ru/kupit-diplom-nizhnij-novgorod
    Успешной учебы!

  19. Dnrtmmv说道:

    Добрый день!
    Заказать документ о получении высшего образования можно в нашей компании.
    ast-diplomy24.ru/kupit-diplom-nizhnij-novgorod
    Успехов в учебе!

  20. Dnrtlgv说道:

    Здравствуйте!
    Купить документ о получении высшего образования вы имеете возможность в нашем сервисе.
    ast-diploms.com/kupit-diplom-omsk
    Успехов в учебе!

  21. Uazrcvh说道:

    Привет, друзья!
    Заказать диплом о высшем образовании.
    gazony.com/club/user/2/blog/567/

  22. Xazrrat说道:

    Привет!
    Рекомендации по безопасной покупке диплома о высшем образовании
    arusak-diploms-srednee.ru/kupit-diplom-medicinskogo-uchilishha В 

  23. Manrema说道:

    Привет!
    Купить документ о получении высшего образования
    ast-diploms24.ru/kupit-diplom-rostov-na-donu

  24. Yrefxjp说道:

    Здравствуйте!
    Приобрести диплом любого ВУЗа.
    epistles.ru/blogs/1296/ѕолучите-?иплом-Ѕыстро-и-Ќадежно
    Хорошей учебы!

  25. Lazrctr说道:

    Привет!
    Мы изготавливаем дипломы любой профессии по приятным тарифам.
    openmotonews.ru/vash-diplom-byistro-i-nadezhno

  26. Trefhpn说道:

    Добрый день!
    Приобретение диплома ПТУ с сокращенной программой обучения в Москве
    nsibirsk.ru/forum/free/topic-24300.html
    Рады оказать помощь!.

  27. Danrghy说道:

    Добрый день!
    Мы готовы предложить дипломы любых профессий.
    gaysocial.gay/read-blog/79_vybiraem-nadezhnyj-internet-magazin-s-diplomami-i-attestatami.html?mode=day
    Поможем вам всегда!.

  28. Diplomi_cqol说道:

    Здравствуйте!
    Заказать документ о получении высшего образования вы сможете у нас в Москве.
    diploms-x.com/kupit-diplom-novosibirsk 

  29. Diplomi_agol说道:

    Привет, друзья!
    Приобрести документ о получении высшего образования можно в нашем сервисе.
    ast-diploms.com/kupit-diplom-s-registraciej 

  30. Diplomi_epol说道:

    Привет, друзья!
    Приобрести документ о получении высшего образования можно в нашей компании в столице.
    ast-diplomy.com/kupit-diplom-bakalavra-ili-specialista 

  31. Jamesjer说道:

    doxycycline over the counter uk: doxycycline price – doxycycline price australia

  32. Michaelphime说道:

    AC Milan https://italy.milan-ar.com is one of the most successful and decorated football clubs in the world.

  33. Charlesimify说道:

    Ремонт плоской кровли https://remontiruem-krovly.ru в Москве, цена работы за 1 м?. Прайс лист на работы под ключ, отзывы и фото.

  34. ThomasInace说道:

    http://amoxildelivery.pro/# amoxicillin 500 tablet

  35. ThomasEnawl说道:

    распечатка наклеек https://salavat-rik.ru

  36. StevenSof说道:

    Thai Company Directory https://thaicorporates.com List of companies and business information.

  37. Uazrwjy说道:

    Добрый день!
    Приобрести диплом университета.
    true.pahom.su/2024/07/07/4-e-klyuchevyh-gruppy-onlayn-magazinov-chto-prodayut-dokumenty.html

  38. Uazrubo说道:

    Здравствуйте!
    Заказать диплом о высшем образовании.
    http://www.indianhighcaste.com/read-blog/2081

  39. Uazrftk说道:

    Здравствуйте!
    Заказать диплом любого университета.
    ai.ceo/read-blog/147281

  40. Dnrtrah说道:

    Добрый день!
    Купить документ о получении высшего образования можно у нас.
    ast-diplomy.com/kupit-diplom-moskva
    Удачи!

  41. ThomasInace说道:

    http://amoxildelivery.pro/# amoxacillian without a percription

  42. Lazrusx说道:

    Добрый день!
    Мы изготавливаем дипломы любых профессий по приятным тарифам.
    suncityprinting.com/2024/06/30/купить-диплом-в-воткинске/

  43. Jamesjer说道:

    doxycycline cap tab 100mg: doxycycline online cheap – doxycycline drug

  44. ThomasInace说道:

    http://doxycyclinedelivery.pro/# doxycycline prescription uk

  45. BomesMix说道:

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

  46. Sazrclf说道:

    Привет!
    Мы изготавливаем дипломы любых профессий по приятным тарифам. Стоимость будет зависеть от определенной специальности, года получения и университета. Всегда стараемся поддерживать для заказчиков адекватную ценовую политику. Для нас важно, чтобы дипломы были доступны для большого количества наших граждан.
    formfinance.ru/obrazovanie-po-zaprosu-kak-kupit-diplom-tochno-otrazhayushhiy-tvoi-zhelaniya

  47. Diplomi_hkst说道:

    стоит ли покупать диплом о высшем образовании diploms-x.com .

  48. Diplomi_ufol说道:

    Здравствуйте!
    Заказать документ о получении высшего образования вы сможете в нашем сервисе.
    ast-diplomas.com/kupit-diplom-chelyabinsk 

发表回复

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