欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Qt?Qml實(shí)現(xiàn)毛玻璃效果

 更新時(shí)間:2025年01月02日 09:51:45   作者:夢(mèng)起丶  
毛玻璃效果是一種常見的?UI?設(shè)計(jì)風(fēng)格,它通過模糊背景并添加透明度和噪聲效果,使界面元素看起來像是半透明的磨砂玻璃,下面我們來看看如何使用Qml實(shí)現(xiàn)毛玻璃效果吧

寫在前面

毛玻璃效果(Acrylic Effect)是一種常見的 UI 設(shè)計(jì)風(fēng)格,它通過模糊背景并添加透明度和噪聲效果,使界面元素看起來像是半透明的磨砂玻璃。

本文將介紹如何使用 Qml 實(shí)現(xiàn)這種效果,并提供一個(gè)完整的示例代碼。

1. 效果圖

2. 毛玻璃效果的實(shí)現(xiàn)原理

毛玻璃效果的核心是通過模糊背景圖像,并疊加透明度和噪聲效果來實(shí)現(xiàn)。

具體來說,實(shí)現(xiàn)毛玻璃效果的步驟如下:

  • 捕獲背景圖像:首先需要捕獲背景圖像,作為模糊效果的輸入。
  • 模糊處理:對(duì)捕獲的背景圖像進(jìn)行模糊處理,生成模糊效果。
  • 添加亮度和色調(diào):通過疊加一個(gè)半透明的矩形,調(diào)整模糊區(qū)域的亮度和色調(diào)。
  • 添加噪聲效果:在模糊區(qū)域上疊加噪聲圖像,增加磨砂玻璃的質(zhì)感。

3. 實(shí)現(xiàn)毛玻璃效果

DelAcrylic.qml 文件定義了一個(gè)自定義的 Qml 組件,用于實(shí)現(xiàn)毛玻璃效果。以下是該文件的主要部分:

ShaderEffectSource: 用于捕獲源項(xiàng)(sourceItem)的內(nèi)容,并將其作為模糊效果的輸入。sourceRect 屬性定義了捕獲的區(qū)域。

ShaderEffectSource {
    id: __source
    anchors.fill: parent
    visible: false
    sourceRect: Qt.rect(control.x, control.y, control.width, control.height)
}

FastBlur: 對(duì) ShaderEffectSource 的內(nèi)容進(jìn)行模糊處理。radius 屬性控制模糊的強(qiáng)度。

FastBlur {
    id: __fastBlur
    anchors.fill: parent
    source: __source
    radius: 32
}

Rectangle: 有兩個(gè)矩形,第一個(gè)矩形用于設(shè)置背景的亮度(luminosity),第二個(gè)矩形用于設(shè)置顏色的色調(diào)(colorTint)和透明度(opacityTint)。

Rectangle {
    anchors.fill: parent
    color: Qt.rgba(1, 1, 1, luminosity)
    radius: control.radiusBg
}

Rectangle {
    anchors.fill: parent
    color: Qt.rgba(colorTint.r, colorTint.g, colorTint.b, opacityTint)
    radius: control.radiusBg
}

Image: 用于添加噪聲效果,噪聲圖像通過 base64 編碼嵌入到 Qml 文件中。opacity 屬性控制噪聲的透明度。

Image {
    id: __noiseImage
    anchors.fill: parent
    source: ""
    fillMode: Image.Tile
    opacity: 0.02
}

4. 如何使用

main.qml 是示例文件,使用 DelAcrylic 組件并提供了交互式的滑塊來控制模糊效果的參數(shù)。

以下是該文件的主要部分:

Window: 定義了一個(gè)窗口,寬度為 750,高度為 500,標(biāo)題為 "Acrylic Test"。

Window {
    width: 750
    height: 500
    visible: true
    title: qsTr("Acrylic Test")
}

Image: 作為背景圖像,填充整個(gè)窗口。

Image {
    id: bg
    anchors.fill: parent
    source: "qrc:/img.jpg"
}

DelAcrylic: 使用 DelAcrylic 組件,將其放置在窗口的中心位置,并綁定背景圖像作為模糊效果的源項(xiàng)。opacityNoise、opacityTintradiusBlur 屬性分別綁定到三個(gè)滑塊的值。

DelAcrylic {
    id: acrylic
    x: (bg.width - width) * 0.5
    y: (bg.height - height) * 0.5
    width: 300
    height: 300
    sourceItem: bg
    opacityNoise: slider1.value
    opacityTint: slider2.value
    radiusBlur: slider3.value

    MouseArea {
        anchors.fill: parent
        drag.target: parent
    }
}

Column: 包含三個(gè)滑塊,分別用于控制 opacityNoiseopacityTintradiusBlur 屬性。

Column {
    Slider {
        id: slider1
        anchors.horizontalCenter: parent.horizontalCenter
        from: 0
        to: 1
        stepSize: 0.01
        value: 0.02
        ToolTip.visible: hovered
        ToolTip.text: value.toFixed(2)

        Text {
            anchors.left: parent.right
            anchors.leftMargin: 10
            anchors.verticalCenter: parent.verticalCenter
            text: qsTr("opacityNoise")
        }
    }

    Slider {
        id: slider2
        anchors.horizontalCenter: parent.horizontalCenter
        from: 0
        to: 1
        stepSize: 0.01
        value: 0
        ToolTip.visible: hovered
        ToolTip.text: value.toFixed(2)

        Text {
            anchors.left: parent.right
            anchors.leftMargin: 10
            anchors.verticalCenter: parent.verticalCenter
            text: qsTr("opacityTint")
        }
    }

    Slider {
        id: slider3
        from: 0
        to: 100
        value: 48
        ToolTip.visible: hovered
        ToolTip.text: value.toFixed(0)

        Text {
            anchors.left: parent.right
            anchors.leftMargin: 10
            anchors.verticalCenter: parent.verticalCenter
            text: qsTr("radiusBlur")
        }
    }
}

結(jié)語(yǔ)

通過 DelAcrylic.qmlmain.qml 文件,我們實(shí)現(xiàn)了一個(gè)具有毛玻璃效果的 Qml 應(yīng)用程序。DelAcrylic 組件通過模糊背景圖像、添加亮度和色調(diào)、以及疊加噪聲效果,實(shí)現(xiàn)了毛玻璃效果。

這種毛玻璃效果可以廣泛應(yīng)用于現(xiàn)代 UI 設(shè)計(jì)中,特別是在需要模糊背景或?qū)崿F(xiàn)類似 Acrylic 效果的場(chǎng)景中。通過調(diào)整模糊強(qiáng)度、透明度和噪聲效果,我們可以創(chuàng)建出豐富多樣的視覺效果,提升用戶體驗(yàn)。

改進(jìn)建議:

  • 性能優(yōu)化:模糊效果可能會(huì)對(duì)性能產(chǎn)生影響,特別是在高分辨率或復(fù)雜場(chǎng)景下。可以考慮優(yōu)化模糊算法或降低模糊的強(qiáng)度以提高性能。
  • 更多參數(shù)控制:可以添加更多的參數(shù)控制,例如噪聲的類型、模糊的方向等,以提供更豐富的視覺效果。

到此這篇關(guān)于Qt Qml實(shí)現(xiàn)毛玻璃效果的文章就介紹到這了,更多相關(guān)Qt Qml毛玻璃內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • c++函數(shù)指針使用示例分享

    c++函數(shù)指針使用示例分享

    這篇文章主要介紹了c++函數(shù)指針使用示例,需要的朋友可以參考下
    2014-03-03
  • opencv實(shí)現(xiàn)圖片與視頻中人臉檢測(cè)功能

    opencv實(shí)現(xiàn)圖片與視頻中人臉檢測(cè)功能

    這篇文章主要為大家詳細(xì)介紹了opencv實(shí)現(xiàn)圖片與視頻中人臉檢測(cè)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C語(yǔ)言中的for循環(huán)語(yǔ)句基本語(yǔ)法及使用

    C語(yǔ)言中的for循環(huán)語(yǔ)句基本語(yǔ)法及使用

    這篇文章主要介紹了C語(yǔ)言中的for循環(huán)語(yǔ)句基本語(yǔ)法及使用,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06
  • Ubuntu 環(huán)境下的 C/C++ 編譯與調(diào)試配置方法

    Ubuntu 環(huán)境下的 C/C++ 編譯與調(diào)試配置方法

    本文檔詳細(xì)介紹了如何在Ubuntu環(huán)境中使用VSCode進(jìn)行C/C++的編譯與調(diào)試配置,通過配置`tasks.json`和`launch.json`,實(shí)現(xiàn)了統(tǒng)一管理輸出文件、優(yōu)化調(diào)試流程以及跨平臺(tái)兼容性,配置了`g++`編譯器和`gdb`調(diào)試器,并使用C/C++插件來提高開發(fā)效率,感興趣的朋友跟隨小編一起看看吧
    2024-11-11
  • C++通過控制臺(tái)訪問deepseek接口并進(jìn)行對(duì)話

    C++通過控制臺(tái)訪問deepseek接口并進(jìn)行對(duì)話

    這篇文章主要為大家詳細(xì)介紹了C++如何通過控制臺(tái)訪問deepseek接口并進(jìn)行對(duì)話,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2025-02-02
  • C語(yǔ)言求質(zhì)數(shù)的幾種簡(jiǎn)單易懂方式

    C語(yǔ)言求質(zhì)數(shù)的幾種簡(jiǎn)單易懂方式

    這篇文章主要介紹了C語(yǔ)言求質(zhì)數(shù)的幾種簡(jiǎn)單易懂方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 深入探討C++父類子類中虛函數(shù)的應(yīng)用

    深入探討C++父類子類中虛函數(shù)的應(yīng)用

    本篇文章是對(duì)C++父類子類中虛函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • 基于C++實(shí)現(xiàn)職工管理系統(tǒng)

    基于C++實(shí)現(xiàn)職工管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了基于C++實(shí)現(xiàn)職工管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • 詳解c++良好的編程習(xí)慣與編程要點(diǎn)

    詳解c++良好的編程習(xí)慣與編程要點(diǎn)

    c++語(yǔ)言的靈活是建立在對(duì)編程者個(gè)人的編程素質(zhì)的嚴(yán)格要求基礎(chǔ)上的,好的C++編程習(xí)慣能避免很多問題。沒有好的編程習(xí)慣,極有可能編寫一行代碼,編譯器能報(bào)十幾個(gè)錯(cuò)誤,而且就算編譯通過了,將來在運(yùn)行過程中也會(huì)有很多莫名奇妙的問題
    2021-06-06
  • C++中new和delete的使用方法詳解

    C++中new和delete的使用方法詳解

    這篇文章主要介紹了C++中new和delete的使用方法詳解的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下
    2017-10-10

最新評(píng)論