91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

阜平县| 曲周县| 塘沽区| 科技| 将乐县| 临高县| 天气| 陆良县| 红原县| 黄山市| 建始县| 明水县| 江华| 从江县| 康平县| 梓潼县| 文安县| 普兰县| 河北省| 东兰县| 辽阳市| 香港| 高平市| 呼玛县| 丽江市| 徐汇区| 新余市| 东光县| 汨罗市| 新野县| 唐河县| 花垣县| 济宁市| 乳山市| 塘沽区| 崇文区| 盈江县| 宿松县| 怀集县| 扬州市| 伊金霍洛旗|