国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

基于Flutter實(shí)現(xiàn)動(dòng)態(tài)高斯模糊的流程步驟

 更新時(shí)間:2023年11月06日 09:12:06   作者:易秋  
一個(gè)App加上高斯模糊會(huì)形成一種高級(jí)的感覺,本文將介紹如何制作一個(gè)根據(jù)背景內(nèi)容來動(dòng)態(tài)高斯模糊,文中有詳細(xì)的代碼實(shí)現(xiàn)步驟,代碼示例講解的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下

效果如下

實(shí)現(xiàn)思路

AppBar本質(zhì)上是一個(gè)Widget,我們不直接通過ScaffoldappBar屬性來設(shè)置AppBar,而是將我們需要的AppBar放在body屬性里面,至于為什么不能放在appBar屬性里面呢,最主要的原因是,ScaffoldappBar屬性是頂級(jí)組件,在appBar以外的任何組件都無法覆蓋或置于其下,而我們的主要實(shí)現(xiàn)思路是通過Stack組件的堆疊以及Positioned的位置設(shè)置來實(shí)現(xiàn)此效果

實(shí)現(xiàn)步驟

創(chuàng)建一個(gè)工程

import 'package:flutter/material.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
    );
  }
}

創(chuàng)建自定義嵌套導(dǎo)航路由

App結(jié)構(gòu)構(gòu)建

為了使代碼更好的管理和維護(hù),我們對(duì)頁面使用三層架構(gòu)模式,即分為state、logicview三層,state層專注于數(shù)據(jù),logic專注于頁面的邏輯、view專注于頁面的顯示,這類似于Vue<template> <script> <style>分層模式

dependencies:
  flutter:
    sdk: flutter
  # 路由管理
  get: ^4.6.5
  # 屏幕適配工具
  flutter_screenutil: ^5.9.0

main.dart中更改為如下內(nèi)容

import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get_navigation/src/root/get_material_app.dart';
import 'package:text/router/routeconfig.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return ScreenUtilInit(
      designSize: const Size(720, 1080),
      minTextAdapt: true,
      splitScreenMode: true,
      builder: (context, child) {
        return GetMaterialApp(
          title: 'Flutter Demo',
          // 隱藏debug
          debugShowCheckedModeBanner: false,
          theme: ThemeData(
            colorScheme: ColorScheme.fromSeed(seedColor: Colors.blueGrey),
            useMaterial3: true,
          ),
          getPages: RouteConfig.getPages,
          // 初始化主頁
          initialRoute: RouteConfig.main,
        );
      },
    );
  }
}

在lib中創(chuàng)建如下文件夾及文件 

router文件夾的內(nèi)容

routeconfig.dart

import 'package:get/get.dart';
import 'package:text/pages/appmain/view.dart';

class RouteConfig {
  //主頁面
  static const String main = "/";

  static final List<GetPage> getPages = [
    GetPage(name: main, page: () => const AppMainPage()),
  ];
}

appmain文件夾的內(nèi)容

state.dart

class AppMainState {
  AppMainState();
}

logic.dart

import 'package:get/get.dart';
import 'state.dart';

class AppMainLogic extends GetxController {
  final AppMainState state = AppMainState();
}

view.dart

import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'logic.dart';

class AppMainPage extends StatefulWidget {
  const AppMainPage({super.key});

  @override
  State<AppMainPage> createState() => _AppMainPageState();
}

class _AppMainPageState extends State<AppMainPage>
    with TickerProviderStateMixin {
  final logic = Get.put(AppMainLogic());
  final state = Get.find<AppMainLogic>().state;

  @override
  void initState() {
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Container(),
    );
  }
}

mainrouteconfig.dart

import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:text/pages/home/view.dart';

class NestedController extends GetxController {
  static const String home = "/homePage";
  static const String explore = "/explorePage";
  static const String musicLibrary = "/musicLibraryPage";

  static final Map<String, Widget> pages = {
    home: const HomePage(),
  };

  Route? onGenerateRoute(RouteSettings settings) {
    GetPageRoute? getPageRoute;
    pages.forEach((key, value) {
      if (settings.name == key) {
        getPageRoute = GetPageRoute(
          settings: settings,
          page: () => value,
          transition: Transition.fade,
        );
      }
    });

    return getPageRoute;
  }
}

home文件夾的內(nèi)容

state.dart

class HomeState {
  HomeState() {
    ///Initialize variables
  }
}

logic.dart

import 'package:get/get.dart';

import 'state.dart';

class HomeLogic extends GetxController {
  final HomeState state = HomeState();
}

view.dart

import 'package:flutter/material.dart';
import 'package:get/get.dart';

import 'logic.dart';

class HomePage extends StatefulWidget {
  const HomePage({super.key});

  @override
  State<HomePage> createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> {
  final logic = Get.put(HomeLogic());
  final state = Get.find<HomeLogic>().state;

  @override
  Widget build(BuildContext context) {
    return Container();
  }
}

創(chuàng)建完基礎(chǔ)App架構(gòu)模式后,我們開始自定義一個(gè)橋套導(dǎo)航,以便使我們?cè)谕粋€(gè)頁面內(nèi)做頁面的跳轉(zhuǎn),這類似于TabBar的效果

接下來我們就可以使用我們的自定義嵌套導(dǎo)航了, 頁面的嵌套導(dǎo)航總管理在pages/appmain文件夾下的mainrouteconfig.dart,然后我們接著完成嵌套導(dǎo)航結(jié)構(gòu)

自定義嵌套導(dǎo)航

在需要用到嵌套導(dǎo)航的頁面引入如下代碼

Navigator(
                      key: Get.nestedKey(1),
                      initialRoute: NestedController.home,
                      onGenerateRoute: state.nestedController.onGenerateRoute,
                    )

如我們想在appmain下的view.dart中引入,首先state層建立我們需要的數(shù)據(jù),這里我使用了一個(gè)第三方的TabBar組件,大家想用官方的組件也可以,只需稍做修改即可

導(dǎo)入第三方組件依賴

dependencies:
  flutter:
    sdk: flutter
  # 路由管理
  get: ^4.6.5
  # 屏幕適配工具
  flutter_screenutil: ^5.9.0
  # bruno ui組件
  bruno: ^3.4.3

appmain/state.dart中修改如下

import 'package:bruno/bruno.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:text/pages/appmain/mainrouteconfig.dart';

class AppMainState {
  late List<BadgeTab> tabs; // Tab列表
  late TabController tabController; // Tab控制器

  late NestedController nestedController;

  AppMainState() {
    // 添加頂部tab
    tabs = [];
    tabs.add(BadgeTab(text: "首頁"));
    tabs.add(BadgeTab(text: "發(fā)現(xiàn)"));
    tabs.add(BadgeTab(text: "樂庫"));

    nestedController =
        Get.put(NestedController(), permanent: true); // 創(chuàng)建嵌套導(dǎo)航控制器
  }
}

appmain/logic.dart修改如下,這里的void brnTabBarOnTap(brnState, index)函數(shù)中多了兩個(gè)頁面,大家可以自行在pages創(chuàng)建另外兩個(gè)頁面,也可以根據(jù)自己的需求進(jìn)行更改

import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:text/pages/appmain/mainrouteconfig.dart';
import 'state.dart';

class AppMainLogic extends GetxController {
  final AppMainState state = AppMainState();

    void tabControllerInit(TickerProvider tickerProvider) {
    state.tabController =
        TabController(length: state.tabs.length, vsync: tickerProvider);
  }

  // 路由跳轉(zhuǎn)控制
  void brnTabBarOnTap(brnState, index) {
    brnState.refreshBadgeState(index);
    switch (index) {
      case 0:
        Get.toNamed(NestedController.home, id: 1, arguments: {});
      case 1:
        Get.toNamed(NestedController.explore, id: 1, arguments: {});
      case 2:
        Get.toNamed(NestedController.musicLibrary, id: 1, arguments: {});
    }
  }
}

我創(chuàng)建的頁面如下,內(nèi)容和home文件夾下的各文件類似,只是類名不同

然后在appmain/mainrouteconfig.dart中稍作修改

  static const String home = "/homePage";
  static const String explore = "/explorePage";
  static const String musicLibrary = "/musicLibraryPage";
 
  static final Map<String, Widget> pages = {
    home: const HomePage(),
    explore: const ExplorePage(),
    musicLibrary: const MusicLibraryPage(),
  };

然后我們就可以在appmain/view中使用了,為了更好的適配多分辨率屏幕的影響,我們可以先定義一個(gè)頁面縮放小工具,我們?cè)趌ib目錄下創(chuàng)建一個(gè)common文件夾,文件夾下創(chuàng)建一個(gè)utils文件夾,里面有個(gè)工具類screenadaptor.dart

工具類內(nèi)容如下,此工具類是為了更好的管理橫豎屏的像素而建立的類

import 'package:flutter_screenutil/flutter_screenutil.dart';

class ScreenAdaptor {

  ScreenAdaptor();
  double getLengthByOrientation(double horizon, double vertical)
  {
    return ScreenUtil().orientation.index == 0 ? horizon : vertical;
  }
}

final ScreenAdaptor screenAdaptor = ScreenAdaptor();

這時(shí),我們就可以在appmain/view.dart中添加嵌套導(dǎo)航的組件以及一些樣式的優(yōu)化,代碼如下

import 'package:bruno/bruno.dart';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart';
import 'package:text/common/utils/screenadaptor.dart';
import 'logic.dart';

class AppMainPage extends StatefulWidget {
  const AppMainPage({super.key});

  @override
  State<AppMainPage> createState() => _AppMainPageState();
}

class _AppMainPageState extends State<AppMainPage>
    with TickerProviderStateMixin {
  final logic = Get.put(AppMainLogic());
  final state = Get.find<AppMainLogic>().state;

  @override
  void initState() {
    super.initState();
    logic.tabControllerInit(this);
  }

    @override
  void dispose() {
    super.dispose();
    state.tabController.dispose();
    state.nestedController.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: ConstrainedBox(
        constraints: const BoxConstraints.expand(),
        child: Stack(
          children: [
            Positioned(
              // 不可以修改
              top: screenAdaptor.getLengthByOrientation(35.h, 35.h),
              child: SizedBox(
                width: ScreenUtil().screenWidth,
                height: ScreenUtil().screenHeight,
                child: Navigator(
                  key: Get.nestedKey(1),
                  initialRoute: "/homePage",
                  onGenerateRoute: state.nestedController.onGenerateRoute,
                ),
              ),
            ),
            Positioned(
              top: screenAdaptor.getLengthByOrientation(-10.h, -10.h),
              child: SizedBox(
                width: ScreenUtil().screenWidth,
                child: BrnAppBar(
                  // 狀態(tài)欄和底部欄樣式
                  systemOverlayStyle: const SystemUiOverlayStyle(
                    statusBarColor: Colors.transparent,
                    statusBarIconBrightness: Brightness.dark,
                    statusBarBrightness: Brightness.dark,
                    systemNavigationBarColor: Colors.transparent,
                  ),
                  primary: true,
                  // 不顯示底部分割線
                  showDefaultBottom: false,
                  backgroundColor: Colors.transparent,
                  title: BrnTabBar(
                    indicatorColor: Colors.transparent,
                    backgroundcolor: Colors.transparent,
                    padding: EdgeInsets.fromLTRB(
                        screenAdaptor.getLengthByOrientation(70.w, 160.w),
                        0,
                        screenAdaptor.getLengthByOrientation(70.w, 160.w),
                        0),
                    mode: BrnTabBarBadgeMode.origin,
                    controller: state.tabController,
                    tabs: state.tabs,
                    onTap: logic.brnTabBarOnTap,
                    labelStyle: const TextStyle(
                      backgroundColor: Colors.transparent,
                      fontWeight: FontWeight.bold,
                    ),
                    unselectedLabelStyle: const TextStyle(
                      backgroundColor: Colors.transparent,
                      fontWeight: FontWeight.bold,
                    ),
                  ),
                  leadingWidth:
                      screenAdaptor.getLengthByOrientation(100.w, 50.w),
                  leading: IconButton(
                    onPressed: (){}, // 打開側(cè)邊欄
                    icon: const Icon(Icons.menu),
                  ),
                  themeData: BrnAppBarConfig(
                    itemSpacing: 0,
                    leftAndRightPadding: 0,
                  ),
                  actions: <Widget>[
                    IconButton(
                      onPressed: () {},
                      icon: const Icon(Icons.search),
                    ),
                  ],
                ),
              ),
            ),
          ],
        ),
      ),
    );
  }
}

然后一運(yùn)行,就可以發(fā)現(xiàn)大體效果出來了

有了AppBar框架后,我們就可以實(shí)現(xiàn)我們的動(dòng)態(tài)高斯模糊了

高斯模糊

組件的背景高斯模糊我們可以通過BackdropFilter這一個(gè)類來做實(shí)現(xiàn),基于此,我封裝了一個(gè)類來便于我們使用

我們?cè)?code>lib目錄下新建一個(gè)component文件夾,里面創(chuàng)建一個(gè)BlurRectWidget的類

內(nèi)容為

import 'dart:ui';

import 'package:flutter/material.dart';

class BlurRectWidget extends StatelessWidget {
  final Widget _widget;
  final double singmaX;
  final double singmaY;

  const BlurRectWidget(this._widget, {super.key, required this.singmaX, required this.singmaY});

  @override
  Widget build(BuildContext context) {
    return ClipRRect(
      child: BackdropFilter(
        filter: ImageFilter.blur(
          sigmaX: singmaX,
          sigmaY: singmaY,
        ),
        child: _widget,
      ),
    );
  }
}

使用方法

BlurRectWidget(
                  singmaX: 20,
                  singmaY: 20,
                  widget // 這里換成你想包裹的widget
               )

比如我們?cè)?code>appmain/view.dart中將BrnAppBar包裹起來

BlurRectWidget(
                  singmaX: 20,
                  singmaY: 20,
                  BrnAppBar( ... )   
                ),

運(yùn)行查看效果

可以看到已有高斯模糊效果,那是不是動(dòng)態(tài)的呢,我們?cè)?code>home/view里面添加一些內(nèi)容來驗(yàn)證

home/view.dart內(nèi)容修改如下

import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart';
import 'package:text/common/utils/screenadaptor.dart';

import 'logic.dart';

class HomePage extends StatefulWidget {
  const HomePage({super.key});

  @override
  State<HomePage> createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> {
  final logic = Get.put(HomeLogic());
  final state = Get.find<HomeLogic>().state;

  @override
  Widget build(BuildContext context) {
    return Container(
      padding: EdgeInsets.fromLTRB(
        screenAdaptor.getLengthByOrientation(24.h, 20.h),
        0,
        screenAdaptor.getLengthByOrientation(24.h, 20.h),
        0,
      ),
      child: Stack(
        children: [
          SizedBox(
            // 占滿屏幕
            width: ScreenUtil().screenWidth,
            height: ScreenUtil().screenHeight,
            child: ListView(
              children: [
                // 占位
                SizedBox(
                  height: screenAdaptor.getLengthByOrientation(45.h, 45.h),
                ),
                Container(
                  color: Colors.blue,
                  height: 1000,
                  width: 100,
                  child: Image.network(
                    "https://t.mwm.moe/mp/",
                    fit: BoxFit.cover,
                  ),
                ),
              ],
            ),
          ),
        ],
      ),
    );
  }
}

重新運(yùn)行效果

可以看到已經(jīng)有了動(dòng)態(tài)高斯模糊 自此高級(jí)觀感的AppBar已經(jīng)實(shí)現(xiàn)完畢

封裝BackdropFilter

為了能像使用CSS里的filter一樣方便,我封裝了一個(gè)BackdropCSSFilter類, 此類基于https://github.com/iofod/flutter_css_filter做修改,因?yàn)樵髡叩腃SSFilter對(duì)組件進(jìn)行模糊而不是對(duì)背景進(jìn)行模糊,所以我做修改了

common/utils目錄下創(chuàng)建如下文件

base.dart內(nèi)容如下

import 'dart:math' as math;
import 'css_filter.dart';
import 'utils.dart';

class BackdropFilterMatrix {
  /// Check: https://developer.mozilla.org/en-US/docs/Web/CSS/filter-function/contrast()
  static contrast({required List<double> matrix, required double value}) {
    double v = value;
    double b = (1.0 - value) * 0.5 * 255.0; // 0.5*255 => 127

    return multiplyMatrix5(matrix, <double>[
      v,
      0,
      0,
      0,
      b,
      0,
      v,
      0,
      0,
      b,
      0,
      0,
      v,
      0,
      b,
      0,
      0,
      0,
      1,
      0,
      0,
      0,
      0,
      0,
      1
    ]);
  }

  /// Formula from: https://www.w3.org/TR/filter-effects-1/#grayscaleEquivalent
  static grayscale({required List<double> matrix, required double value}) {
    double v = 1.0 - value;
    double lumR = 0.2126;
    double lumG = 0.7152;
    double lumB = 0.0722;

    return multiplyMatrix5(matrix, <double>[
      (lumR + (1 - lumR) * v),
      (lumG - lumG * v),
      (lumB - lumB * v),
      0,
      0,
      (lumR - lumR * v),
      (lumG + (1 - lumG) * v),
      (lumB - lumB * v),
      0,
      0,
      (lumR - lumR * v),
      (lumG - lumG * v),
      (lumB + (1 - lumB) * v),
      0,
      0,
      0,
      0,
      0,
      1,
      0,
      0,
      0,
      0,
      0,
      1
    ]);
  }

  /// Formula from: https://www.w3.org/TR/filter-effects-1/#sepiaEquivalent
  static sepia({required List<double> matrix, required double value}) {
    double v = 1.0 - value;

    return multiplyMatrix5(matrix, <double>[
      (0.393 + 0.607 * v),
      (0.769 - 0.769 * v),
      (0.189 - 0.189 * v),
      0,
      0,
      (0.349 - 0.349 * v),
      (0.686 + 0.314 * v),
      (0.168 - 0.168 * v),
      0,
      0,
      (0.272 - 0.272 * v),
      (0.534 - 0.534 * v),
      (0.131 + 0.869 * v),
      0,
      0,
      0,
      0,
      0,
      1,
      0,
      0,
      0,
      0,
      0,
      1
    ]);
  }

  /// Check: https://www.geeksforgeeks.org/css-invert-function/
  static invert({required List<double> matrix, required double value}) {
    // v * (255 - n) + (1 - v) * n => (1 - 2v) * n + 255 * v
    double v = value * 255.0;
    double k = 1.0 - 2.0 * value;

    // The fifth column n is 255.
    return multiplyMatrix5(matrix, <double>[
      k,
      0,
      0,
      0,
      v,
      0,
      k,
      0,
      0,
      v,
      0,
      0,
      k,
      0,
      v,
      0,
      0,
      0,
      1,
      0,
      0,
      0,
      0,
      0,
      1
    ]);
  }

  /// Check: https://stackoverflow.com/questions/64639589/how-to-adjust-hue-saturation-and-brightness-of-an-image-in-flutter
  static hue({required List<double> matrix, required double value}) {
    double v = math.pi * (value / 180.0);
    double cosVal = math.cos(v);
    double sinVal = math.sin(v);
    double lumR = 0.213;
    double lumG = 0.715;
    double lumB = 0.072;

    return multiplyMatrix5(matrix, <double>[
      (lumR + (cosVal * (1 - lumR))) + (sinVal * (-lumR)),
      (lumG + (cosVal * (-lumG))) + (sinVal * (-lumG)),
      (lumB + (cosVal * (-lumB))) + (sinVal * (1 - lumB)),
      0,
      0,
      (lumR + (cosVal * (-lumR))) + (sinVal * 0.143),
      (lumG + (cosVal * (1 - lumG))) + (sinVal * 0.14),
      (lumB + (cosVal * (-lumB))) + (sinVal * (-0.283)),
      0,
      0,
      (lumR + (cosVal * (-lumR))) + (sinVal * (-(1 - lumR))),
      (lumG + (cosVal * (-lumG))) + (sinVal * lumG),
      (lumB + (cosVal * (1 - lumB))) + (sinVal * lumB),
      0,
      0,
      0,
      0,
      0,
      1,
      0,
      0,
      0,
      0,
      0,
      1
    ]);
  }

  static brightness({required List<double> matrix, required double value}) {
    double v = value;

    return multiplyMatrix5(matrix, <double>[
      v,
      0,
      0,
      0,
      0,
      0,
      v,
      0,
      0,
      0,
      0,
      0,
      v,
      0,
      0,
      0,
      0,
      0,
      1,
      0,
      0,
      0,
      0,
      0,
      1
    ]);
  }

  /// Check: https://docs.rainmeter.net/tips/colormatrix-guide/
  static saturate({required List<double> matrix, required double value}) {
    return BackdropFilterMatrix.grayscale(matrix: matrix, value: 1.0 - value);
  }

  static opacity({required List<double> matrix, required double value}) {
    return multiplyMatrix5(matrix, <double>[
      1,
      0,
      0,
      0,
      0,
      0,
      1,
      0,
      0,
      0,
      0,
      0,
      1,
      0,
      0,
      0,
      0,
      0,
      value,
      0,
      0,
      0,
      0,
      0,
      1
    ]);
  }
}

// Allows matrix multiplication.
final filterTypeMap = {
  'contrast': BackdropFilterMatrix.contrast,
  'grayscale': BackdropFilterMatrix.grayscale,
  'hueRotate': BackdropFilterMatrix.hue,
  'brightness': BackdropFilterMatrix.brightness,
  'saturate': BackdropFilterMatrix.saturate,
  'opacity': BackdropFilterMatrix.opacity,
};

// Not superimposed on the original matrix.
final filterAloneMap = {
  'sepia': BackdropCSSFilter.sepia,
  'invert': BackdropCSSFilter.invert,
  'blur': BackdropCSSFilter.blur
};

css_filter.dart

/// CSS filter for flutter
/// Author: qkorbit
/// Released under BSD-3-Clause License.
library css_filter;

export 'filter.dart';
export 'presets.dart';
export 'base.dart' show BackdropFilterMatrix;
export 'utils.dart' show BackdropCSSFilterMatrix;

filter.dart

import 'dart:ui';
import 'package:flutter/material.dart';
import 'utils.dart';
import 'base.dart';

/// Use CSS filter effects on flutter's Widget. All CSS filters are implemented except `drop-shadow()`.
/// `drop-shadow()` should be replaced by the [BoxShadow](https://api.flutter.dev/flutter/painting/BoxShadow-class.html) or [Shadow](https://api.flutter.dev/flutter/dart-ui/Shadow-class.html) widget.
///
/// Example:
///
/// ```dart
/// CSSFilter.contrast(child: const Text('foo'), value: 1.2);
/// ```
///
/// Support effects:
/// * contrast()
/// * grayscale()
/// * sepia()
/// * hueRotate()
/// * brightness()
/// * saturate()
/// * invert()
/// * blur()
/// * opacity()
class BackdropCSSFilter {
  /// Adjusts the contrast of the input widget.
  /// A value under 1.0 decreases the contrast, while a value over 1.0 increases it.
  /// A value of 0.0 will make it completely gray.
  /// Default value is 1.0.
  static Widget contrast({required Widget child, required double value}) {
    if (!isNotDefault(value)) return child;

    return execFilterSample(
        BackdropFilterMatrix.contrast(matrix: baseMatrix(), value: value),
        child);
  }

  /// Converts the input widget to grayscale.
  /// Values between 0.0 and 1.0 are linear multipliers on the effect.
  /// A value of 1.0 is completely grayscale.
  /// Default value is 0.0.
  static Widget grayscale({required Widget child, required double value}) {
    if (!isNotNegative(value)) return child;

    return execFilterSample(
        BackdropFilterMatrix.grayscale(matrix: baseMatrix(), value: value),
        child);
  }

  /// Converts the input widget to sepia, giving it a warmer, more yellow/brown appearance.
  /// Values between 0.0 and 1.0 are linear multipliers on the effect.
  /// A value of 1.0 is completely sepia.
  /// Default value is 0.0.
  static Widget sepia({required Widget child, required double value}) {
    if (!isNotNegative(value)) return child;

    return execFilterSample(
        BackdropFilterMatrix.sepia(matrix: baseMatrix(), value: value), child);
  }

  /// Rotates the [hue](https://en.wikipedia.org/wiki/Hue) of the input widget.
  /// A positive hue rotation increases the hue value, while a negative rotation decreases the hue value.
  /// @parmas value: A value of rotate angle.
  /// Default value is 0.0.
  static Widget hueRotate({required Widget child, required double value}) {
    if (value == 0.0) return child;

    return execFilterSample(
        BackdropFilterMatrix.hue(matrix: baseMatrix(), value: value), child);
  }

  /// Apply a linear multiplier to the input widget, making it appear brighter or darker.
  /// A value under 1.0 darkens the Widget, while a value over 1.0 brightens it.
  /// A value of 0.0 will make it completely black.
  /// Default value is 1.0.
  static Widget brightness({required Widget child, required double value}) {
    if (!isNotDefault(value)) return child;

    return execFilterSample(
        BackdropFilterMatrix.brightness(matrix: baseMatrix(), value: value),
        child);
  }

  /// Super-saturates or desaturates the input widget.
  /// A value under 1.0 desaturates the Widget, while a value over 1.0 super-saturates it.
  /// A value of 0.0 is completely unsaturated.
  /// Default value is 1.0.
  static Widget saturate({required Widget child, required double value}) {
    if (!isNotDefault(value)) return child;

    return execFilterSample(
        BackdropFilterMatrix.saturate(matrix: baseMatrix(), value: value),
        child);
  }

  /// Inverts the color of input widget.
  /// Values between 0.0 and 1.0 are linear multipliers on the effect.
  /// A value of 1.0 is completely inverted.
  /// Default value is 0.0.
  static Widget invert({required Widget child, required double value}) {
    if (!isNotNegative(value)) return child;

    return execFilterSample(
        BackdropFilterMatrix.invert(matrix: baseMatrix(), value: value), child);
  }

  /// Apply a Gaussian blur to the input widget.
  /// A larger value will create more blur on input widget.
  /// @parmas value: A value of blur radius.
  /// Default value is 0.0.
  static Widget blur({required Widget child, required double value}) {
    if (!isNotNegative(value)) return child;

    return ClipRRect(
      child: BackdropFilter(
          filter: ImageFilter.blur(
              sigmaX: value, sigmaY: value, tileMode: TileMode.decal),
          child: child),
    );
  }

  /// Apply transparency to input widget.
  /// Values between 0.0 and 1.0 are linear multipliers on the effect.
  /// A value of 0.0 is completely transparent.
  /// Default value is 1.0.
  static Widget opacity({required Widget child, required double value}) {
    if (!isNotDefault(value)) return child;

    return execFilterSample(
        BackdropFilterMatrix.opacity(matrix: baseMatrix(), value: value),
        child);
  }

  /// A quick and efficient way to apply multiple filters to the input widget.
  /// You can use any combination of these filter effects.
  ///
  /// Example:
  ///
  /// ```dart
  /// CSSFilter.apply(child: const Text('Hello World!'), value: CSSFilterMatrix().contrast(0.5).blur(3.0));
  /// CSSFilter.apply(child: const Text('Hello World!'), value: CSSFilterMatrix().brightness(1.2).saturate(1.5));
  /// ```
  ///
  static Widget apply(
      {required Widget child, required BackdropCSSFilterMatrix value}) {
    List<double> matrix = baseMatrix();
    Widget tree = child;
    bool canMerge = false;

    value.conf.forEach((K, V) {
      var fn = filterTypeMap[K];

      if (fn != null) {
        matrix = fn(matrix: matrix, value: V);
        canMerge = true;
      } else {
        // merge layers once
        if (canMerge) {
          tree = ClipRRect(
            child: BackdropFilter(
              filter: toColorFilterMatrix(matrix),
              child: tree,
            ),
          );

          canMerge = false;
        }

        var alone = filterAloneMap[K];

        tree = alone!(child: tree, value: V);
        // reset matrix
        matrix = baseMatrix();
      }
    });

    if (!canMerge) return tree;

    return ClipRRect(
      child: BackdropFilter(
        filter: toColorFilterMatrix(matrix),
        child: tree,
      ),
    );
  }
}

presets.dart

import 'package:flutter/material.dart';

import 'filter.dart';
import 'utils.dart';

/// Added more preset filter effects to CSSFilter.
/// The current version adds instagram filter package, the values mainly refer to [CSSgram](https://github.com/una/CSSgram), partly refer to [instagram.css](https://github.com/picturepan2/instagram.css).
///
/// Example:
///
/// ```dart
/// CSSFilterPresets.insAshby(child: const Text('foo'));
/// CSSFilterPresets.insHelena(child: const Text('bar'));
/// ```
///
/// Support effects:
/// * ins1977()
/// * ins1977V2()
/// * insAden()
/// * insAmaro()
/// * insAshby()
/// * insBrannan()
/// * insBrooklyn()
/// * insClarendon()
/// * insDogpatch()
/// * insEarlybird()
/// * insGingham()
/// * insHelena()
/// * insHudson()
/// * insInkwell()
/// * insInkwellV2()
/// * insJuno()
/// * insKelvin()
/// * insLark()
/// * insLofi()
/// * insLudwig()
/// * insMaven()
/// * insMayfair()
/// * insMoon()
/// * insMoonV2()
/// * insNashville()
/// * insNashvilleV2()
/// * insPerpetua()
/// * insPoprocket()
/// * insReyes()
/// * insRise()
/// * insSierra()
/// * insSkyline()
/// * insSlumber()
/// * insStinson()
/// * insSutro()
/// * insToaster()
/// * insToasterV2()
/// * insValencia()
/// * insVesper()
/// * insWalden()
/// * insWaldenV2()
/// * insWillow()
/// * insXpro2()
///
class CSSFilterPresets {
  /// A quick and efficient way to apply preset effects to the input widget.
  /// You can even adjust the intensity of the preset effects.
  ///
  /// Example:
  ///
  /// ```dart
  /// CSSFilterPresets.apply(
  ///   child: const Text('foo'),
  ///   value: CSSFilterPresets.insMaven,
  ///   strength: 0.6
  /// );
  /// ```
  ///
  /// If the input widget is transparent, then the `alphaBlending` parameter should be set to adjust the [Alpha Compositing](https://ciechanow.ski/alpha-compositing/) to avoid gross overlay of transparency.
  /// In general, `alphaBlending` is set to the same opacity value as the input widget. If the opacity of the input widget is unknown, the `alphaBlending` value is set according to the actual situation.
  ///
  static Widget apply(
      {required Widget child,
      required Function value,
      double strength = 1.0,
      double alphaBlending = 1.0}) {
    if (strength <= 0.0) return child;
    if (strength >= 1.0) strength = 1.0;

    Widget filtered = value(child: child);

    if (strength == 1.0) return filtered;
    if (alphaBlending > 1.0) alphaBlending = 1.0;
    if (alphaBlending < 0.0) alphaBlending = 0.0;

    Widget tree = Stack(children: [
      Positioned(child: child),
      Positioned(
          child:
              IgnorePointer(child: Opacity(opacity: strength, child: filtered)))
    ]);

    if (alphaBlending == 1.0) return tree;

    return Opacity(
        opacity: 1.0 - (1.0 - alphaBlending) * strength, child: tree);
  }

  static Widget origin({required Widget child}) {
    return child;
  }

  static Widget ins1977({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(243, 106, 188, 0.3)),
      blendMode: BlendMode.screen,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix().contrast(1.1).brightness(1.1).saturate(1.3)),
    );
  }

  static Widget ins1977V2({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value: BackdropCSSFilterMatrix().sepia(0.5).hueRotate(-30.0).saturate(1.4));
  }

  static Widget insAden({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderLinearSample([
        const Color.fromRGBO(66, 10, 14, 0.2),
        const Color.fromRGBO(0, 0, 0, 0.0)
      ], Alignment.centerRight),
      blendMode: BlendMode.darken,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .hueRotate(-20.0)
              .contrast(0.9)
              .saturate(0.85)
              .brightness(1.2)),
    );
  }

  static Widget insAmaro({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(125, 105, 24, 0.2)),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.35)
              .contrast(1.1)
              .brightness(1.2)
              .saturate(1.3)),
    );
  }

  static Widget insAshby({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(125, 105, 24, 0.35)),
      blendMode: BlendMode.lighten,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix().sepia(0.5).contrast(1.2).saturate(1.8)),
    );
  }

  static Widget insBrannan({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(161, 44, 199, 0.31)),
      blendMode: BlendMode.lighten,
      child: BackdropCSSFilter.apply(
          child: child, value: BackdropCSSFilterMatrix().sepia(0.5).contrast(1.4)),
    );
  }

  static Widget insBrooklyn({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(168, 223, 193, 0.4),
        const Color.fromRGBO(196, 183, 200, 1.0)
      ], [
        0.0,
        0.7
      ]),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child, value: BackdropCSSFilterMatrix().contrast(0.9).brightness(1.1)),
    );
  }

  static Widget insClarendon({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(127, 187, 227, 0.2)),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child, value: BackdropCSSFilterMatrix().contrast(1.2).saturate(1.35)),
    );
  }

  static Widget insDogpatch({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value: BackdropCSSFilterMatrix().sepia(0.35).saturate(1.1).contrast(1.5));
  }

  static Widget insEarlybird({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(208, 186, 142, 1.0),
        const Color.fromRGBO(54, 3, 9, 1.0),
        const Color.fromRGBO(29, 2, 16, 1.0)
      ], [
        0.2,
        0.85,
        1.0
      ]),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child, value: BackdropCSSFilterMatrix().contrast(0.9).sepia(0.2)),
    );
  }

  static Widget insGingham({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(230, 230, 250, 1.0)),
      blendMode: BlendMode.softLight,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix().brightness(1.05).hueRotate(-10.0)),
    );
  }

  static Widget insHelena({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(158, 175, 30, 0.25)),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.5)
              .contrast(1.05)
              .brightness(1.05)
              .saturate(1.35)),
    );
  }

  static Widget insHudson({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(166, 177, 255, 0.5),
        const Color.fromRGBO(52, 33, 52, 0.5)
      ], [
        0.5,
        1.0
      ]),
      blendMode: BlendMode.multiply,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix().brightness(1.2).contrast(0.9).saturate(1.1)),
    );
  }

  static Widget insInkwell({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value: BackdropCSSFilterMatrix()
            .sepia(0.3)
            .contrast(1.1)
            .brightness(1.1)
            .grayscale(1.0));
  }

  static Widget insInkwellV2({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value:
        BackdropCSSFilterMatrix().brightness(1.25).contrast(0.85).grayscale(1.0));
  }

  static Widget insJuno({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(127, 187, 227, 0.2)),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.35)
              .contrast(1.15)
              .brightness(1.15)
              .saturate(1.8)),
    );
  }

  static Widget insKelvin({required Widget child}) {
    Widget sub = ShaderMask(
        shaderCallback:
            execShaderDirectSample(const Color.fromRGBO(56, 44, 52, 1.0)),
        blendMode: BlendMode.colorDodge,
        child: child);

    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(183, 125, 33, 1.0)),
      blendMode: BlendMode.overlay,
      child: sub,
    );
  }

  static Widget insLark({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value: BackdropCSSFilterMatrix()
            .sepia(0.25)
            .contrast(1.2)
            .brightness(1.3)
            .saturate(1.25));
  }

  static Widget insLofi({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child, value: BackdropCSSFilterMatrix().saturate(1.1).contrast(1.5));
  }

  static Widget insLudwig({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(125, 105, 24, 0.1)),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.25)
              .contrast(1.05)
              .brightness(1.05)
              .saturate(2.0)),
    );
  }

  static Widget insMaven({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(3, 230, 26, 0.2)),
      blendMode: BlendMode.hue,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .contrast(0.95)
              .brightness(0.95)
              .saturate(1.5)
              .sepia(0.25)),
    );
  }

  static Widget insMayfair({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(255, 255, 255, 0.32),
        const Color.fromRGBO(255, 200, 200, 0.24),
        const Color.fromRGBO(17, 17, 17, 0.4)
      ], const [
        0.0,
        0.0,
        0.6
      ]),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child, value: BackdropCSSFilterMatrix().contrast(1.1).saturate(1.1)),
    );
  }

  static Widget insMoon({required Widget child}) {
    Widget sub = ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(160, 160, 160, 1.0)),
      blendMode: BlendMode.softLight,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix().grayscale(1).contrast(1.1).brightness(1.1)),
    );

    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(56, 56, 56, 1.0)),
      blendMode: BlendMode.lighten,
      child: sub,
    );
  }

  static Widget insMoonV2({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value: BackdropCSSFilterMatrix()
            .brightness(1.4)
            .contrast(0.95)
            .saturate(0.0)
            .sepia(0.35));
  }

  static Widget insNashville({required Widget child}) {
    Widget sub = ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(247, 176, 153, 0.56)),
      blendMode: BlendMode.darken,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.2)
              .contrast(1.2)
              .brightness(1.05)
              .saturate(1.2)),
    );

    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(0, 70, 150, 0.4)),
      blendMode: BlendMode.lighten,
      child: sub,
    );
  }

  static Widget insNashvilleV2({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(128, 78, 15, 0.5),
        const Color.fromRGBO(128, 78, 15, 0.65)
      ]),
      blendMode: BlendMode.screen,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.25)
              .contrast(1.5)
              .brightness(0.9)
              .hueRotate(-15.0)),
    );
  }

  static Widget insPerpetua({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderLinearSample([
        const Color.fromRGBO(0, 91, 154, 0.5),
        const Color.fromRGBO(230, 193, 61, 0.5)
      ], Alignment.bottomCenter),
      blendMode: BlendMode.softLight,
      child: child,
    );
  }

  static Widget insPoprocket({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(206, 39, 70, 0.75),
        const Color.fromRGBO(0, 0, 0, 1.0)
      ], const [
        0.4,
        0.8
      ]),
      blendMode: BlendMode.screen,
      child: BackdropCSSFilter.apply(
          child: child, value: BackdropCSSFilterMatrix().sepia(0.15).brightness(1.2)),
    );
  }

  static Widget insReyes({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value: BackdropCSSFilterMatrix()
            .sepia(0.75)
            .contrast(0.75)
            .brightness(1.25)
            .saturate(1.4));
  }

  static Widget insRise({required Widget child}) {
    Widget sub = ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(236, 205, 169, 0.15),
        const Color.fromRGBO(50, 30, 7, 0.4)
      ], [
        0.55,
        1.0
      ]),
      blendMode: BlendMode.multiply,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .brightness(1.05)
              .sepia(0.2)
              .contrast(0.9)
              .saturate(0.9)),
    );

    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(232, 197, 152, 0.48),
        const Color.fromRGBO(0, 0, 0, 0.0)
      ], [
        0.0,
        0.9
      ]),
      blendMode: BlendMode.overlay,
      child: sub,
    );
  }

  static Widget insSierra({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(128, 78, 15, 0.5),
        const Color.fromRGBO(0, 0, 0, 0.65)
      ]),
      blendMode: BlendMode.screen,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.25)
              .contrast(1.5)
              .brightness(0.9)
              .hueRotate(-15.0)),
    );
  }

  static Widget insSkyline({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value: BackdropCSSFilterMatrix()
            .sepia(0.15)
            .contrast(1.25)
            .brightness(1.25)
            .saturate(1.2));
  }

  static Widget insSlumber({required Widget child}) {
    Widget sub = ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(69, 41, 12, 0.4)),
      blendMode: BlendMode.lighten,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix().saturate(0.66).brightness(1.05)),
    );

    return ShaderMask(
        shaderCallback:
            execShaderDirectSample(const Color.fromRGBO(125, 105, 24, 0.5)),
        blendMode: BlendMode.softLight,
        child: sub);
  }

  static Widget insStinson({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(240, 149, 128, 0.2)),
      blendMode: BlendMode.softLight,
      child: BackdropCSSFilter.apply(
          child: child,
          value:
          BackdropCSSFilterMatrix().contrast(0.75).saturate(0.85).brightness(1.15)),
    );
  }

  static Widget insSutro({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(0, 0, 0, 0.0),
        const Color.fromRGBO(0, 0, 0, 0.5)
      ], const [
        0.5,
        0.9
      ]),
      blendMode: BlendMode.darken,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.4)
              .contrast(1.2)
              .brightness(0.9)
              .saturate(1.4)
              .hueRotate(-10.0)),
    );
  }

  static Widget insToaster({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(128, 78, 15, 1.0),
        const Color.fromRGBO(59, 0, 59, 1.0)
      ]),
      blendMode: BlendMode.screen,
      child: BackdropCSSFilter.apply(
          child: child, value: BackdropCSSFilterMatrix().contrast(1.3).brightness(0.9)),
    );
  }

  static Widget insToasterV2({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(128, 78, 15, 1.0),
        const Color.fromRGBO(0, 0, 0, 0.25)
      ]),
      blendMode: BlendMode.screen,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.25)
              .contrast(1.5)
              .brightness(0.95)
              .hueRotate(-15.0)),
    );
  }

  static Widget insValencia({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(58, 3, 57, 0.5)),
      blendMode: BlendMode.exclusion,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix().contrast(1.08).brightness(1.08).sepia(0.08)),
    );
  }

  static Widget insVesper({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(125, 105, 24, 0.25)),
      blendMode: BlendMode.overlay,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.35)
              .contrast(1.15)
              .brightness(1.2)
              .saturate(1.3)),
    );
  }

  static Widget insWalden({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(0, 68, 204, 0.3)),
      blendMode: BlendMode.screen,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .brightness(1.1)
              .hueRotate(-10.0)
              .sepia(0.3)
              .saturate(1.6)),
    );
  }

  static Widget insWaldenV2({required Widget child}) {
    return ShaderMask(
      shaderCallback:
          execShaderDirectSample(const Color.fromRGBO(229, 240, 128, 0.5)),
      blendMode: BlendMode.darken,
      child: BackdropCSSFilter.apply(
          child: child,
          value: BackdropCSSFilterMatrix()
              .sepia(0.35)
              .contrast(0.8)
              .brightness(1.25)
              .saturate(1.4)),
    );
  }

  static Widget insWillow({required Widget child}) {
    return BackdropCSSFilter.apply(
        child: child,
        value: BackdropCSSFilterMatrix()
            .brightness(1.2)
            .contrast(0.85)
            .saturate(0.05)
            .sepia(0.2));
  }

  static Widget insXpro2({required Widget child}) {
    return ShaderMask(
      shaderCallback: execShaderRadialSample([
        const Color.fromRGBO(230, 231, 224, 1.0),
        const Color.fromRGBO(43, 42, 161, 0.6)
      ], [
        0.4,
        1.1
      ]),
      blendMode: BlendMode.colorBurn,
      child: BackdropCSSFilter.apply(child: child, value: BackdropCSSFilterMatrix().sepia(0.3)),
    );
  }
}

utils.dart

import 'package:flutter/material.dart';

List<double> baseMatrix() {
  return <double>[
    1,
    0,
    0,
    0,
    0,
    0,
    1,
    0,
    0,
    0,
    0,
    0,
    1,
    0,
    0,
    0,
    0,
    0,
    1,
    0,
    0,
    0,
    0,
    0,
    1
  ];
}

/// Check: https://github.com/openkraken/kraken/blob/main/kraken/lib/src/css/filter.dart
/// Calc 5x5 matrix multiplication.
List<double> multiplyMatrix5(List<double> a, List<double> b) {
  if (a.length != b.length) {
    throw FlutterError('Matrix length should be same.');
  }

  if (a.length != 25) {
    throw FlutterError('Matrix5 size is not correct.');
  }

  var a00 = a[0];
  var a01 = a[1];
  var a02 = a[2];
  var a03 = a[3];
  var a04 = a[4];
  var a10 = a[5];
  var a11 = a[6];
  var a12 = a[7];
  var a13 = a[8];
  var a14 = a[9];
  var a20 = a[10];
  var a21 = a[11];
  var a22 = a[12];
  var a23 = a[13];
  var a24 = a[14];
  var a30 = a[15];
  var a31 = a[16];
  var a32 = a[17];
  var a33 = a[18];
  var a34 = a[19];
  var a40 = a[20];
  var a41 = a[21];
  var a42 = a[22];
  var a43 = a[23];
  var a44 = a[24];

  var b00 = b[0];
  var b01 = b[1];
  var b02 = b[2];
  var b03 = b[3];
  var b04 = b[4];
  var b10 = b[5];
  var b11 = b[6];
  var b12 = b[7];
  var b13 = b[8];
  var b14 = b[9];
  var b20 = b[10];
  var b21 = b[11];
  var b22 = b[12];
  var b23 = b[13];
  var b24 = b[14];
  var b30 = b[15];
  var b31 = b[16];
  var b32 = b[17];
  var b33 = b[18];
  var b34 = b[19];
  var b40 = b[20];
  var b41 = b[21];
  var b42 = b[22];
  var b43 = b[23];
  var b44 = b[24];

  return [
    a00 * b00 + a01 * b10 + a02 * b20 + a03 * b30 + a04 * b40,
    a00 * b01 + a01 * b11 + a02 * b21 + a03 * b31 + a04 * b41,
    a00 * b02 + a01 * b12 + a02 * b22 + a03 * b32 + a04 * b42,
    a00 * b03 + a01 * b13 + a02 * b23 + a03 * b33 + a04 * b43,
    a00 * b04 + a01 * b14 + a02 * b24 + a03 * b34 + a04 * b44,
    a10 * b00 + a11 * b10 + a12 * b20 + a13 * b30 + a14 * b40,
    a10 * b01 + a11 * b11 + a12 * b21 + a13 * b31 + a14 * b41,
    a10 * b02 + a11 * b12 + a12 * b22 + a13 * b32 + a14 * b42,
    a10 * b03 + a11 * b13 + a12 * b23 + a13 * b33 + a14 * b43,
    a10 * b04 + a11 * b14 + a12 * b24 + a13 * b34 + a14 * b44,
    a20 * b00 + a21 * b10 + a22 * b20 + a23 * b30 + a24 * b40,
    a20 * b01 + a21 * b11 + a22 * b21 + a23 * b31 + a24 * b41,
    a20 * b02 + a21 * b12 + a22 * b22 + a23 * b32 + a24 * b42,
    a20 * b03 + a21 * b13 + a22 * b23 + a23 * b33 + a24 * b43,
    a20 * b04 + a21 * b14 + a22 * b24 + a23 * b34 + a24 * b44,
    a30 * b00 + a31 * b10 + a32 * b20 + a33 * b30 + a34 * b40,
    a30 * b01 + a31 * b11 + a32 * b21 + a33 * b31 + a34 * b41,
    a30 * b02 + a31 * b12 + a32 * b22 + a33 * b32 + a34 * b42,
    a30 * b03 + a31 * b13 + a32 * b23 + a33 * b33 + a34 * b43,
    a30 * b04 + a31 * b14 + a32 * b24 + a33 * b34 + a34 * b44,
    a40 * b00 + a41 * b10 + a42 * b20 + a43 * b30 + a44 * b40,
    a40 * b01 + a41 * b11 + a42 * b21 + a43 * b31 + a44 * b41,
    a40 * b02 + a41 * b12 + a42 * b22 + a43 * b32 + a44 * b42,
    a40 * b03 + a41 * b13 + a42 * b23 + a43 * b33 + a44 * b43,
    a40 * b04 + a41 * b14 + a42 * b24 + a43 * b34 + a44 * b44,
  ];
}

ColorFilter toColorFilterMatrix(List<double> matrix) {
  return ColorFilter.matrix(matrix.sublist(0, 20));
}

Widget execFilterSample(List<double> matrix, Widget child) {
  return ClipRRect(
      child: BackdropFilter(filter: toColorFilterMatrix(matrix), child: child));
}

bool isNotNegative(double v) {
  return v > 0.0;
}

bool isNotDefault(double v) {
  return v != 1.0 && v >= 0.0;
}

execShaderDirectSample(Color color, [Alignment end = Alignment.centerRight]) {
  return (Rect bounds) {
    return LinearGradient(
        end: end,
        colors: [color, color],
        stops: const [0.0, 1.0]).createShader(bounds);
  };
}

execShaderLinearSample(List<Color> colors,
    [Alignment end = Alignment.centerRight,
    List<double> stops = const [0.0, 1.0]]) {
  return (Rect bounds) {
    return LinearGradient(end: end, colors: colors, stops: stops)
        .createShader(bounds);
  };
}

execShaderRadialSample(List<Color> colors,
    [List<double> stops = const [0.0, 1.0], radius = 0.8]) {
  return (Rect bounds) {
    return RadialGradient(
            center: Alignment.center,
            radius: radius,
            colors: colors,
            stops: stops
            // tileMode: TileMode.mirror,
            )
        .createShader(bounds);
  };
}

/// Generates the configuration for applying CSSFilter effects, which is provided to `CSSFilter.apply` for use.
/// Supports chain calls.
///
/// Example:
///
/// ```dart
/// CSSFilter.apply(
///   child: const Text('Hello World!'),
///   value: CSSFilterMatrix().contrast(1.5).sepia(0.4)
/// );
/// ```
class BackdropCSSFilterMatrix {
  Map conf = {};

  BackdropCSSFilterMatrix contrast([double value = 1.0]) {
    conf['contrast'] = value;
    return this;
  }

  BackdropCSSFilterMatrix grayscale([double value = 0.0]) {
    conf['grayscale'] = value;
    return this;
  }

  BackdropCSSFilterMatrix sepia([double value = 0.0]) {
    conf['sepia'] = value;
    return this;
  }

  BackdropCSSFilterMatrix hueRotate([double value = 0.0]) {
    conf['hueRotate'] = value;
    return this;
  }

  BackdropCSSFilterMatrix brightness([double value = 1.0]) {
    conf['brightness'] = value;
    return this;
  }

  BackdropCSSFilterMatrix saturate([double value = 1.0]) {
    conf['saturate'] = value;
    return this;
  }

  BackdropCSSFilterMatrix invert([double value = 0.0]) {
    conf['invert'] = value;
    return this;
  }

  BackdropCSSFilterMatrix blur([double value = 0.0]) {
    conf['blur'] = value;
    return this;
  }

  BackdropCSSFilterMatrix opacity([double value = 1.0]) {
    conf['opacity'] = value;
    return this;
  }
}

至此封裝完畢使用方法

BackdropCSSFilter.blur(
                  value: 10,
                  child: BrnAppBar( ... )   
                ),

效果同理

去除底部小白條

去除白條后的效果

以上就是基于Flutter實(shí)現(xiàn)動(dòng)態(tài)高斯模糊的流程步驟的詳細(xì)內(nèi)容,更多關(guān)于Flutter動(dòng)態(tài)高斯模糊的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論

www久久久久久久久久久| 日本美女性生活一级片| 亚洲av男人的天堂你懂的| 免费69视频在线看| 大白屁股精品视频国产| 日本女大学生的黄色小视频| 欧美精品 日韩国产| 337p日本大胆欧美人| 成人H精品动漫在线无码播放| 中文字幕,亚洲人妻| 亚洲第一伊人天堂网| 38av一区二区三区| 久草免费人妻视频在线| 摧残蹂躏av一二三区| 日韩成人性色生活片| 91精品国产麻豆国产| 日本丰满熟妇大屁股久久| 亚洲va天堂va国产va久| 亚洲成人黄色一区二区三区| 91国产在线视频免费观看| 精品人妻伦一二三区久 | 99精品久久久久久久91蜜桃| 日本特级片中文字幕| 成人av免费不卡在线观看| 最新国产精品网址在线观看| 大尺度激情四射网站| 欧美性受xx黑人性猛交| 中文字幕日韩精品就在这里| 丝袜长腿第一页在线| 福利视频网久久91| 日本一二三中文字幕| 天天摸天天日天天操| 久久久久久久久久一区二区三区 | 在线视频这里只有精品自拍| 中文字幕奴隷色的舞台50| 97人妻无码AV碰碰视频| av亚洲中文天堂字幕网| 精品一区二区三区欧美| 91国产资源在线视频| 玩弄人妻熟妇性色av少妇| 黑人解禁人妻叶爱071| 日韩欧美一级黄片亚洲| 99的爱精品免费视频| 日韩精品中文字幕播放| 红桃av成人在线观看| 亚洲免费国产在线日韩| 在线免费观看日本伦理| 大鸡巴插入美女黑黑的阴毛| 欧美视频综合第一页| 亚洲变态另类色图天堂网| 白白操白白色在线免费视频| 四川五十路熟女av| 亚洲国产精品免费在线观看| 中文字幕日韩精品日本| 婷婷激情四射在线观看视频| 中文字幕日韩精品就在这里| 福利午夜视频在线观看| 91免费观看国产免费| 久久久久久久久久一区二区三区 | 另类av十亚洲av| mm131美女午夜爽爽爽| 喷水视频在线观看这里只有精品| 中文字幕午夜免费福利视频| 农村胖女人操逼视频| 北条麻妃av在线免费观看| 91久久人澡人人添人人爽乱| 日本性感美女视频网站| 亚洲国产最大av综合| 大陆胖女人与丈夫操b国语高清| 亚洲一区二区三区av网站| 天天日天天干天天舔天天射| 国产之丝袜脚在线一区二区三区| 亚洲综合在线视频可播放| 成人亚洲精品国产精品| 国产中文精品在线观看| lutube在线成人免费看| 日本精品视频不卡一二三| 美女日逼视频免费观看| 国内精品在线播放第一页| 97a片免费在线观看| 狠狠躁夜夜躁人人爽天天久天啪| 国产日韩一区二区在线看| 欧洲欧美日韩国产在线| 日韩a级黄色小视频| 青青尤物在线观看视频网站| 国产精品探花熟女在线观看| av一区二区三区人妻| 亚洲人妻视频在线网| 亚洲中文精品字幕在线观看| av中文字幕在线观看第三页| 1000部国产精品成人观看视频| 青草久久视频在线观看| 沈阳熟妇28厘米大战黑人| 黄片三级三级三级在线观看| 日本中文字幕一二区视频| 绯色av蜜臀vs少妇| 91欧美在线免费观看| 精品av久久久久久久| 99久久99久国产黄毛片| 2019av在线视频| 激情人妻校园春色亚洲欧美| 欧美性感尤物人妻在线免费看| 唐人色亚洲av嫩草| 毛片一级完整版免费| 91自产国产精品视频| 在线免费观看黄页视频| 国产精品精品精品999| 日本一区精品视频在线观看| 动色av一区二区三区| 扒开让我视频在线观看| 沙月文乃人妻侵犯中文字幕在线| 9色精品视频在线观看| 欧美日本aⅴ免费视频| 黄工厂精品视频在线观看| 这里只有精品双飞在线播放| 中文字幕网站你懂的| 中文字幕av熟女人妻| 亚洲av黄色在线网站| 9久在线视频只有精品| 亚洲在线一区二区欧美| 欧美日韩精品永久免费网址| 熟女91pooyn熟女| 亚洲Av无码国产综合色区| 五色婷婷综合狠狠爱| 国产精品黄大片在线播放| 一级黄色片夫妻性生活| 新97超碰在线观看| 激情色图一区二区三区| 国产在线观看黄色视频| 亚洲在线免费h观看网站| 欧美精品免费aaaaaa| 国产视频在线视频播放| 岛国一区二区三区视频在线| 日本裸体熟妇区二区欧美| 欧美视频不卡一区四区| 中文字幕日韩91人妻在线| 亚洲狠狠婷婷综合久久app| 天天摸天天干天天操科普| 精品一线二线三线日本| 99精品视频在线观看免费播放| 韩国一级特黄大片做受| 一区二区三区视频,福利一区二区| 蜜桃臀av蜜桃臀av| 最近的中文字幕在线mv视频| 激情五月婷婷综合色啪| 自拍偷拍一区二区三区图片| 亚洲欧美综合在线探花| 狍和女人的王色毛片| 青青在线视频性感少妇和隔壁黑丝| 成人午夜电影在线观看 久久| 搞黄色在线免费观看| 日本美女成人在线视频| 国产成人自拍视频播放| 青青草原网站在线观看| 欧美区一区二区三视频| 熟女少妇激情五十路| 99国内小视频在现欢看| 一级黄片久久久久久久久| 熟女少妇激情五十路| 欧美精品免费aaaaaa| 国产午夜无码福利在线看| 亚洲在线免费h观看网站| 亚洲一区二区久久久人妻| 在线免费观看av日韩| 在线免费观看靠比视频的网站| 干逼又爽又黄又免费的视频| 亚洲av日韩精品久久久| 综合页自拍视频在线播放| 亚洲欧美在线视频第一页| 久久久久久久亚洲午夜综合福利| 欧美伊人久久大香线蕉综合| 老鸭窝在线观看一区| 97黄网站在线观看| 日韩美av高清在线| 亚洲国产香蕉视频在线播放| 日韩成人综艺在线播放| 春色激情网欧美成人| 97欧洲一区二区精品免费| 一区二区在线视频中文字幕| 早川濑里奈av黑人番号| 91成人在线观看免费视频| 欧美一区二区三区久久久aaa| 偷拍美女一区二区三区| 日本成人一区二区不卡免费在线| 大肉大捧一进一出好爽在线视频 | 97国产精品97久久| 欧美老鸡巴日小嫩逼| 日比视频老公慢点好舒服啊| 天天日天天干天天爱| 啊啊好大好爽啊啊操我啊啊视频 | 动漫黑丝美女的鸡巴| 亚洲中文字字幕乱码| 1000小视频在线| 国产精品入口麻豆啊啊啊| 日本av熟女在线视频| 97色视频在线观看| 老师让我插进去69AV| 亚洲精品麻豆免费在线观看| 91桃色成人网络在线观看| 又粗又硬又猛又爽又黄的| 天天操天天干天天日狠狠插| 天天插天天狠天天操| 日韩人妻xxxxx| 骚货自慰被发现爆操| av一本二本在线观看| 国产亚洲视频在线二区| 久久精品国产999| 91久久国产成人免费网站| 97国产在线av精品| 日本美女性生活一级片| 亚洲av无码成人精品区辽| 熟女俱乐部一二三区| 亚洲国产精品久久久久蜜桃| 欧美日韩高清午夜蜜桃大香蕉| 手机看片福利盒子日韩在线播放| 天天干天天插天天谢| a v欧美一区=区三区| 日日夜夜精品一二三| 男生用鸡操女生视频动漫| 日本少妇的秘密免费视频| 自拍偷拍vs一区二区三区| 无忧传媒在线观看视频| 亚洲人一区二区中文字幕| 亚洲精品欧美日韩在线播放| 欧美成人综合视频一区二区 | 97人妻无码AV碰碰视频| 91社福利《在线观看| 4个黑人操素人视频网站精品91| 亚洲1卡2卡三卡4卡在线观看| 成年午夜免费无码区| 午夜久久久久久久99| 特级欧美插插插插插bbbbb| 91精品国产麻豆国产| 国产女人被做到高潮免费视频| 久久久久国产成人精品亚洲午夜| 亚洲1区2区3区精华液| 成年人黄色片免费网站| 91自产国产精品视频| 人妻丝袜精品中文字幕| 欧美日韩亚洲国产无线码| 午夜久久久久久久99| 亚洲无码一区在线影院| 可以在线观看的av中文字幕| 亚洲熟妇无码一区二区三区| 在线观看操大逼视频| 国产黄网站在线观看播放| 亚洲av色香蕉一区二区三区 | 日韩写真福利视频在线观看| 青青青青草手机在线视频免费看| 欧美久久一区二区伊人| 日韩av熟妇在线观看| 大鸡巴插入美女黑黑的阴毛| 亚洲av无女神免非久久| 夜夜嗨av一区二区三区中文字幕| 亚洲成人情色电影在线观看| 蜜桃色婷婷久久久福利在线| 欧美aa一级一区三区四区| 欧美黄色录像免费看的| 快点插进来操我逼啊视频| 国产综合高清在线观看| 激情综合治理六月婷婷| av在线shipin| 久草视频 久草视频2| 午夜国产免费福利av| 国产之丝袜脚在线一区二区三区 | 啊慢点鸡巴太大了啊舒服视频| 欧美亚洲一二三区蜜臀| 国产成人综合一区2区| 韩国爱爱视频中文字幕| 在线免费视频 自拍| 操的小逼流水的文章| 在线免费观看日本伦理| 天天插天天色天天日| 超级av免费观看一区二区三区| 一区二区三区的久久的蜜桃的视频 | 青青草精品在线视频观看| 在线国产日韩欧美视频| 操操网操操伊剧情片中文字幕网| 香蕉aⅴ一区二区三区| 免费人成黄页网站在线观看国产| 偷拍自拍视频图片免费| 成人av久久精品一区二区| 欧美 亚洲 另类综合| 日韩熟女av天堂系列| 亚洲天堂av最新网址| 少妇一区二区三区久久久| 亚洲成人线上免费视频观看| 香蕉片在线观看av| 在线视频免费观看网| 久久这里只有精品热视频| 国产精品日韩欧美一区二区| 亚洲一区二区三区久久午夜| 亚洲中文字字幕乱码| 99精品亚洲av无码国产另类| 把腿张开让我插进去视频| 插逼视频双插洞国产操逼插洞| 黄色成人在线中文字幕| 日韩欧美在线观看不卡一区二区| 亚洲成av人无码不卡影片一| 阿v天堂2014 一区亚洲| 欧美在线一二三视频| 亚洲av自拍偷拍综合| 国产日本精品久久久久久久| 亚洲欧美另类手机在线| 国产性生活中老年人视频网站| 国产精品久久久黄网站| 超鹏97历史在线观看| 成熟熟女国产精品一区| 亚洲欧美日韩视频免费观看| 直接能看的国产av| 丰满少妇人妻xxxxx| 中文字幕一区二 区二三区四区| 亚洲 中文 自拍 无码| 51精品视频免费在线观看| 精品一区二区亚洲欧美| 色噜噜噜噜18禁止观看| 人人妻人人澡人人爽人人dvl| 青青草原网站在线观看| 3337p日本欧洲大胆色噜噜| 午夜免费体验区在线观看| 制服丝袜在线人妻中文字幕| 亚洲欧美一卡二卡三卡| 中国把吊插入阴蒂的视频| 激情国产小视频在线| 国产黄色a级三级三级三级| 免费国产性生活视频| 国产日韩一区二区在线看| 黄色成年网站午夜在线观看| 动漫精品视频在线观看| 亚洲av极品精品在线观看| 日日日日日日日日夜夜夜夜夜夜| 久久免看30视频口爆视频| 黑人借宿ntr人妻的沦陷2| 国产福利小视频二区| 中文字幕一区二区亚洲一区| 91破解版永久免费| 日本一二三中文字幕| 晚上一个人看操B片| 久久这里只有精彩视频免费| 一区二区免费高清黄色视频| 东京热男人的av天堂| 91精品激情五月婷婷在线| 国产又粗又硬又猛的毛片视频| 九一传媒制片厂视频在线免费观看| 班长撕开乳罩揉我胸好爽| 亚洲在线免费h观看网站| av网站色偷偷婷婷网男人的天堂| 91九色porny国产蝌蚪视频| 农村胖女人操逼视频| 亚洲日产av一区二区在线| 福利视频网久久91| tube69日本少妇| huangse网站在线观看| 5528327男人天堂| 九九视频在线精品播放| 亚洲Av无码国产综合色区| 端庄人妻堕落挣扎沉沦| 亚洲一区二区三区精品视频在线| 绝顶痉挛大潮喷高潮无码| av在线免费中文字幕| 日本高清成人一区二区三区| 亚洲综合一区二区精品久久| 中文字幕在线免费第一页| 精品一区二区三四区| 99精品免费久久久久久久久a| 天天操天天射天天操天天天| 日本人竟这样玩学生妹| 日本性感美女三级视频| 国产精品污污污久久| 精品一区二区三四区| 91久久人澡人人添人人爽乱| 女生被男生插的视频网站| 五十路av熟女松本翔子| 青青草人人妻人人妻| 一区二区三区四区五区性感视频 | 中文字幕一区二 区二三区四区| 日韩美女搞黄视频免费| 中国黄色av一级片| 日日操综合成人av| 人人妻人人爽人人澡人人精品| 久久麻豆亚洲精品av| 精品欧美一区二区vr在线观看| 在线观看911精品国产| 青青青aaaa免费| 97少妇精品在线观看| 亚洲精品午夜aaa久久| 狠狠的往里顶撞h百合| 青青热久免费精品视频在线观看| 中文字幕在线欧美精品| 亚洲欧美激情中文字幕| 中文字幕国产专区欧美激情| 亚洲欧美激情国产综合久久久| 99视频精品全部15| 亚洲熟女综合色一区二区三区四区| 中文字幕一区二区亚洲一区| 国产精品熟女久久久久浪潮| 亚洲图库另类图片区| 亚洲1069综合男同| av天堂中文免费在线| 一级黄片大鸡巴插入美女| 自拍偷拍日韩欧美亚洲| 国产av一区2区3区| 天天色天天舔天天射天天爽| weyvv5国产成人精品的视频| 99热久久极品热亚洲| 初美沙希中文字幕在线| 高潮视频在线快速观看国家快速| 啊啊啊想要被插进去视频| 亚国产成人精品久久久| 国产剧情演绎系列丝袜高跟| AV天堂一区二区免费试看| a v欧美一区=区三区| 国产性色生活片毛片春晓精品| 亚洲欧美色一区二区| 在线免费观看欧美小视频| 在线观看免费视频色97| 一区二区视频在线观看免费观看| 亚洲av自拍偷拍综合| 北条麻妃高跟丝袜啪啪| 91大神福利视频网| 熟女妇女老妇一二三区| 在线免费观看亚洲精品电影| 2018最新中文字幕在线观看 | 护士小嫩嫩又紧又爽20p| 黄页网视频在线免费观看| 欧美一区二区三区在线资源| 亚洲人妻30pwc| 91九色国产熟女一区二区| 国产九色91在线观看精品| 国产自拍在线观看成人| 97超碰最新免费在线观看| 国产三级影院在线观看| 男女之间激情网午夜在线| 天天干天天操天天扣| 91极品大一女神正在播放| 国产精品福利小视频a| 黑人借宿ntr人妻的沦陷2| 国产精品午夜国产小视频| 任我爽精品视频在线播放| 97小视频人妻一区二区| 午夜毛片不卡免费观看视频| 日韩欧美中文国产在线| 摧残蹂躏av一二三区| 亚洲高清一区二区三区视频在线| 亚洲熟女女同志女同| 欲满人妻中文字幕在线| 99精品一区二区三区的区| 午夜美女福利小视频| 亚洲第一伊人天堂网| 中字幕人妻熟女人妻a62v网| 99一区二区在线观看| 成人福利视频免费在线| 99婷婷在线观看视频| 天天干天天啪天天舔| 爱有来生高清在线中文字幕| brazzers欧熟精品系列| 美女吃鸡巴操逼高潮视频| 欧洲欧美日韩国产在线| 夜鲁夜鲁狠鲁天天在线| 欧美日本在线观看一区二区| 日本熟妇丰满厨房55| 不卡精品视频在线观看| 日本美女成人在线视频| 中文字幕免费福利视频6| 日本人妻少妇18—xx| 少妇被强干到高潮视频在线观看| 2018最新中文字幕在线观看| 成人av久久精品一区二区| 午夜精品一区二区三区福利视频| 99久久99一区二区三区| 久久这里有免费精品| 最新91九色国产在线观看| 曰本无码人妻丰满熟妇啪啪| 11久久久久久久久久久| 日韩成人免费电影二区| 大香蕉伊人国产在线| 97人人妻人人澡人人爽人人精品| 欧美黑人性猛交xxxxⅹooo| 国产精品自拍偷拍a| 免费人成黄页网站在线观看国产| 自拍偷拍亚洲欧美在线视频| 久久久制服丝袜中文字幕| 超碰97免费人妻麻豆| 在线观看免费岛国av| 亚洲欧美国产麻豆综合| 欧美成人综合色在线噜噜| 亚洲精品麻豆免费在线观看| 天天日天天天天天天天天天天 | 久久久极品久久蜜桃| lutube在线成人免费看| 久久美欧人妻少妇一区二区三区| 一区二区在线观看少妇| 女蜜桃臀紧身瑜伽裤| 91久久精品色伊人6882| 日本啪啪啪啪啪啪啪| a v欧美一区=区三区| 亚洲高清免费在线观看视频| 在线观看免费岛国av| 欧美中文字幕一区最新网址| 91国产在线免费播放| 亚洲成人线上免费视频观看| 不卡日韩av在线观看| 色综合久久久久久久久中文| 国产成人精品久久二区91| 久久久久久久久久一区二区三区| 黑人借宿ntr人妻的沦陷2| free性日本少妇| 欧洲亚洲欧美日韩综合| 天堂v男人视频在线观看| 东京热男人的av天堂| 国产一区成人在线观看视频| 亚洲av男人的天堂你懂的| 女人精品内射国产99| 直接能看的国产av| 国产精品黄片免费在线观看| 不卡日韩av在线观看| 中国老熟女偷拍第一页| 亚洲一级特黄特黄黄色录像片| 亚洲乱码中文字幕在线| 在线观看视频一区麻豆| 99的爱精品免费视频| 亚洲一级 片内射视正片| 92福利视频午夜1000看 | 欧美专区日韩专区国产专区| 免费观看丰满少妇做受| 88成人免费av网站| 好男人视频在线免费观看网站| 亚洲欧美精品综合图片小说| 天天干夜夜操天天舔| 午夜av一区二区三区| 99热这里只有精品中文| 亚洲精品国品乱码久久久久| 中国产一级黄片免费视频播放| av欧美网站在线观看| 成人午夜电影在线观看 久久| 国产乱弄免费视频观看| 亚洲欧美福利在线观看| 51国产成人精品视频| av中文字幕福利网| 欧美成人精品欧美一级黄色| 天堂女人av一区二区| 亚洲av日韩精品久久久久久hd| 在线观看免费岛国av| 大鸡巴操娇小玲珑的女孩逼| 精品日产卡一卡二卡国色天香| 91九色国产熟女一区二区| 日韩精品中文字幕福利| 亚洲免费国产在线日韩| 99re国产在线精品| 老有所依在线观看完整版| 欧美亚洲免费视频观看| 天天日天天干天天干天天日| 免费福利av在线一区二区三区| 天天通天天透天天插| 超碰97人人澡人人| 亚洲激情唯美亚洲激情图片| 国产 在线 免费 精品| 免费69视频在线看| 国产在线自在拍91国语自产精品| 亚洲一区二区激情在线| 骚逼被大屌狂草视频免费看| 38av一区二区三区| 日本又色又爽又黄又粗| 亚洲熟女女同志女同| 国产日韩av一区二区在线| 美女操逼免费短视频下载链接| 大陆av手机在线观看| 久久香蕉国产免费天天| 不卡一不卡二不卡三| 亚洲激情唯美亚洲激情图片| 久草视频 久草视频2| 美女大bxxxx内射| 综合国产成人在线观看| 青青青青青免费视频| 在线国产日韩欧美视频| 国产精品成久久久久三级蜜臀av| 91精品国产91久久自产久强| 亚洲 欧美 精品 激情 偷拍| 中文字幕在线观看极品视频| 98精产国品一二三产区区别| 五十路熟女人妻一区二| 91福利在线视频免费观看| 93精品视频在线观看| 97人人妻人人澡人人爽人人精品| yy96视频在线观看| 日韩黄色片在线观看网站| 日本最新一二三区不卡在线| 亚洲欧美自拍另类图片| 一区二区三区国产精选在线播放| a v欧美一区=区三区| 五十路熟女人妻一区二区9933 | 日本性感美女视频网站| 北条麻妃肉色丝袜视频| 亚洲福利午夜久久久精品电影网 | 欧美日韩一区二区电影在线观看| 欧美一区二区三区激情啪啪啪 | 婷婷六月天中文字幕| 免费看国产又粗又猛又爽又黄视频| 欧美麻豆av在线播放| 国产又粗又硬又猛的毛片视频| av男人天堂狠狠干| 免费观看成年人视频在线观看| 一区国内二区日韩三区欧美| 好了av中文字幕在线| 日韩av有码中文字幕| 精品91自产拍在线观看一区| eeuss鲁片一区二区三区| 午夜精品福利91av| 大胆亚洲av日韩av| 日韩美女综合中文字幕pp| 国产一区二区久久久裸臀| 93人妻人人揉人人澡人人| 97少妇精品在线观看| 天天操天天干天天艹| 制丝袜业一区二区三区| 青青草成人福利电影| 亚洲午夜精品小视频| 天天射夜夜操狠狠干| 成人av中文字幕一区| 人妻熟女在线一区二区| 在线免费视频 自拍| 天天草天天色天天干| 亚洲一区久久免费视频| 亚洲 人妻 激情 中文| 亚洲在线一区二区欧美| 国产+亚洲+欧美+另类| 一区二区三区欧美日韩高清播放| 中文字幕第一页国产在线| 日韩激情文学在线视频| 操操网操操伊剧情片中文字幕网| 日韩无码国产精品强奸乱伦| 日韩av熟妇在线观看| 久久久精品欧洲亚洲av| 涩涩的视频在线观看视频| 国产变态另类在线观看| 色哟哟国产精品入口| 中文字幕国产专区欧美激情| 大鸡吧插逼逼视频免费看| 初美沙希中文字幕在线| 亚洲国际青青操综合网站| 93视频一区二区三区| 日日操夜夜撸天天干| 55夜色66夜色国产精品站| 91国内视频在线观看| 欧美日本在线观看一区二区| 在线观看视频 你懂的| 黄色男人的天堂视频| 色婷婷六月亚洲综合香蕉| 国产亚洲成人免费在线观看| 欧美日本在线视频一区| 成人性黑人一级av| 偷拍自拍国产在线视频| 天码人妻一区二区三区在线看| 自拍偷拍日韩欧美亚洲| 91九色porny国产蝌蚪视频| 国产九色91在线视频| 欧美成人一二三在线网| 精品黑人巨大在线一区| 成年人中文字幕在线观看| 亚洲欧美自拍另类图片| 欧美黑人与人妻精品| 亚洲精品一区二区三区老狼| 偷拍自拍视频图片免费| 懂色av蜜桃a v| 黄色的网站在线免费看 | 9久在线视频只有精品| 五十路av熟女松本翔子| 国产白袜脚足J棉袜在线观看| 在线观看av2025| 女生被男生插的视频网站| 欧美中文字幕一区最新网址 | 成年女人免费播放视频| 岛国免费大片在线观看| jul—619中文字幕在线| 任你操任你干精品在线视频| 绝色少妇高潮3在线观看| 超级碰碰在线视频免费观看| 岛国免费大片在线观看| 久久国产精品精品美女| 中文字幕之无码色多多| 日韩伦理短片在线观看| 福利国产视频在线观看| 在线免费观看黄页视频| 免费在线观看污污视频网站| 日本福利午夜电影在线观看| 亚洲综合色在线免费观看| 国产成人精品午夜福利训2021 | 97香蕉碰碰人妻国产樱花| 97人妻无码AV碰碰视频| 天天躁夜夜躁日日躁a麻豆| 午夜在线观看岛国av,com| 欧美一区二区三区啪啪同性| 经典av尤物一区二区| 亚洲va欧美va人人爽3p| 午夜久久久久久久精品熟女| 亚洲成人熟妇一区二区三区| 在线免费观看亚洲精品电影| 后入美女人妻高清在线| 中国把吊插入阴蒂的视频| 性感美女诱惑福利视频| 非洲黑人一级特黄片| 91综合久久亚洲综合| av天堂中文免费在线| 熟女人妻三十路四十路人妻斩| 欧美老鸡巴日小嫩逼| 97瑟瑟超碰在线香蕉| 日本黄色特一级视频| 中文乱理伦片在线观看| 欧美另类z0z变态| 久久艹在线观看视频| 欧美伊人久久大香线蕉综合| 日韩中文字幕在线播放第二页| 日韩精品激情在线观看| 亚洲精品中文字幕下载| 国产无遮挡裸体免费直播视频| 成人蜜桃美臀九一一区二区三区| 国内资源最丰富的网站| 亚洲老熟妇日本老妇| av天堂加勒比在线| 适合午夜一个人看的视频| 中国黄片视频一区91| 91快播视频在线观看| 亚洲av日韩av第一区二区三区| 搡老妇人老女人老熟女| 九九视频在线精品播放| 天天日天天干天天搡| 黄色三级网站免费下载| 国产av一区2区3区| 国产视频精品资源网站| 欧美精品黑人性xxxx| 国内资源最丰富的网站| 91人妻精品久久久久久久网站| 欧美色呦呦最新网址| 在线视频国产欧美日韩| 人妻在线精品录音叫床| 国产福利小视频二区| 亚洲熟妇无码一区二区三区| 黑人乱偷人妻中文字幕| 免费男阳茎伸入女阳道视频| 抽查舔水白紧大视频| 亚洲美女高潮喷浆视频| 欧美性受xx黑人性猛交| 国产精品亚洲а∨天堂免| 欧美一区二区三区乱码在线播放| 亚洲av人人澡人人爽人人爱| 白嫩白嫩美女极品国产在线观看| 2012中文字幕在线高清| 亚洲区欧美区另类最新章节| 国产大学生援交正在播放| 欧美日韩情色在线观看| 非洲黑人一级特黄片| 日韩精品电影亚洲一区| 经典av尤物一区二区| 97人人模人人爽人人喊| 中文字幕第1页av一天堂网| 天天日天天透天天操| 99的爱精品免费视频| 日韩国产乱码中文字幕| av森泽佳奈在线观看| 亚洲av午夜免费观看| 亚洲人成精品久久久久久久| 黄色视频成年人免费观看| 欧美男人大鸡吧插女人视频| 午夜的视频在线观看| 曰本无码人妻丰满熟妇啪啪| 清纯美女在线观看国产| 久久h视频在线观看| 18禁美女无遮挡免费| 超级福利视频在线观看| AV天堂一区二区免费试看| 激情色图一区二区三区| 天天日天天摸天天爱| 日本阿v视频在线免费观看| 激情伦理欧美日韩中文字幕| 在线观看的黄色免费网站| 成熟丰满熟妇高潮xx×xx| 欧美日韩亚洲国产无线码| 欧美久久一区二区伊人| 老司机欧美视频在线看| 黑人进入丰满少妇视频| 国产男女视频在线播放| 99精品视频在线观看免费播放| 国产 在线 免费 精品| 99国产精品窥熟女精品| 成人免费公开视频无毒 | 老司机在线精品福利视频| 国产在线观看免费人成短视频| 99精品国产aⅴ在线观看| 香港一级特黄大片在线播放| 欧美女同性恋免费a| 国产日韩一区二区在线看| 精品国产高潮中文字幕| 国产揄拍高清国内精品对白| 国产一区二区三免费视频| 偷拍自拍亚洲视频在线观看| 国产刺激激情美女网站| 亚洲欧美综合在线探花| 国产亚洲天堂天天一区| 日韩a级黄色小视频| 亚洲伊人av天堂有码在线| 欧美香蕉人妻精品一区二区| 亚洲 自拍 色综合图| 99人妻视频免费在线| 亚洲午夜精品小视频| 硬鸡巴动态操女人逼视频| 欧美交性又色又爽又黄麻豆| 亚洲精品ww久久久久久| 中国把吊插入阴蒂的视频| 久久久久只精品国产三级| rct470中文字幕在线| 色婷婷精品大在线观看| 中字幕人妻熟女人妻a62v网 | 色综合天天综合网国产成人| 婷婷综合亚洲爱久久| 国产精品污污污久久| 超污视频在线观看污污污| 黄色黄色黄片78在线| 国产成人自拍视频在线免费观看| 青青青aaaa免费| 在线免费观看日本伦理| 偷青青国产精品青青在线观看| 中国老熟女偷拍第一页| 999热精品视频在线| 亚洲精品精品国产综合| 午夜毛片不卡在线看| 亚洲乱码中文字幕在线| 日韩欧美在线观看不卡一区二区 | 在线国产精品一区二区三区| 人妻爱爱 中文字幕| 人妻无码中文字幕专区| 精品美女久久久久久| 97色视频在线观看| 综合一区二区三区蜜臀| 班长撕开乳罩揉我胸好爽| 93人妻人人揉人人澡人人| 蜜桃视频17c在线一区二区| 沙月文乃人妻侵犯中文字幕在线| 男女第一次视频在线观看| 99精品一区二区三区的区| 天天干天天操天天扣| 一区二区三区综合视频| 99久久超碰人妻国产| 91久久人澡人人添人人爽乱| 欧美成人黄片一区二区三区| 久草视频福利在线首页| 大胸性感美女羞爽操逼毛片| 黄色视频在线观看高清无码| 91精品免费久久久久久| 免费观看国产综合视频| 91国内精品自线在拍白富美| 三级黄色亚洲成人av| 一区二区三区美女毛片| 91成人精品亚洲国产| 欧美激情精品在线观看| 亚洲精品av在线观看| 91国产在线视频免费观看| 亚洲成人情色电影在线观看| 五月天久久激情视频| 欧美一区二区中文字幕电影 | 青青青青视频在线播放| 人妻熟女中文字幕aⅴ在线| 可以免费看的www视频你懂的| 亚洲第一伊人天堂网| 成年午夜免费无码区| 日韩av有码中文字幕| 久久精品亚洲国产av香蕉| 欧美一级视频一区二区| 国产精品黄页网站视频| 熟女少妇激情五十路| 最新国产亚洲精品中文在线| 在线免费观看国产精品黄色| 99一区二区在线观看| 亚洲熟妇x久久av久久| 国内资源最丰富的网站| 99久久99一区二区三区| 国产a级毛久久久久精品| 中文字幕人妻av在线观看| 韩国一级特黄大片做受| 国产美女午夜福利久久| gav成人免费播放| 国产av福利网址大全| 国产成人自拍视频播放| 中文字幕最新久久久| 啪啪啪啪啪啪啪免费视频| 1000部国产精品成人观看视频 | 非洲黑人一级特黄片| 粉嫩小穴流水视频在线观看| 五十路av熟女松本翔子| av一本二本在线观看| 国产一区二区三免费视频| 91大屁股国产一区二区| 亚洲精品欧美日韩在线播放| 熟女人妻三十路四十路人妻斩| 四虎永久在线精品免费区二区| 91麻豆精品91久久久久同性| 2022国产综合在线干| 天天射夜夜操狠狠干| 91极品新人『兔兔』精品新作| 国产品国产三级国产普通话三级| 亚洲国际青青操综合网站| 亚洲欧美成人综合视频| 亚洲av日韩高清hd| 综合激情网激情五月五月婷婷| 中文字幕日本人妻中出| 少妇高潮无套内谢麻豆| 2020国产在线不卡视频 | 骚货自慰被发现爆操| 黄色片黄色片wyaa| 国产精品久久久久久美女校花| 美女被肏内射视频网站| 超污视频在线观看污污污| 国产精品自偷自拍啪啪啪| 美女张开两腿让男人桶av| 91chinese在线视频| 国产美女午夜福利久久| 99热久久极品热亚洲| 午夜毛片不卡免费观看视频| 日本精品一区二区三区在线视频。| 精品91高清在线观看| 日本最新一二三区不卡在线| 91大屁股国产一区二区| 国产第一美女一区二区三区四区| 国产夫妻视频在线观看免费| 少妇系列一区二区三区视频| 亚洲欧美清纯唯美另类| 中文字幕高清在线免费播放| 青草青永久在线视频18| 成人蜜桃美臀九一一区二区三区 | 国产精品久久久黄网站| 啊用力插好舒服视频| 青青青视频手机在线观看| 含骚鸡巴玩逼逼视频| 亚洲免费国产在线日韩| 蜜桃精品久久久一区二区| 亚洲熟妇x久久av久久| 桃色视频在线观看一区二区| 人人爱人人妻人人澡39| 任我爽精品视频在线播放| 欧洲精品第一页欧洲精品亚洲| 91传媒一区二区三区| 99re国产在线精品| 亚洲精品国偷自产在线观看蜜桃| 欧美香蕉人妻精品一区二区| 91片黄在线观看喷潮| 亚洲 清纯 国产com| 人妻少妇精品久久久久久| 久久免看30视频口爆视频| 青草久久视频在线观看| 国产乱弄免费视频观看| 2021年国产精品自拍| 欧美一区二区三区啪啪同性| 鸡巴操逼一级黄色气| 超碰97人人澡人人| 精品少妇一二三视频在线| 18禁精品网站久久| 中文字幕奴隷色的舞台50| 久久精品国产999| 日韩黄色片在线观看网站| 一区二区三区国产精选在线播放| 久久久精品国产亚洲AV一| 91精品资源免费观看| 亚洲一区二区三区久久受| 亚洲国产香蕉视频在线播放| 久久精品在线观看一区二区| 熟女人妻在线观看视频| 韩国黄色一级二级三级| 18禁美女无遮挡免费| 久久一区二区三区人妻欧美| 99精品视频在线观看免费播放| 国产福利小视频免费观看| 国产又粗又黄又硬又爽| 亚洲国产精品黑丝美女| 亚洲青青操骚货在线视频| 激情啪啪啪啪一区二区三区 | 超碰97人人澡人人| 中国无遮挡白丝袜二区精品| 性感美女高潮视频久久久| 欧美精品一区二区三区xxxx| 日日夜夜精品一二三| 免费看国产av网站| 骚逼被大屌狂草视频免费看| 社区自拍揄拍尻屁你懂的| 一区二区三区四区视频| heyzo蜜桃熟女人妻| 欧美另类重口味极品在线观看| 超污视频在线观看污污污 | 91免费福利网91麻豆国产精品| 999九九久久久精品| 成人免费毛片aaaa| 亚洲成人国产av在线| 亚洲av无女神免非久久| 最新97国产在线视频| 亚洲欧美清纯唯美另类 | 天天日天天鲁天天操| 蜜桃久久久久久久人妻| 免费在线福利小视频| 丝袜美腿欧美另类 中文字幕| 婷婷久久一区二区字幕网址你懂得| 亚洲欧美一区二区三区爱爱动图| 五十路熟女人妻一区二| 淫秽激情视频免费观看| 小穴多水久久精品免费看| 99热久久这里只有精品8| 四虎永久在线精品免费区二区| 国产实拍勾搭女技师av在线| 欧美一区二区三区高清不卡tv| 亚洲一区二区人妻av| 人妻自拍视频中国大陆| 中文字幕高清在线免费播放 | 中文字幕熟女人妻久久久| 亚洲av男人天堂久久| 亚洲1区2区3区精华液| 初美沙希中文字幕在线| 色婷婷六月亚洲综合香蕉| 天天操天天干天天艹| 亚洲 中文 自拍 无码| 天天干天天操天天摸天天射| 亚洲欧美自拍另类图片| 国产一级麻豆精品免费| 超碰97免费人妻麻豆| 天天操天天干天天插| 69精品视频一区二区在线观看| 黄色录像鸡巴插进去| 黄色中文字幕在线播放| 久久国产精品精品美女| 伊人情人综合成人久久网小说| 啊用力插好舒服视频| 国产亚洲精品欧洲在线观看| 很黄很污很色的午夜网站在线观看| 天天躁日日躁狠狠躁av麻豆| 欧美成人综合色在线噜噜| 国产精品三级三级三级| 538精品在线观看视频| 中国老熟女偷拍第一页| 久久99久久99精品影院| 亚洲一区二区三区av网站| 国产不卡av在线免费| 亚洲色偷偷综合亚洲AV伊人| 伊人网中文字幕在线视频| 亚洲变态另类色图天堂网| 韩国爱爱视频中文字幕| 少妇被强干到高潮视频在线观看| 亚洲区美熟妇久久久久| 国产三级片久久久久久久| 2021年国产精品自拍| 中文字幕av第1页中文字幕| 美女视频福利免费看| 久久久制服丝袜中文字幕| 青青青青青手机视频| 黄色成人在线中文字幕| 久久这里只有精品热视频| 日本人妻少妇18—xx| 青青草国内在线视频精选| 亚洲av成人免费网站| 亚洲欧美另类手机在线| 韩国女主播精品视频网站| 免费手机黄页网址大全| 专门看国产熟妇的网站| 欧美一区二区三区四区性视频| 精品suv一区二区69| 午夜免费体验区在线观看| 伊人综合aⅴ在线网| 亚洲欧美激情中文字幕| 青青草国内在线视频精选| 最后99天全集在线观看| 国产精品一区二区av国| 97超碰人人搞人人| 2019av在线视频| 丝袜长腿第一页在线| 伊人综合免费在线视频| 亚洲欧美综合在线探花| 天天躁日日躁狠狠躁av麻豆| 精品亚洲国产中文自在线| 77久久久久国产精产品| 白白操白白色在线免费视频| 成年人该看的视频黄免费| 天天摸天天日天天操| 欧美爆乳肉感大码在线观看| 中文字日产幕乱六区蜜桃| 丰满的子国产在线观看| 黄色录像鸡巴插进去| 日韩剧情片电影在线收看| 午夜精品在线视频一区| 日日夜夜狠狠干视频| 日本一本午夜在线播放| 国产综合精品久久久久蜜臀| 亚洲成人av在线一区二区| 黄色三级网站免费下载| 亚洲国产在线精品国偷产拍| 97精品成人一区二区三区| 熟女91pooyn熟女| 亚洲第一黄色在线观看| 亚洲精品 日韩电影| 亚洲精品乱码久久久久久密桃明| 日韩不卡中文在线视频网站| av在线免费中文字幕| 99精品国产自在现线观看| 扒开腿挺进肉嫩小18禁视频| 日韩a级黄色小视频| 国产97视频在线精品| 欧美日本国产自视大全| 中文字幕乱码人妻电影| 偷拍自拍亚洲美腿丝袜| 大香蕉大香蕉在线看| 天天日天天摸天天爱| 亚洲高清免费在线观看视频| 日本在线不卡免费视频| av一本二本在线观看| 在线观看国产网站资源| huangse网站在线观看| 国产自拍在线观看成人| 亚洲av男人的天堂你懂的| 91久久人澡人人添人人爽乱| 888欧美视频在线| 色呦呦视频在线观看视频| 欲满人妻中文字幕在线| 欧美日韩v中文在线| 99久久久无码国产精品性出奶水| 性感美女高潮视频久久久| 欧美视频中文一区二区三区| 大香蕉福利在线观看| 蜜臀av久久久久久久| 久碰精品少妇中文字幕av| 亚洲精品国产综合久久久久久久久| 国产一区二区三免费视频| 91精品一区二区三区站长推荐| 国产自拍黄片在线观看| 晚上一个人看操B片| 国产伦精品一区二区三区竹菊| 日韩二区视频一线天婷婷五| 又色又爽又黄又刺激av网站| 色婷婷综合激情五月免费观看| 日韩欧美在线观看不卡一区二区| 韩国女主播精品视频网站| 欧洲欧美日韩国产在线| 丰满少妇人妻xxxxx| 一二三中文乱码亚洲乱码one| 成人av在线资源网站| 国产欧美精品免费观看视频| 成人网18免费视频版国产| 欧美性受xx黑人性猛交| 91国产在线视频免费观看| 天天躁日日躁狠狠躁av麻豆| 欧美地区一二三专区| 在线播放 日韩 av| 亚洲国产成人av在线一区| 五月婷婷在线观看视频免费| 天天操天天污天天射| 神马午夜在线观看视频| 精品一线二线三线日本| 欧美男人大鸡吧插女人视频| 亚洲人妻av毛片在线| 色在线观看视频免费的| 人妻少妇精品久久久久久 | 91社福利《在线观看| 男人天堂av天天操| 精品人妻伦一二三区久| 国产精品久久久久国产三级试频| 早川濑里奈av黑人番号| 人妻熟女在线一区二区| 天天干天天爱天天色| 2022国产精品视频| 无码国产精品一区二区高潮久久4| 国产午夜男女爽爽爽爽爽视频| 干逼又爽又黄又免费的视频| 在线观看免费av网址大全| 欧美乱妇无乱码一区二区| 国产丰满熟女成人视频| 激情五月婷婷综合色啪| 三级av中文字幕在线观看| 青娱乐最新视频在线| 2025年人妻中文字幕乱码在线 | 久久久久久97三级| 日韩人妻在线视频免费| 五月天中文字幕内射| 538精品在线观看视频| 亚洲色偷偷综合亚洲AV伊人| 久久一区二区三区人妻欧美| 内射久久久久综合网| 婷婷五月亚洲综合在线| 大陆胖女人与丈夫操b国语高清| 中文字幕人妻av在线观看| 啊慢点鸡巴太大了啊舒服视频| 久久丁香花五月天色婷婷| 国产精选一区在线播放| 啊慢点鸡巴太大了啊舒服视频| 快点插进来操我逼啊视频| 天堂av中文在线最新版| 日韩午夜福利精品试看| 亚洲精品成人网久久久久久小说| 另类av十亚洲av| 日韩精品啪啪视频一道免费| 中文字日产幕乱六区蜜桃| 男生舔女生逼逼视频| 久久丁香婷婷六月天| 中文字幕av第1页中文字幕| 国产精品午夜国产小视频| 国产麻豆剧果冻传媒app| 亚洲精品欧美日韩在线播放| 久久久久久久久久久久久97| 最新国产精品拍在线观看| 精品国产成人亚洲午夜| 99精品国产免费久久| 国产一级精品综合av| 日本高清撒尿pissing| 欧美中文字幕一区最新网址| 国产日韩欧美视频在线导航| 国产又粗又猛又爽又黄的视频美国| 中文字幕无码日韩专区免费| 2021久久免费视频| 久草视频福利在线首页| 在线制服丝袜中文字幕| 欧美精品国产综合久久| 国产性感美女福利视频| 黄色片年轻人在线观看| 国产精品一区二区av国| 天天色天天操天天透| 成人资源在线观看免费官网| 日日夜夜大香蕉伊人| 日韩伦理短片在线观看| 欧美日韩情色在线观看| 97a片免费在线观看| 青青社区2国产视频| 国产精品久久久黄网站| 日本黄色三级高清视频| 国产精品久久久久网| 亚洲熟妇久久无码精品| 中文字幕第三十八页久久| aaa久久久久久久久| 亚洲中文精品人人免费| 欧美男同性恋69视频| 人妻3p真实偷拍一二区| 亚洲 中文 自拍 另类 欧美| 亚洲第一伊人天堂网| 熟女人妻一区二区精品视频| 免费观看成年人视频在线观看| 亚洲麻豆一区二区三区| 乱亲女秽乱长久久久| 国产不卡av在线免费| 久久久久久cao我的性感人妻| 欧美日本在线视频一区| 一二三中文乱码亚洲乱码one| 动漫美女的小穴视频| 日本韩国免费福利精品| 久久艹在线观看视频| 韩国AV无码不卡在线播放| 亚洲人成精品久久久久久久| 免费手机黄页网址大全| 中文字幕欧美日韩射射一| 亚洲高清视频在线不卡| 欧美日韩v中文在线| 男生舔女生逼逼视频| 黄色片黄色片wyaa| av一本二本在线观看| 91小伙伴中女熟女高潮| 三级黄色亚洲成人av| 免费看美女脱光衣服的视频| 国产污污污污网站在线| 欧美viboss性丰满| 亚洲 清纯 国产com| 亚洲成人情色电影在线观看| 久久久久久国产精品| 欧美专区日韩专区国产专区| 国产美女精品福利在线| 在线观看免费岛国av| 六月婷婷激情一区二区三区| 丁香花免费在线观看中文字幕| eeuss鲁片一区二区三区| 国产综合高清在线观看| 国产综合高清在线观看| 欲满人妻中文字幕在线| 插小穴高清无码中文字幕| 91天堂天天日天天操| 日本丰满熟妇BBXBBXHD| 深田咏美亚洲一区二区| 天天操天天射天天操天天天| 9l人妻人人爽人人爽| 亚洲精品色在线观看视频| 国产无遮挡裸体免费直播视频| 91老师蜜桃臀大屁股| 一区二区在线观看少妇| 大鸡八强奸视频在线观看| av天堂中文免费在线| 国产精品自拍偷拍a| 日韩近亲视频在线观看| 啪啪啪啪啪啪啪免费视频| 中文字幕亚洲久久久| 2020国产在线不卡视频 | 黄色片一级美女黄色片| 在线免费观看日本伦理| 中文字幕高清资源站| 91高清成人在线视频| 国产午夜亚洲精品不卡在线观看| 熟女人妻在线中出观看完整版| 欧美aa一级一区三区四区| 国产熟妇乱妇熟色T区| 亚洲精品色在线观看视频| 成人24小时免费视频| 日视频免费在线观看| 中文字幕,亚洲人妻| 四虎永久在线精品免费区二区| 黄页网视频在线免费观看| 大鸡巴操b视频在线| 亚洲日本一区二区三区| 一区二区三区四区五区性感视频| 亚洲国产在人线放午夜| 亚洲码av无色中文| 337p日本大胆欧美人| 92福利视频午夜1000看| 亚洲中文精品人人免费| 新97超碰在线观看| 大陆胖女人与丈夫操b国语高清| 日韩剧情片电影在线收看| 日本最新一二三区不卡在线| 日韩影片一区二区三区不卡免费| 九色porny九色9l自拍视频| 含骚鸡巴玩逼逼视频| 玖玖一区二区在线观看| 91大屁股国产一区二区| 粉嫩av蜜乳av蜜臀| 日韩成人免费电影二区| 亚洲一区二区三区精品视频在线| 在线观看免费av网址大全| 午夜大尺度无码福利视频| 欧美va不卡视频在线观看| 性色蜜臀av一区二区三区| 新婚人妻聚会被中出| 亚洲 自拍 色综合图| 99久久久无码国产精品性出奶水| 69精品视频一区二区在线观看| 超碰97人人澡人人| 国产精品自拍视频大全| 国产日韩av一区二区在线| 中文字幕人妻被公上司喝醉在线| 老鸭窝日韩精品视频观看| 天天草天天色天天干| 亚洲国产精品久久久久久6| 亚洲一级av无码一级久久精品| 亚洲图库另类图片区| 久久久制服丝袜中文字幕| 都市激情校园春色狠狠| 粉嫩av懂色av蜜臀av| 欧美中文字幕一区最新网址| 欧美日韩国产一区二区三区三州| 人妻爱爱 中文字幕| 91大屁股国产一区二区| 人人妻人人澡欧美91精品| 欧美80老妇人性视频| 免费69视频在线看| 成人av亚洲一区二区| AV无码一区二区三区不卡| 男人的天堂在线黄色| 热久久只有这里有精品| 六月婷婷激情一区二区三区| 亚洲综合在线观看免费| 最新国产精品网址在线观看| 国产女人叫床高潮大片视频| 欧美伊人久久大香线蕉综合| 91超碰青青中文字幕| 婷婷午夜国产精品久久久| 在线观看国产免费麻豆| a v欧美一区=区三区| 国产又粗又黄又硬又爽| 黄片三级三级三级在线观看| 久久久久五月天丁香社区| 中文字幕一区二区自拍| 国产在线91观看免费观看| 又大又湿又爽又紧A视频| 亚洲精品国品乱码久久久久| 337p日本大胆欧美人| 国产午夜福利av导航| 一色桃子人妻一区二区三区| 大香蕉福利在线观看| 少妇与子乱在线观看| 亚洲精品无码色午夜福利理论片| 欧美精产国品一二三区| 国产麻豆剧传媒精品国产av蜜桃| 欧美精品 日韩国产| jiuse91九色视频| 天天躁日日躁狠狠躁av麻豆| 玩弄人妻熟妇性色av少妇| 午夜在线观看岛国av,com| 亚洲免费国产在线日韩| 伊人成人综合开心网| 亚洲福利天堂久久久久久 | 欧美日韩精品永久免费网址| 亚洲午夜伦理视频在线 | 男人操女人的逼免费视频| 中文字幕第1页av一天堂网| 天天操夜夜操天天操天天操| 中文字幕一区二区三区蜜月| 欧美激情精品在线观看| 欧美亚洲偷拍自拍色图| 天天日天天添天天爽| 91精品资源免费观看| 丰满少妇人妻xxxxx| 天天通天天透天天插| 午夜在线观看一区视频| 日本韩国免费一区二区三区视频| 激情小视频国产在线| 视频一区 二区 三区 综合| 欧美特级特黄a大片免费| 黄色中文字幕在线播放| 天堂av在线播放免费| 亚洲一区自拍高清免费视频| 欧美一级片免费在线成人观看| 视频 一区二区在线观看| 中文字幕 亚洲av| 97精品人妻一区二区三区精品| 人妻凌辱欧美丰满熟妇| 亚洲一区久久免费视频| 亚洲最大黄 嗯色 操 啊| 大屁股肉感人妻中文字幕在线| 一区二区在线观看少妇| 亚洲一级av大片免费观看| 男人靠女人的逼视频| 丝袜长腿第一页在线| aⅴ精产国品一二三产品| 国产精品久久久黄网站| 福利一二三在线视频观看 | av成人在线观看一区| 黄色大片免费观看网站| 国产精品国产三级国产精东 | 国内精品在线播放第一页| 日本免费一级黄色录像| 天天通天天透天天插| 超级福利视频在线观看| 大陆精品一区二区三区久久| 中文字幕日韩精品日本| 欧美精品欧美极品欧美视频 | 视频一区二区综合精品| 欧美美女人体视频一区| okirakuhuhu在线观看| 青青色国产视频在线| 欧美日韩一区二区电影在线观看 | 久精品人妻一区二区三区| 免费啪啪啪在线观看视频| 91p0rny九色露脸熟女| 成人av免费不卡在线观看| 337p日本大胆欧美人| 中文 成人 在线 视频| 青青草国内在线视频精选| 人人妻人人澡欧美91精品| 丝袜美腿欧美另类 中文字幕| av中文字幕在线观看第三页| 一区二区麻豆传媒黄片| 直接能看的国产av| 人妻爱爱 中文字幕| 自拍偷拍 国产资源| 国产一级精品综合av| 国产视频网站一区二区三区| 男人和女人激情视频| 热久久只有这里有精品| 国产综合高清在线观看| 丰满熟女午夜福利视频| 免费黄高清无码国产| 国产又粗又猛又爽又黄的视频美国| 日韩美av高清在线| 大香蕉玖玖一区2区| 日韩精品一区二区三区在线播放| 中文字幕无码一区二区免费| 天天日夜夜操天天摸| 91人妻精品一区二区久久| 久久久久久久久久一区二区三区| 亚洲成人午夜电影在线观看| 无忧传媒在线观看视频| 日韩熟女av天堂系列| 福利视频广场一区二区| 一区二区三区久久中文字幕| 日韩中文字幕在线播放第二页 | 性色av一区二区三区久久久| 1024久久国产精品| 欧美成人猛片aaaaaaa| 亚洲精品国产久久久久久| 2012中文字幕在线高清| 99精品视频之69精品视频| 夫妻在线观看视频91| 99久久激情婷婷综合五月天| 91国内视频在线观看| 这里有精品成人国产99| 日韩近亲视频在线观看| 久草视频 久草视频2| 亚洲精品无码色午夜福利理论片| 人妻丰满熟妇综合网| 日本女人一级免费片| 国产精彩福利精品视频| 成年人午夜黄片视频资源| 欧美黄片精彩在线免费观看| 欧美日本国产自视大全| 天天日天天舔天天射进去| 国产精品自偷自拍啪啪啪| 99久久成人日韩欧美精品| 成人网18免费视频版国产| 午夜精品一区二区三区更新| 亚洲国产成人av在线一区| 99精品免费观看视频| 日本后入视频在线观看| 国产精品久久久久久久久福交| 成人H精品动漫在线无码播放| 2o22av在线视频| 日本特级片中文字幕| 中文字幕之无码色多多| 中文字幕午夜免费福利视频| 最后99天全集在线观看| 2020久久躁狠狠躁夜夜躁| 少妇人妻100系列| 亚洲少妇高潮免费观看| 日本午夜久久女同精女女| 亚洲av天堂在线播放| 精品国产在线手机在线| 91大神福利视频网| 国产精品手机在线看片| 97人妻色免费视频| 国产精品久久9999| 高潮视频在线快速观看国家快速| 亚洲天堂精品久久久| 亚洲最大黄了色网站| 2020av天堂网在线观看| 免费一级黄色av网站| 亚洲熟色妇av日韩熟色妇在线| 中文字幕在线欧美精品| 一区二区三区四区视频在线播放 | 亚洲人妻av毛片在线| 动漫精品视频在线观看| 婷婷久久久久深爱网| 少妇露脸深喉口爆吞精| 97a片免费在线观看| 岛国青草视频在线观看| 男女第一次视频在线观看| 婷婷久久久综合中文字幕| 国产97在线视频观看| 国产91精品拍在线观看| 最新中文字幕免费视频| www天堂在线久久| 欧洲国产成人精品91铁牛tv| 丝袜长腿第一页在线| 少妇人妻真实精品视频| 亚洲免费在线视频网站| 午夜的视频在线观看| 人妻少妇性色欲欧美日韩| 亚洲黄色av网站免费播放| 午夜蜜桃一区二区三区| 成年人午夜黄片视频资源| 91色九色porny| 亚洲日本一区二区三区| av天堂中文字幕最新| 91麻豆精品传媒国产黄色片| 亚洲av色香蕉一区二区三区| 中文字幕高清在线免费播放| 中文字幕奴隷色的舞台50| 日本少妇的秘密免费视频| 久久丁香婷婷六月天| 啊慢点鸡巴太大了啊舒服视频| 1769国产精品视频免费观看| 初美沙希中文字幕在线| 国产精品人久久久久久| 女蜜桃臀紧身瑜伽裤| 亚洲 人妻 激情 中文| 免费在线看的黄网站| 性生活第二下硬不起来| 国产精品人妻一区二区三区网站| 插小穴高清无码中文字幕| 北条麻妃高跟丝袜啪啪| 日本阿v视频在线免费观看| 自拍偷拍 国产资源| 国产黄色片在线收看| 天天干天天操天天插天天日| 国产 在线 免费 精品| 美女在线观看日本亚洲一区| 国产精品黄色的av| 国产成人精品av网站| 亚洲精品午夜aaa久久| 亚洲1069综合男同| 99精品久久久久久久91蜜桃| 国产品国产三级国产普通话三级| 97精品成人一区二区三区| 国产精彩福利精品视频| 欧美日韩人妻久久精品高清国产 | 揄拍成人国产精品免费看视频| 久青青草视频手机在线免费观看 | 黄色大片男人操女人逼| 99久久超碰人妻国产| 18禁美女黄网站色大片下载| 五十路人妻熟女av一区二区| 视频 一区二区在线观看| 国产一级麻豆精品免费| 国产高清97在线观看视频| 成人高潮aa毛片免费| 日本a级视频老女人| 亚洲午夜伦理视频在线| 91成人在线观看免费视频| 日美女屁股黄邑视频| 十八禁在线观看地址免费| 97香蕉碰碰人妻国产樱花| 欧亚日韩一区二区三区观看视频| 亚洲综合图片20p| 91麻豆精品91久久久久同性| 久久精品36亚洲精品束缚| 欧美日本aⅴ免费视频| 亚洲图库另类图片区| 中文字幕网站你懂的| 一区二区三区另类在线 | 国产福利在线视频一区| 97国产在线观看高清| 视频 国产 精品 熟女 | 韩国AV无码不卡在线播放| 97黄网站在线观看| 国产激情av网站在线观看| 日韩美av高清在线| 国产精品一区二区久久久av| 免费男阳茎伸入女阳道视频 | 狠狠躁狠狠爱网站视频 | 97瑟瑟超碰在线香蕉| 美女福利视频网址导航| 91人妻精品一区二区在线看| 日本三极片视频网站观看| 中文字幕乱码人妻电影| 中文字幕在线乱码一区二区| 久久久超爽一二三av| 大香蕉福利在线观看| 精品美女福利在线观看| 中文字幕AV在线免费看 | 99久久超碰人妻国产| h国产小视频福利在线观看| 国产综合视频在线看片| 国产乱子伦精品视频潮优女| 精品国产午夜视频一区二区| av黄色成人在线观看| 精品suv一区二区69| 欧美男人大鸡吧插女人视频| av网址国产在线观看| 国产激情av网站在线观看| 国产欧美精品不卡在线| 天天日天天爽天天爽| 亚洲 中文字幕在线 日韩| brazzers欧熟精品系列| 人人爱人人妻人人澡39| 国产性色生活片毛片春晓精品 | 亚洲一区二区激情在线| 性感美女诱惑福利视频| 男人天堂av天天操| 免费观看污视频网站| 欧美aa一级一区三区四区| 91精品国产91久久自产久强| 国产精品大陆在线2019不卡| 老熟妇凹凸淫老妇女av在线观看| 免费看国产av网站| 午夜精品福利一区二区三区p| 一区二区三区的久久的蜜桃的视频 | 1024久久国产精品| 最近的中文字幕在线mv视频| 黄色录像鸡巴插进去| 亚洲一区二区三区五区| 老司机你懂得福利视频| 日韩一个色综合导航| 国产va精品免费观看| 国产在线观看免费人成短视频| 大学生A级毛片免费视频| 亚洲国产在人线放午夜| tube69日本少妇| www日韩毛片av| 国产精品久久久久久久久福交| 精品91自产拍在线观看一区| 亚洲一区制服丝袜美腿| 日韩美女搞黄视频免费| 2022国产精品视频| 午夜福利人人妻人人澡人人爽| 成年女人免费播放视频| 天天操天天爽天天干| 内射久久久久综合网| 啊啊啊视频试看人妻| 新婚人妻聚会被中出| 中国视频一区二区三区| 2022精品久久久久久中文字幕| 日韩三级电影华丽的外出| 免费观看丰满少妇做受| 强行扒开双腿猛烈进入免费版| 人人妻人人人操人人人爽| 亚洲中文字字幕乱码| 日韩欧美制服诱惑一区在线| 国产美女精品福利在线| 成年人午夜黄片视频资源| 色婷婷六月亚洲综合香蕉| 国产又粗又黄又硬又爽| 亚洲2021av天堂| www骚国产精品视频| 久草福利电影在线观看| 一级黄色片夫妻性生活| 97香蕉碰碰人妻国产樱花| 日本女大学生的黄色小视频| 日本人妻少妇18—xx| 亚洲高清国产自产av| 97国产在线观看高清| 一个人免费在线观看ww视频| 黄片色呦呦视频免费看| 国产性色生活片毛片春晓精品 | 国产精品中文av在线播放| 可以免费看的www视频你懂的| 亚洲视频在线观看高清| 欧美激情电影免费在线| 亚洲精品三级av在线免费观看| 国产熟妇人妻ⅹxxxx麻豆| 大陆av手机在线观看| aⅴ五十路av熟女中出| 国产精品自拍在线视频| 风流唐伯虎电视剧在线观看 | 大香蕉大香蕉在线有码 av| 亚洲精品av在线观看| 九色精品视频在线播放| av在线免费中文字幕| 色爱av一区二区三区| 亚洲男人让女人爽的视频| 精品一区二区三区三区色爱| 在线免费观看日本伦理| 午夜影院在线观看视频羞羞羞| 偷拍自拍亚洲视频在线观看| 在线视频免费观看网| 天天日天天摸天天爱| 青青青青青手机视频| 2019av在线视频| 成年人该看的视频黄免费| 99亚洲美女一区二区三区| 亚洲欧美一区二区三区电影| 四川乱子伦视频国产vip| 国产极品精品免费视频| 欧美老妇精品另类不卡片| 国产精品国产三级麻豆| 亚洲 国产 成人 在线| 91久久综合男人天堂| 337p日本大胆欧美人| 成人免费公开视频无毒| 日本性感美女写真视频| 日本一区精品视频在线观看| 国产又粗又黄又硬又爽| 天堂av狠狠操蜜桃| 国产一区av澳门在线观看| 66久久久久久久久久久| 美味人妻2在线播放| 98精产国品一二三产区区别| 日本午夜久久女同精女女| 亚洲av午夜免费观看| 97人人妻人人澡人人爽人人精品| 国产激情av网站在线观看| 91‖亚洲‖国产熟女| 日韩中文字幕精品淫| 欧美亚洲免费视频观看| 精品美女久久久久久| 精品国产亚洲av一淫| 成熟丰满熟妇高潮xx×xx| yellow在线播放av啊啊啊| 日本黄在免费看视频| 欧美性受xx黑人性猛交| 91免费福利网91麻豆国产精品| 偷拍美女一区二区三区| 视频二区在线视频观看| 2021年国产精品自拍| 日韩欧美国产精品91| 日韩三级电影华丽的外出| 中文字幕熟女人妻久久久| 熟女少妇激情五十路| av新中文天堂在线网址| 午夜久久久久久久精品熟女| 国产内射中出在线观看| 亚洲激情唯美亚洲激情图片| 一级a看免费观看网站| 91欧美在线免费观看| 日本啪啪啪啪啪啪啪| 啪啪啪啪啪啪啪啪av| 日韩人妻xxxxx| 国产九色91在线观看精品| 日日操夜夜撸天天干| 日本一道二三区视频久久| 99视频精品全部15| 福利一二三在线视频观看| 欧美一区二区三区激情啪啪啪| 国产精品免费不卡av| 日本在线不卡免费视频| 色哟哟在线网站入口| 天天操天天污天天射| 非洲黑人一级特黄片| 精品91高清在线观看| 国产黄色片在线收看| 色天天天天射天天舔| 色综合久久无码中文字幕波多| 在线视频免费观看网| 国产精品国色综合久久| 熟女在线视频一区二区三区| 精品亚洲在线免费观看| 狠狠躁夜夜躁人人爽天天天天97| 91国产资源在线视频| 人妻素人精油按摩中出| 久久99久久99精品影院| 五月婷婷在线观看视频免费| 亚洲精品乱码久久久本| 自拍偷拍亚洲欧美在线视频| 最后99天全集在线观看| 偷青青国产精品青青在线观看| 成人av在线资源网站| 天天摸天天日天天操| 18禁免费av网站| 伊人综合aⅴ在线网| 国内精品在线播放第一页| 老司机在线精品福利视频| 黄色录像鸡巴插进去| 操的小逼流水的文章| 午夜成午夜成年片在线观看 | 日韩a级黄色小视频| 天堂av中文在线最新版| 国产内射中出在线观看| 青青青艹视频在线观看| 日韩视频一区二区免费观看| 黄色片黄色片wyaa| 美女吃鸡巴操逼高潮视频| 国产精品国产三级国产午| 鸡巴操逼一级黄色气| 亚洲另类在线免费观看| 免费69视频在线看| 中文字幕在线免费第一页| 日韩视频一区二区免费观看| 在线观看免费av网址大全| 91综合久久亚洲综合| 特级无码毛片免费视频播放| 亚洲日本一区二区三区| 久久久久久久一区二区三| 青青青青青青青青青青草青青| gay gay男男瑟瑟在线网站| 亚洲欧美一区二区三区爱爱动图| 亚洲天堂有码中文字幕视频| 亚洲区欧美区另类最新章节| 男人的网址你懂的亚洲欧洲av| 中字幕人妻熟女人妻a62v网| 老熟妇xxxhd老熟女| 一区二区三区日本伦理| 欧美天堂av无线av欧美| 女人精品内射国产99| 青青草在观免费国产精品| 91九色porny蝌蚪国产成人| 欧亚日韩一区二区三区观看视频| 最新日韩av传媒在线| 国产欧美精品免费观看视频| 久久久久只精品国产三级| 天天日天天日天天射天天干| 伊人精品福利综合导航| 国产精品精品精品999| 家庭女教师中文字幕在线播放| 香蕉片在线观看av| 2o22av在线视频| 91亚洲手机在线视频播放| 91精品免费久久久久久| 国产免费av一区二区凹凸四季| 国产综合视频在线看片| 精品国产乱码一区二区三区乱| 2020久久躁狠狠躁夜夜躁| 国产伦精品一区二区三区竹菊| 绯色av蜜臀vs少妇| 亚洲成a人片777777| 日韩中文字幕精品淫| 瑟瑟视频在线观看免费视频| 抽查舔水白紧大视频| 人妻爱爱 中文字幕| 福利视频网久久91| 国产在线一区二区三区麻酥酥| 骚逼被大屌狂草视频免费看| 美女福利写真在线观看视频| 美女在线观看日本亚洲一区| 欧美偷拍亚洲一区二区| 中文字幕在线视频一区二区三区| 亚洲黄色av网站免费播放| 亚洲va国产va欧美精品88| 99精品视频在线观看免费播放| 精品黑人一区二区三区久久国产| av俺也去在线播放| 亚洲伊人av天堂有码在线| 久久久久久cao我的性感人妻| 天天操天天插天天色| 国产一区二区视频观看| 老司机在线精品福利视频| 激情五月婷婷综合色啪| 看一级特黄a大片日本片黑人| 人妻少妇精品久久久久久 | 婷婷六月天中文字幕| 91啪国自产中文字幕在线| 99久久99一区二区三区| 亚洲青青操骚货在线视频| 国产日韩欧美视频在线导航 | 亚洲 清纯 国产com| 传媒在线播放国产精品一区| 亚洲激情,偷拍视频| 亚洲高清国产拍青青草原| 精品一区二区三区欧美| 在线不卡成人黄色精品| 国产九色91在线视频| 色97视频在线播放| 日韩精品中文字幕在线| 欧美亚洲一二三区蜜臀| 欧美美女人体视频一区| 日韩加勒比东京热二区| 亚洲推理片免费看网站| 中文字幕高清在线免费播放| 国产不卡av在线免费| 青草青永久在线视频18| 沙月文乃人妻侵犯中文字幕在线| 国产一区二区欧美三区| 亚洲一区二区三区精品乱码| 日韩人妻在线视频免费| 青青青青视频在线播放| 亚洲 人妻 激情 中文| 中出中文字幕在线观看| 色偷偷伊人大杳蕉综合网 | 国产又粗又硬又猛的毛片视频| 9色精品视频在线观看| 92福利视频午夜1000看| 欧美色婷婷综合在线| 亚洲av第国产精品| 亚洲麻豆一区二区三区| 久久久麻豆精亚洲av麻花| 国产91久久精品一区二区字幕| 91av中文视频在线| 漂亮 人妻被中出中文| 国产白嫩美女一区二区| 亚洲成人免费看电影| 亚洲国产在线精品国偷产拍 | 在线观看成人国产电影| 成年人啪啪视频在线观看| 好吊视频—区二区三区| 国产亚洲四十路五十路| 成年午夜影片国产片| 红杏久久av人妻一区| 国产日韩欧美美利坚蜜臀懂色| 视频一区二区在线免费播放| 婷婷五月亚洲综合在线| 熟妇一区二区三区高清版| 97欧洲一区二区精品免费| 特大黑人巨大xxxx| 韩国一级特黄大片做受| 一色桃子久久精品亚洲 | 97少妇精品在线观看| 亚洲成人黄色一区二区三区 | 青青草精品在线视频观看| 成人高清在线观看视频| 中文字幕在线观看极品视频| 欧美viboss性丰满| 婷婷综合亚洲爱久久| 亚洲欧美人精品高清| 亚洲免费视频欧洲免费视频| 午夜福利人人妻人人澡人人爽| 日辽宁老肥女在线观看视频| 亚洲人成精品久久久久久久| 在线免费观看欧美小视频| av新中文天堂在线网址| 免费在线福利小视频| 中文字幕亚洲久久久| 天天色天天爱天天爽| 精品美女福利在线观看| 欧美熟妇一区二区三区仙踪林| 精品国产乱码一区二区三区乱| 欧美麻豆av在线播放| 国产一区二区神马久久| 青青色国产视频在线| 天天操天天射天天操天天天| 亚洲午夜在线视频福利| 亚洲一区二区人妻av| 久久久制服丝袜中文字幕| 亚洲av可乐操首页| 欧美男同性恋69视频| 亚洲一级av无码一级久久精品 | 都市家庭人妻激情自拍视频| 亚国产成人精品久久久| 激情五月婷婷免费视频| 日韩视频一区二区免费观看| 97人妻人人澡爽人人精品| 啪啪啪18禁一区二区三区 | 98视频精品在线观看| 亚洲欧美自拍另类图片| 成人av久久精品一区二区| 久精品人妻一区二区三区| 日日日日日日日日夜夜夜夜夜夜| 动色av一区二区三区| 韩国AV无码不卡在线播放 | 青青青青青青青青青青草青青 | 狠狠躁狠狠爱网站视频 | 精品一区二区亚洲欧美| 亚洲综合另类精品小说| 不卡日韩av在线观看| 人妻久久久精品69系列| 777奇米久久精品一区| 国产品国产三级国产普通话三级| 偷拍自拍视频图片免费| 天天插天天狠天天操| 亚洲综合在线观看免费| 9色在线视频免费观看| 欧美国品一二三产区区别| avjpm亚洲伊人久久| 亚洲国产香蕉视频在线播放| 日美女屁股黄邑视频| 国产美女一区在线观看| 93精品视频在线观看| 视频一区二区在线免费播放 | 天天干天天插天天谢| 国产精品一区二区三区蜜臀av| 午夜美女少妇福利视频| 白白操白白色在线免费视频| 国产精品免费不卡av| 999九九久久久精品| 懂色av蜜桃a v| 天天日天天玩天天摸| 欧美日本在线视频一区| 2025年人妻中文字幕乱码在线| 精品人妻每日一部精品| 亚洲熟女综合色一区二区三区四区| 久久久久久9999久久久久| 秋霞午夜av福利经典影视| 超碰97人人做人人爱| 亚洲一区二区三区在线高清| 欧美日韩亚洲国产无线码| 久久久噜噜噜久久熟女av| 在线免费观看黄页视频| 亚洲 国产 成人 在线| 中文字幕一区二 区二三区四区| 自拍偷拍亚洲另类色图| av大全在线播放免费| 天天日天天摸天天爱| 91麻豆精品久久久久| 自拍偷拍一区二区三区图片| 日日摸夜夜添夜夜添毛片性色av| 欧美伊人久久大香线蕉综合| 天天日天天操天天摸天天舔| 国产成人无码精品久久久电影| 99精品免费久久久久久久久a| 韩国AV无码不卡在线播放| 热思思国产99re| 国产一级精品综合av| 97人人模人人爽人人喊| 岛国一区二区三区视频在线| 国产麻豆91在线视频| 国产精彩对白一区二区三区| 热思思国产99re| 久久久久久久久久一区二区三区| 97精品人妻一区二区三区精品| 国产视频精品资源网站| 伊人精品福利综合导航| 自拍偷区二区三区麻豆| 天天操天天干天天艹| 男女之间激情网午夜在线| avjpm亚洲伊人久久| 日韩熟女系列一区二区三区| 亚洲国产欧美国产综合在线| 免费69视频在线看| 亚洲av无女神免非久久| av俺也去在线播放| 免费无毒热热热热热热久| 国产真实灌醉下药美女av福利| 国产高清女主播在线| 97瑟瑟超碰在线香蕉| 国产av一区2区3区| 亚洲高清国产自产av| 丰满熟女午夜福利视频| 在线观看成人国产电影| 午夜在线精品偷拍一区二| av天堂加勒比在线| 2020久久躁狠狠躁夜夜躁| 极品粉嫩小泬白浆20p主播| 欧美黑人性暴力猛交喷水| 亚洲福利精品视频在线免费观看| 97人人模人人爽人人喊| 在线视频这里只有精品自拍| 少妇人妻100系列| 午夜影院在线观看视频羞羞羞| 激情图片日韩欧美人妻| 丁香花免费在线观看中文字幕| 免费福利av在线一区二区三区| 亚洲午夜福利中文乱码字幕| 91亚洲精品干熟女蜜桃频道| 经典亚洲伊人第一页| 80电影天堂网官网| 最新欧美一二三视频| 中文 成人 在线 视频| 国产九色91在线观看精品| 精品首页在线观看视频| 视频 一区二区在线观看| 欧美viboss性丰满| 一区二区熟女人妻视频| 特级无码毛片免费视频播放 | 青青热久免费精品视频在线观看| 最新日韩av传媒在线| 人妻无码中文字幕专区| 亚洲精品久久视频婷婷| 欧美 亚洲 另类综合| 又黄又刺激的午夜小视频| 福利片区一区二体验区| 国产亚洲四十路五十路| 亚洲免费av在线视频| 日本欧美视频在线观看三区| 99热国产精品666| 欧美日韩人妻久久精品高清国产| 色呦呦视频在线观看视频| 国产精品成人xxxx| 国产高潮无码喷水AV片在线观看| 欧美va亚洲va天堂va| 专门看国产熟妇的网站| 欧美精品一二三视频| 国产一区二区三免费视频| 在线观看的黄色免费网站| 一区二区三区另类在线| 91麻豆精品传媒国产黄色片| 国产乱弄免费视频观看| 亚洲成人av一区久久| 欧美一级视频一区二区| 中文字幕国产专区欧美激情| 黄色大片男人操女人逼| 一区国内二区日韩三区欧美| 国产精品系列在线观看一区二区 | 成人乱码一区二区三区av| 欧美老鸡巴日小嫩逼| 亚洲av黄色在线网站| 毛片av在线免费看| 精品91高清在线观看| 91she九色精品国产| 天天干天天爱天天色| 国产九色91在线观看精品| 天天艹天天干天天操| mm131美女午夜爽爽爽| 青青青青青青草国产| 综合激情网激情五月天| av手机在线观播放网站| av中文在线天堂精品| 亚洲综合乱码一区二区| 57pao国产一区二区| 新97超碰在线观看| 天天操天天射天天操天天天| 国产97在线视频观看| 久久农村老妇乱69系列| 亚洲男人让女人爽的视频| 亚洲国产成人av在线一区| 欧美精品黑人性xxxx| 我想看操逼黄色大片| 好男人视频在线免费观看网站| 精品一区二区三区欧美| 黑人巨大精品欧美视频| 国产一线二线三线的区别在哪| 色综合久久久久久久久中文| 天天日天天玩天天摸| 色婷婷久久久久swag精品| 老师啊太大了啊啊啊尻视频| 日韩av有码一区二区三区4| 91小伙伴中女熟女高潮| 视频 国产 精品 熟女 | 欧美精品免费aaaaaa| 热久久只有这里有精品| 青青在线视频性感少妇和隔壁黑丝 | 国产揄拍高清国内精品对白| 日本精品一区二区三区在线视频。| 国产欧美日韩在线观看不卡| 亚洲国产香蕉视频在线播放| 天天干夜夜操啊啊啊| 亚洲嫩模一区二区三区| 91成人精品亚洲国产| 91人妻精品一区二区久久| 亚洲无码一区在线影院| 欧美在线一二三视频| 91在线免费观看成人| av在线资源中文字幕| 国产精品欧美日韩区二区| 亚洲自拍偷拍精品网| 亚洲精品中文字幕下载| 青青青青草手机在线视频免费看| 天美传媒mv视频在线观看| 国产精品福利小视频a| 自拍偷拍日韩欧美亚洲| 婷婷激情四射在线观看视频| 天堂av狠狠操蜜桃| 亚洲丝袜老师诱惑在线观看| 亚洲欧美激情人妻偷拍| 中文字幕最新久久久| 亚洲中文字幕校园春色| 蝴蝶伊人久久中文娱乐网| 亚洲国产精品美女在线观看| 538精品在线观看视频| 亚洲欧美日韩视频免费观看| 亚洲男人让女人爽的视频| 国产视频网站一区二区三区 | 天天日天天操天天摸天天舔| 自拍偷拍日韩欧美一区二区| www,久久久,com| 人人爽亚洲av人人爽av| 国产大学生援交正在播放| 亚洲精品在线资源站| 青青青视频自偷自拍38碰| 国产露脸对白在线观看| 午夜成午夜成年片在线观看| 99热久久这里只有精品| 亚洲va国产va欧美精品88| 国产刺激激情美女网站| 一区二区久久成人网| av中文字幕在线观看第三页| 55夜色66夜色国产精品站| 福利午夜视频在线观看| 亚洲av黄色在线网站| 国产精品女邻居小骚货| 黄页网视频在线免费观看| 天天射,天天操,天天说| 99精品国产自在现线观看| 亚洲福利午夜久久久精品电影网 | 91久久精品色伊人6882| 亚洲丝袜老师诱惑在线观看| 亚洲av黄色在线网站| 欧美激情精品在线观看| 精品suv一区二区69| 色哟哟国产精品入口| 午夜精品一区二区三区4| 91精品国产91青青碰| 97精品综合久久在线| 免费av岛国天堂网站| 亚洲 中文 自拍 另类 欧美| 黑人3p华裔熟女普通话| 国产va在线观看精品| 天天插天天狠天天操| 视频久久久久久久人妻| 欧美视频综合第一页| 欧美精产国品一二三产品价格| 欧美熟妇一区二区三区仙踪林| 亚洲另类综合一区小说| 黑人变态深video特大巨大| 中国熟女一区二区性xx| 人妻最新视频在线免费观看| 久久丁香婷婷六月天| 开心 色 六月 婷婷| 中文字幕在线欧美精品| 91国产资源在线视频| 成人国产小视频在线观看| 97欧洲一区二区精品免费| 啊啊啊想要被插进去视频| 欧美va亚洲va天堂va| 三级av中文字幕在线观看| 亚洲综合另类欧美久久| 人妻熟女在线一区二区| 国产激情av网站在线观看| 亚洲国产最大av综合| 亚洲第17页国产精品| 青青青视频手机在线观看| 特一级特级黄色网片| 国产av国片精品一区二区| 免费在线黄色观看网站| 欧美黄色录像免费看的| 中文字幕在线乱码一区二区| 亚洲国产香蕉视频在线播放| 成人性黑人一级av| 4个黑人操素人视频网站精品91| 在线免费观看靠比视频的网站| 成年午夜影片国产片| www,久久久,com| 40道精品招牌菜特色| 夜色撩人久久7777| 国产性感美女福利视频| 精品91高清在线观看| 美女张开两腿让男人桶av| 91中文字幕免费在线观看| 人人人妻人人澡人人| 免费在线福利小视频| 精品国产污污免费网站入口自| 一区二区在线视频中文字幕| av中文字幕福利网| 熟女人妻在线观看视频| 国产精品视频资源在线播放| 亚洲国产最大av综合| 免费观看污视频网站| 中文字幕av男人天堂| 91精品国产综合久久久蜜| 午夜免费体验区在线观看| 欧美性感尤物人妻在线免费看| 欧美另类一区二区视频| 日韩无码国产精品强奸乱伦| 国产精品黄页网站视频| 亚洲av自拍天堂网| 传媒在线播放国产精品一区| 亚洲日本一区二区久久久精品| 精品91高清在线观看| 懂色av蜜桃a v| 少妇与子乱在线观看| 天天插天天狠天天操| 少妇人妻久久久久视频黄片| 精品乱子伦一区二区三区免费播| 中英文字幕av一区| 亚洲欧美国产综合777| 亚洲1区2区3区精华液| 国产美女一区在线观看| 婷婷午夜国产精品久久久| 亚洲一区av中文字幕在线观看| 北条麻妃高跟丝袜啪啪| 偷青青国产精品青青在线观看 | 最新国产精品网址在线观看| 国产aⅴ一线在线观看| 日韩影片一区二区三区不卡免费| 国产精品sm调教视频| 99re久久这里都是精品视频| 青青青青视频在线播放| 午夜毛片不卡免费观看视频 | 中文字幕国产专区欧美激情 | av老司机亚洲一区二区| nagger可以指黑人吗| 成年人的在线免费视频| 快点插进来操我逼啊视频| 欧美精品激情在线最新观看视频| 五十路息与子猛烈交尾视频| av在线播放国产不卡| 午夜精品福利一区二区三区p| 国产精品人久久久久久| 天天干夜夜操啊啊啊| 日本一区美女福利视频| 福利视频一区二区三区筱慧| 99热这里只有国产精品6| 中文字幕亚洲久久久| 日韩欧美一级aa大片| 狠狠躁狠狠爱网站视频| 97人妻夜夜爽二区欧美极品| 国产成人精品久久二区91| 国产精品久久久久久美女校花| 人妻3p真实偷拍一二区| 又大又湿又爽又紧A视频| 年轻的人妻被夫上司侵犯| 午夜成午夜成年片在线观看| 2021久久免费视频| 中文字幕乱码人妻电影| 欧美特级特黄a大片免费| 亚洲一区二区三区久久午夜| 超碰公开大香蕉97| 日日夜夜狠狠干视频| 一区二区在线视频中文字幕| 不卡一区一区三区在线| 亚洲免费视频欧洲免费视频| 日本少妇人妻xxxxx18| 少妇人妻真实精品视频| 日韩a级黄色小视频| 国产日韩欧美美利坚蜜臀懂色| 一本一本久久a久久精品综合不卡| 在线观看视频 你懂的| 国产不卡av在线免费| 在线观看免费视频网| 成年美女黄网站18禁久久| 97小视频人妻一区二区| 欧美地区一二三专区| 日比视频老公慢点好舒服啊| 美女吃鸡巴操逼高潮视频| 人妻少妇亚洲精品中文字幕| 中文字幕在线观看极品视频| 首之国产AV医生和护士小芳| 日韩欧美制服诱惑一区在线| 一色桃子久久精品亚洲| 亚洲精品麻豆免费在线观看| 都市家庭人妻激情自拍视频| 欧美一区二区三区啪啪同性| 78色精品一区二区三区| 久草视频在线一区二区三区资源站| 午夜福利人人妻人人澡人人爽| 超污视频在线观看污污污| 久久久久国产成人精品亚洲午夜| 成人在线欧美日韩国产| 黄色无码鸡吧操逼视频| 久久综合老鸭窝色综合久久| 女警官打开双腿沦为性奴| 国产精品久久综合久久| 亚洲精品无码久久久久不卡| 国产麻豆91在线视频| tube69日本少妇| 97人妻色免费视频| 成年人的在线免费视频| 免费观看污视频网站| 乱亲女秽乱长久久久| 密臀av一区在线观看| 亚洲一区av中文字幕在线观看| 激情小视频国产在线| 国产又粗又硬又猛的毛片视频 | 91超碰青青中文字幕| 亚洲综合另类精品小说| 神马午夜在线观看视频| 免费男阳茎伸入女阳道视频| 国产乱子伦一二三区| av在线shipin| 性色av一区二区三区久久久| 自拍偷拍亚洲另类色图| 日本av高清免费网站| 日韩亚洲高清在线观看| 影音先锋女人av噜噜色| 一级黄片大鸡巴插入美女 | 激情国产小视频在线| 日日爽天天干夜夜操| 日韩精品中文字幕福利| 欧美在线精品一区二区三区视频| 精品成人午夜免费看| 爱有来生高清在线中文字幕| 国产janese在线播放| 亚洲av色图18p| 少妇人妻100系列| 日本在线一区二区不卡视频| 亚洲综合一区成人在线| 中文字幕+中文字幕| 狠狠的往里顶撞h百合| 边摸边做超爽毛片18禁色戒| 亚洲精品国产久久久久久| 欧美精产国品一二三产品价格| 区一区二区三国产中文字幕| 五月激情婷婷久久综合网| 美女少妇亚洲精选av| 蜜桃精品久久久一区二区| 91在线免费观看成人| 青春草视频在线免费播放| 精品久久婷婷免费视频| 少妇人妻真实精品视频| 五月激情婷婷久久综合网| 男人的天堂一区二区在线观看| okirakuhuhu在线观看| 姐姐的朋友2在线观看中文字幕| 免费av岛国天堂网站| 久草视频在线一区二区三区资源站 | 亚洲国产免费av一区二区三区| 99精品视频在线观看免费播放| 国产麻豆91在线视频| 亚洲综合另类欧美久久| 日韩中文字幕福利av| 午夜免费体验区在线观看| 国产精品人妻熟女毛片av久| 欧美日韩v中文在线| 人人爽亚洲av人人爽av| 亚洲国产香蕉视频在线播放| 我想看操逼黄色大片| 日本韩国在线观看一区二区| 国产成人精品午夜福利训2021 | 超碰97免费人妻麻豆| 天天色天天操天天透|