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

1 回复

更多关于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,
  });
}

注意

  1. ShareContentShareResult 类是为了演示目的而创建的简单数据结构,实际插件可能提供不同的数据结构和回调方式。你需要参考share_facebook_callback插件的文档来调整这些部分。
  2. imageUrl 必须是一个有效的、可以公开访问的URL。
  3. shareDialogMode 可以是 ShareDialogMode.feedShareDialogMode.shareSheet,具体取决于你希望使用的分享对话框类型。

确保在实际项目中根据插件的最新文档和API进行调整。

回到顶部