中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android?Flutter圖片處理之高斯模糊如何實現

發布時間:2022-08-04 14:07:02 來源:億速云 閱讀:146 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“Android Flutter圖片處理之高斯模糊如何實現”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Android Flutter圖片處理之高斯模糊如何實現”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

ImageFilter

在Flutter中,使圖片模糊有2種方式,這2種方式都需要配合ImageFilter.blur()使用。

 factory ImageFilter.blur({ double sigmaX = 0.0, double sigmaY = 0.0, TileMode tileMode = TileMode.clamp })

sigmaX:以x軸方向模糊,值越大越模糊

sigmaY:以Y軸方向模糊,值越大越模糊

TileMode:不需要設置,使用默認值就行

原圖

Android?Flutter圖片處理之高斯模糊如何實現

橫向模糊

ImageFilter.blur(sigmaX: 10, sigmaY: 0)

Android?Flutter圖片處理之高斯模糊如何實現

垂直模糊

ImageFilter.blur(sigmaX: 0, sigmaY: 10)

Android?Flutter圖片處理之高斯模糊如何實現

xy軸同時模糊

ImageFilter.blur(sigmaX: 20, sigmaY: 20)

Android?Flutter圖片處理之高斯模糊如何實現

用法

BackdropFilter

如果是前端開發,看到這個名字應該很熟悉。和CSS中的backdrop-filter一樣,都是用來實現毛玻璃效果。

  const BackdropFilter({
    Key? key,
    required this.filter,
    Widget? child,
  })

filter是一個ImageFilter過濾器,過濾器的效果會應用于父Widget的子widget,過濾器不會作用在child上。所以一般都是使用Stack,將BackdropFilter放在圖片之上。

示例:

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('blur demo'),
      ),
      body: Stack(
        children: [
          /// 圖片在Stack最底層
          Image.asset(
            “assets/images/painting2.jpg”,
          ),
          BackdropFilter(
          	/// 過濾器
            filter: ImageFilter.blur(sigmaX: 10, sigmaY: 10),
            /// 必須設置一個空容器
            child: Container(),
          ),
    }

注意:child中必須設置一個空的Container,不然模糊效果不會生效。

局部模糊

BackdropFilter支持局部模糊,必須使用ClipRect或者其他ClipXXX包裹。

 body: Stack(
   children: [
     Image.asset(imgs[0]),
     Positioned(
       left: 100,
       right: 100,
       top: 200,
       bottom: 200,
       /// 必須clip,否則會對整個區域模糊。
       child: ClipRect(
         child: BackdropFilter(
           filter: ImageFilter.blur(sigmaY: 5, sigmaX: 5),
           child: Container(
             alignment: Alignment.center,
             color: Colors.black.withOpacity(0),
             child: Text('child不會被模糊處理'),
           ),
         ),
       ),
     )
   ],
 ),

Android?Flutter圖片處理之高斯模糊如何實現

ImageFiltered

使用起來非常簡單,只需要設置一個過濾器,child中添加圖片即可實現模糊效果。

 ImageFiltered(
   imageFilter: ImageFilter.blur(sigmaX: 20, sigmaY: 20),
   child: Image.asset(
     "assets/images/painting2.jpg",
   ),
 )

區別

Drop更適合處理局部模糊,性能沒有ImageFiltered好。如果只需要對圖片全部區域進行模糊處理,推薦使用ImageFiltered

讀到這里,這篇“Android Flutter圖片處理之高斯模糊如何實現”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

北流市| 且末县| 永登县| 广水市| 新田县| 阜宁县| 河间市| 田东县| 隆尧县| 平和县| 兴文县| 敖汉旗| 平阳县| 柳江县| 侯马市| 梅州市| 新源县| 弥勒县| 哈巴河县| 吉木乃县| 阜新| 青海省| 定西市| 玛曲县| 聂拉木县| 攀枝花市| 称多县| 德州市| 宁都县| 铜山县| 静海县| 青神县| 乳山市| 车致| 蕲春县| 微山县| 合川市| 新郑市| 视频| 伊金霍洛旗| 万盛区|