Flutter Facebook分享回调插件share_facebook_callback的使用
Flutter Facebook分享回调插件share_facebook_callback的使用
Flutter插件用于将内容分享到Facebook。
您可以使用它来分享到Facebook。支持URL和文本、照片。
支持:
- Android & iOS : Facebook
- 注意:此插件仍在开发中,某些API可能尚未可用。
- 欢迎反馈和Pull请求!
开始使用
在您的pubspec.yaml
文件中添加share_facebook_callback
作为依赖项。
请在安装前检查最新版本。
dependencies:
flutter:
sdk: flutter
# 添加 share_facebook_callback
share_facebook_callback: ^0.0.1
设置
Android
在AndroidManifest.xml
的应用程序标签中添加"Facebook应用ID"。
<application>
...
<!-- 添加以下内容 -->
<meta-data
android:name="com.facebook.sdk.ApplicationId"
android:value="@string/facebook_app_id" />
<meta-data
android:name="com.facebook.sdk.ClientToken"
android:value="@string/facebook_client_token"/>
<provider
android:name="com.facebook.FacebookContentProvider"
android:authorities="com.facebook.app.FacebookContentProvider[facebook_app_id]"
android:exported="true" />
</application>
<queries>
<provider android:authorities="com.facebook.katana.provider.PlatformProvider" />
</queries>
strings.xml
:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<!-- 替换 "12345678901234" 为你的Facebook应用ID -->
<string name="facebook_app_id">12345678901234</string>
<!-- 替换 "123456789abcdefghimnl" 为你的Facebook客户端令牌 -->
<string name="facebook_client_token">123456789abcdefghimnl</string>
</resources>
iOS
设置Facebook
确保在您的Info.plist
文件中添加以下细节。
<key>FacebookAppID</key>
<string>fbid</string>
<key>FacebookClientToken</key>
<string>123456789abcdefghimnl</string>
<key>CFBundleURLTypes</key>
<array>
<dict>
<key>CFBundleURLSchemes</key>
<array>
<string>fb-your-fb-id</string>
</array>
</dict>
</array>
注意:确保在您的fb ID前添加fb:
。
在URL Scheme中添加以下值(参考示例)。
<key>LSApplicationQueriesSchemes</key>
<array>
<string>fbapi</string>
<string>fb-messenger-share-api</string>
</array>
完整示例
以下是完整的示例代码,演示如何使用share_facebook_callback
插件进行Facebook分享并获取回调状态。
import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter/services.dart';
import 'package:share_facebook_callback/share_facebook_callback.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatefulWidget {
const MyApp({Key? key}) : super(key: key);
[@override](/user/override)
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
final _shareFacebookCallbackPlugin = ShareFacebookCallback();
String _platformVersion = 'Unknown';
String _shareFaceStatus = 'Unknow status';
[@override](/user/override)
void initState() {
super.initState();
initPlatformState();
}
// 平台消息是异步的,因此我们在异步方法中初始化。
Future<void> initPlatformState() async {
String platformVersion;
// 平台消息可能会失败,所以我们使用try/catch处理PlatformException。
// 我们还处理消息可能返回null的情况。
try {
platformVersion =
await _shareFacebookCallbackPlugin.getPlatformVersion() ??
'Unknown platform version';
} on PlatformException {
platformVersion = 'Failed to get platform version.';
}
// 如果在异步平台消息飞行时小部件从树中被移除,则我们希望丢弃回复而不是调用
// setState以更新我们的非现有外观。
if (!mounted) return;
setState(() {
_platformVersion = platformVersion;
});
}
Future<void> shareFacebook(String url, String msg) async {
String shareFaceStatus;
try {
shareFaceStatus = await _shareFacebookCallbackPlugin.shareFacebook(
type: ShareType.shareLinksFacebook,
url: 'https://vtcpay.vn/',
quote: 'Happy new year',
) ??
'Unknow sharing Facebook Status';
} catch (e) {
shareFaceStatus = 'Failed to call shareFacebook';
}
if (!mounted) return;
setState(() {
_shareFaceStatus = shareFaceStatus;
});
}
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: const Text('ShareFacebook CallBack'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
ElevatedButton(
onPressed: () {
shareFacebook('https://pub.dev/', 'Flutter');
},
style: ElevatedButton.styleFrom(shape: const StadiumBorder()),
child: const Text('Share Facebook'),
),
const SizedBox(
height: 30,
),
Text('ShareFacebook Status: $_shareFaceStatus\n'),
Text('Platform Version: $_platformVersion\n'),
],
),
),
),
);
}
}
更多关于Flutter Facebook分享回调插件share_facebook_callback的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter Facebook分享回调插件share_facebook_callback的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
当然,以下是一个关于如何在Flutter项目中使用share_facebook_callback
插件进行Facebook分享的示例代码。请注意,实际使用时你需要确保已经正确配置了Facebook SDK并获得了相应的权限。
首先,确保你的pubspec.yaml
文件中已经添加了share_facebook_callback
依赖:
dependencies:
flutter:
sdk: flutter
share_facebook_callback: ^最新版本号 # 请替换为最新的版本号
然后,运行flutter pub get
来获取依赖。
接下来,配置Facebook SDK。这通常涉及在android/app/src/main
目录下的AndroidManifest.xml
中添加Facebook的App ID,以及在iOS项目中配置Facebook的相关信息。由于这些步骤可能因项目而异,这里不详细展开,但请确保按照Facebook的官方文档完成配置。
以下是一个完整的Flutter应用示例,展示如何使用share_facebook_callback
插件进行分享并处理回调:
import 'package:flutter/material.dart';
import 'package:share_facebook_callback/share_facebook_callback.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: ShareFacebookPage(),
);
}
}
class ShareFacebookPage extends StatefulWidget {
@override
_ShareFacebookPageState createState() => _ShareFacebookPageState();
}
class _ShareFacebookPageState extends State<ShareFacebookPage> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Facebook Share Callback Example'),
),
body: Center(
child: ElevatedButton(
onPressed: _shareToFacebook,
child: Text('Share to Facebook'),
),
),
);
}
Future<void> _shareToFacebook() async {
try {
final ShareFacebookCallback shareFacebookCallback = ShareFacebookCallback();
// Share content
final ShareResult result = await shareFacebookCallback.share(
content: ShareContent(
title: 'Hello Facebook',
description: 'This is a test post from Flutter app',
imageUrl: 'https://example.com/image.jpg', // Replace with a valid URL
),
shareDialogMode: ShareDialogMode.feed, // or ShareDialogMode.shareSheet
);
// Handle the result
if (result.isPosted) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text('Shared successfully!')),
);
} else if (result.isCancelled) {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text('Share cancelled')),
);
} else {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text('Share failed')),
);
}
} catch (e) {
// Handle exceptions, e.g., Facebook SDK not initialized
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text('Error: ${e.message}')),
);
}
}
}
class ShareContent {
final String title;
final String description;
final String imageUrl;
ShareContent({
required this.title,
required this.description,
required this.imageUrl,
});
}
class ShareResult {
final bool isPosted;
final bool isCancelled;
ShareResult({
required this.isPosted,
required this.isCancelled,
});
}
注意:
ShareContent
和ShareResult
类是为了演示目的而创建的简单数据结构,实际插件可能提供不同的数据结构和回调方式。你需要参考share_facebook_callback
插件的文档来调整这些部分。imageUrl
必须是一个有效的、可以公开访问的URL。shareDialogMode
可以是ShareDialogMode.feed
或ShareDialogMode.shareSheet
,具体取决于你希望使用的分享对话框类型。
确保在实际项目中根据插件的最新文档和API进行调整。