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

/ 24,996评论 / 141708阅读 / 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. Walteronerb说道:

    https://casinvietnam.shop/# casino tr?c tuy?n vi?t nam

  2. LarryGok说道:

    PBN sites
    We will establish a structure of PBN sites!

    Advantages of our self-owned blog network:

    We execute everything SO THAT GOOGLE DOES NOT comprehend THAT this is A PBN network!!!

    1- We obtain web domains from distinct registrars

    2- The principal site is hosted on a VPS server (VPS is fast hosting)

    3- Other sites are on distinct hostings

    4- We allocate a individual Google profile to each site with confirmation in Search Console.

    5- We make websites on WP, we do not utilise plugins with assistance from which Trojans penetrate and through which pages on your websites are produced.

    6- We refrain from reproduce templates and utilize only exclusive text and pictures

    We never work with website design; the client, if wished, can then edit the websites to suit his wishes

  3. LarryGok说道:

    PBN sites
    We shall create a network of private blog network sites!

    Advantages of our private blog network:

    We carry out everything so Google doesn’t comprehend that THIS IS A private blog network!!!

    1- We buy domains from separate registrars

    2- The leading site is hosted on a virtual private server (Virtual Private Server is fast hosting)

    3- The rest of the sites are on various hostings

    4- We designate a unique Google profile to each site with verification in Search Console.

    5- We make websites on WordPress, we do not utilise plugins with assistance from which malware penetrate and through which pages on your websites are established.

    6- We do not reproduce templates and utilise only exclusive text and pictures

    We do not work with website design; the client, if wanted, can then edit the websites to suit his wishes

  4. Walteronerb说道:

    https://casinvietnam.shop/# casino tr?c tuy?n

  5. RobertSmupt说道:

    В современном мире, где аттестат – это начало отличной карьеры в любой сфере, многие ищут максимально быстрый и простой путь получения качественного образования. Факт наличия официального документа переоценить невозможно. Ведь именно он открывает дверь перед любым человеком, желающим вступить в сообщество профессионалов или учиться в каком-либо институте.
    В данном контексте мы предлагаем очень быстро получить этот важный документ. Вы можете заказать аттестат, что будет выгодным решением для человека, который не смог закончить обучение или потерял документ. Любой аттестат изготавливается аккуратно, с особым вниманием ко всем элементам, чтобы в итоге получился документ, 100% соответствующий оригиналу.
    Преимущества подобного подхода заключаются не только в том, что можно оперативно получить аттестат. Процесс организован комфортно и легко, с профессиональной поддержкой. Начав от выбора нужного образца до точного заполнения личных данных и доставки по стране — все под абсолютным контролем квалифицированных мастеров.
    Для всех, кто ищет быстрый способ получения требуемого документа, наша услуга предлагает отличное решение. Приобрести аттестат – значит избежать длительного обучения и не теряя времени перейти к своим целям, будь то поступление в ВУЗ или начало карьеры.

    http://prema-attestats.ru/

  6. Pretty nice ρost. I just stumblеd upon yօur weblog and wished to say that I have truly еnjoyed browsing your blog posts.
    After all I will be sսbscribing to your rsѕ feed and I hope you write again soon!

  7. Walteronerb说道:

    https://casinvietnam.shop/# danh bai tr?c tuy?n

  8. Walteronerb说道:

    http://casinvietnam.shop/# choi casino tr?c tuy?n tren di?n tho?i

发表回复

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