Flutter卡片滑动匹配插件flutter_tindercard_plus的使用
Flutter卡片滑动匹配插件 flutter_tindercard_plus
的使用
flutter_tindercard_plus
是一个用于实现类似 Tinder 卡片滑动效果的 Flutter 插件。本文将详细介绍如何使用该插件,并提供完整的示例代码。
屏幕截图
开始使用
1. 添加依赖
在你的 pubspec.yaml
文件中添加以下依赖:
dependencies:
flutter_tindercard_plus: ^x.x.x
请确保替换 ^x.x.x
为最新版本号。
2. 导入包
在 Dart 文件中导入该插件:
import 'package:flutter_tindercard_plus/flutter_tindercard_plus.dart';
3. 使用 TinderSwapCard
组件
在你的小部件布局中添加 TinderSwapCard
,并编写单个卡片布局构建器,即可获得类似 Tinder 的卡片滑动效果。
4. 使用 CardSwipeCompleteCallback
使用 CardSwipeCompleteCallback
获取卡片滑动的方向和索引。
5. 使用 CardController
初始化一个 CardController
作为参数传递给组件,并调用 triggerLeft()
或 triggerRight()
方法触发滑动。
6. 使用 CardDragUpdateCallback
使用 CardDragUpdateCallback
获取正在滑动的卡片的详细信息。
示例代码
以下是一个完整的示例应用,展示了如何使用 flutter_tindercard_plus
实现卡片滑动效果。
import 'package:flutter/material.dart';
import 'package:flutter_tindercard_plus/flutter_tindercard_plus.dart';
void main() => runApp(const MyApp());
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const ExampleHomePage(),
);
}
}
class ExampleHomePage extends StatefulWidget {
const ExampleHomePage({Key? key}) : super(key: key);
@override
State<ExampleHomePage> createState() => _ExampleHomePageState();
}
class _ExampleHomePageState extends State<ExampleHomePage>
with TickerProviderStateMixin {
List<String> welcomeImages = [
"assets/welcome0.png",
"assets/welcome1.png",
"assets/welcome2.png",
"assets/welcome2.png",
"assets/welcome1.png",
"assets/welcome1.png"
];
late CardController controller; // Use this to trigger swap.
@override
void initState() {
super.initState();
controller = CardController();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('Tinder Card Example'),
),
body: Center(
child: SizedBox(
height: MediaQuery.of(context).size.height * 0.6,
child: TinderSwapCard(
swipeUp: true,
swipeDown: true,
orientation: AmassOrientation.bottom,
totalNum: welcomeImages.length,
stackNum: 3,
swipeEdge: 4.0,
maxWidth: MediaQuery.of(context).size.width * 0.9,
maxHeight: MediaQuery.of(context).size.width * 0.9,
minWidth: MediaQuery.of(context).size.width * 0.8,
minHeight: MediaQuery.of(context).size.width * 0.8,
cardBuilder: (context, index) => Card(
child: Image.asset(welcomeImages[index]),
),
cardController: controller,
swipeUpdateCallback: (DragUpdateDetails details, Alignment align) {
/// Get swiping card's alignment
if (align.x < 0) {
// Card is LEFT swiping
} else if (align.x > 0) {
// Card is RIGHT swiping
}
},
swipeCompleteCallback:
(CardSwipeOrientation orientation, int index) {
/// Get orientation & index of swiped card!
print("Card Swiped $orientation, Index $index");
},
),
),
),
floatingActionButton: FloatingActionButton(
onPressed: () {
// Trigger a left swipe programmatically
controller.triggerLeft();
},
child: const Icon(Icons.arrow_back),
),
);
}
}
运行示例
- 确保你已经将图片资源(如
welcome0.png
,welcome1.png
,welcome2.png
)添加到项目的assets
目录中。 - 在
pubspec.yaml
中声明这些资源:assets: - assets/welcome0.png - assets/welcome1.png - assets/welcome2.png
- 运行应用程序,查看卡片滑动效果。
通过以上步骤,你可以轻松地在自己的 Flutter 应用中集成 flutter_tindercard_plus
插件,实现卡片滑动匹配功能。
更多关于Flutter卡片滑动匹配插件flutter_tindercard_plus的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter卡片滑动匹配插件flutter_tindercard_plus的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
当然,以下是一个关于如何使用 flutter_tindercard_plus
插件的简单示例代码。这个插件允许你在 Flutter 应用中实现类似 Tinder 的卡片滑动效果。
首先,确保你的 Flutter 项目已经添加了对 flutter_tindercard_plus
插件的依赖。在 pubspec.yaml
文件中添加以下依赖:
dependencies:
flutter:
sdk: flutter
flutter_tindercard_plus: ^x.y.z # 请将 x.y.z 替换为最新版本号
然后运行 flutter pub get
来获取依赖。
接下来,在你的 Dart 文件中实现卡片滑动功能。下面是一个完整的示例:
import 'package:flutter/material.dart';
import 'package:flutter_tindercard_plus/flutter_tindercard_plus.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Tinder Card Example',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: TinderCardExample(),
);
}
}
class TinderCardExample extends StatefulWidget {
@override
_TinderCardExampleState createState() => _TinderCardExampleState();
}
class _TinderCardExampleState extends State<TinderCardExample> {
final List<String> images = [
'https://via.placeholder.com/350x500?text=Card+1',
'https://via.placeholder.com/350x500?text=Card+2',
'https://via.placeholder.com/350x500?text=Card+3',
'https://via.placeholder.com/350x500?text=Card+4',
'https://via.placeholder.com/350x500?text=Card+5',
];
final TinderCardController _tinderCardController = TinderCardController();
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Flutter Tinder Card Example'),
),
body: Center(
child: TinderSwapCard(
totalNum: images.length,
cardBuilder: (context, index) {
return Card(
elevation: 8.0,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(16.0),
),
child: Image.network(images[index]),
);
},
onCardSwipedLeft: (index) {
print("Card $index swiped left!");
},
onCardSwipedRight: (index) {
print("Card $index swiped right!");
},
cardController: _tinderCardController,
),
),
floatingActionButton: FloatingActionButton(
onPressed: () {
_tinderCardController.reset();
},
tooltip: 'Reset',
child: Icon(Icons.replay),
),
);
}
}
在这个示例中,我们做了以下几件事:
- 引入依赖:我们导入了
flutter_tindercard_plus
插件。 - 定义图片列表:我们定义了一个包含图片 URL 的列表。
- 创建控制器:我们创建了一个
TinderCardController
控制器实例,用于控制卡片的滑动行为。 - 构建卡片视图:使用
TinderSwapCard
小部件来显示卡片。我们定义了一个cardBuilder
函数来构建每张卡片的内容,这里是简单的图片。 - 处理卡片滑动事件:我们定义了
onCardSwipedLeft
和onCardSwipedRight
函数来处理卡片向左或向右滑动的事件。 - 重置卡片:我们添加了一个浮动操作按钮(FAB),当点击时,调用
_tinderCardController.reset()
方法来重置卡片的位置。
这个示例展示了如何使用 flutter_tindercard_plus
插件来实现卡片滑动效果,并处理滑动事件。你可以根据需要进一步自定义卡片的内容和样式。