【问题标题】:Share url+image+text with Twitter/Facebook/Instagram与 Twitter/Facebook/Instagram 分享 url+image+text
【发布时间】:2021-11-08 18:03:48
【问题描述】:

是否有任何库/包可以帮助 iOS 和 Android 平台在 FB、Twitter 和 Insta 上共享图像+文本+url?我已经灼热了4个小时,但没有找到任何结果。 https://pub.dev/packages/flutter_share_me 这个包只适用于安卓。如果您有任何解决方案,请指导我。

~ PS:我不想用 Share 包,我有 FB、Insta 和 Twitter 的按钮。当用户点击任何一个按钮时,数据应该在任何社交媒体上共享,我需要回调失败或成功。

【问题讨论】:

  • 分享一个带有 og-tags 的 URL,用于描述和图像。
  • “我需要回电失败或成功” - 为什么?请注意,至少对于 Facebook(可能还有 Instagram),明确禁止以任何方式奖励用户分享。
  • 在我的情况下,我的应用是基于分享和赚钱的,那么我如何才能在 fb 上分享是否完成?如果用户愿意分享,那么他/她将获得金钱
  • 不允许使用该用例,正如 04FS 已经提到的那样。人们需要分享东西是因为他们喜欢它,而不是因为他们从中得到了什么。

标签: facebook flutter twitter dart instagram


【解决方案1】:

编辑
包 social_share_plugin https://github.com/romatroskin/social_share_plugin
提供分享功能并有回调
描述页面忘记提及 twitter 已经包含

完整的 social_share_plugin 示例代码

import 'package:flutter/material.dart';
import 'dart:async';
import 'dart:io';

import 'package:flutter/services.dart';
import 'package:social_share_plugin/social_share_plugin.dart';
import 'package:image_picker/image_picker.dart';

void main() => runApp(MyApp());

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  String _platformVersion = 'Unknown';

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

  // Platform messages are asynchronous, so we initialize in an async method.
  Future<void> initPlatformState() async {
    String platformVersion;
    // Platform messages may fail, so we use a try/catch PlatformException.
    try {
      platformVersion = await SocialSharePlugin.platformVersion;
    } on PlatformException {
      platformVersion = 'Failed to get platform version.';
    }

    // If the widget was removed from the tree while the asynchronous platform
    // message was in flight, we want to discard the reply rather than calling
    // setState to update our non-existent appearance.
    if (!mounted) return;

    setState(() {
      _platformVersion = platformVersion;
    });
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: const Text('Plugin example app'),
        ),
        body: Column(
          children: <Widget>[
            Center(
              child: Text('Running on: $_platformVersion\n'),
            ),
            RaisedButton(
              child: Text('Share to Instagram'),
              onPressed: () async {
                File file = await ImagePicker.pickImage(source: ImageSource.gallery);
                await SocialSharePlugin.shareToFeedInstagram("image/*", file.path);
              },
            ),
            RaisedButton(
              child: Text('Share to Facebook'),
              onPressed: () async {
                File file = await ImagePicker.pickImage(source: ImageSource.gallery);
                await SocialSharePlugin.shareToFeedFacebook('test', file.path);
              },
            ),
            RaisedButton(
              child: Text('Share to Facebook Link'),
              onPressed: () async {
                String url = 'https://flutter.dev/';
                final quote =
                    'Flutter is Google’s portable UI toolkit for building beautiful, natively-compiled applications for mobile, web, and desktop from a single codebase.';
                final result = await SocialSharePlugin.shareToFeedFacebookLink(
                  quote: quote,
                  url: url,
                  onSuccess: (postId) {
                    print('FACEBOOK SUCCESS $postId');
                    return;
                  },
                  onCancel: () {
                    print('FACEBOOK CANCELLED');
                    return;
                  },
                  onError: (error) {
                    print('FACEBOOK ERROR $error');
                    return;
                  },
                );

                print(result);
              },
            ),
            RaisedButton(
              child: Text('Share to Twitter'),
              onPressed: () async {
                String url = 'https://flutter.dev/';
                final text =
                    'Flutter is Google’s portable UI toolkit for building beautiful, natively-compiled applications for mobile, web, and desktop from a single codebase.';
                final result = await SocialSharePlugin.shareToTwitter(
                    text: text,
                    url: url,
                    onSuccess: (_) {
                      print('TWITTER SUCCESS');
                      return;
                    },
                    onCancel: () {
                      print('TWITTER CANCELLED');
                      return;
                    });
                print(result);
              },
            ),
          ],
        ),
      ),
    );
  }
}

你可以使用包https://pub.dev/packages/esys_flutter_share
githubhttps://github.com/esysberlin/esys-flutter-share
iOS 需要特殊操作,您可以查看 iOS 重要说明

分享文字:

Share.text('my text title', 'This is my text to share with other applications.', 'text/plain');

分享文件:

final ByteData bytes = await rootBundle.load('assets/image1.png');
await Share.file('esys image', 'esys.png', bytes.buffer.asUint8List(), 'image/png', text: 'My optional text.');

共享文件:

final ByteData bytes1 = await rootBundle.load('assets/image1.png');
final ByteData bytes2 = await rootBundle.load('assets/image2.png');
final ByteData bytes3 = await rootBundle.load('assets/addresses.csv');

await Share.files(
    'esys images',
    {
        'esys.png': bytes1.buffer.asUint8List(),
        'bluedan.png': bytes2.buffer.asUint8List(),
        'addresses.csv': bytes3.buffer.asUint8List(),
    },
    '*/*',
    text: 'My optional text.');

从网址分享文件:

var request = await HttpClient().getUrl(Uri.parse('https://shop.esys.eu/media/image/6f/8f/af/amlog_transport-berwachung.jpg'));
var response = await request.close();
Uint8List bytes = await consolidateHttpClientResponseBytes(response);
await Share.file('ESYS AMLOG', 'amlog.jpg', bytes, 'image/jpg');

官方演示

【讨论】:

  • 感谢您的帮助,但很抱歉遗漏了相关信息。实际上客户不想使用共享包..我会更新有问题的。我有 fb 按钮 当我点击 FB 按钮时,帖子将在 FB 上分享,我会收到失败和成功的回调。
  • 我已经编辑了我的答案。你可以使用github.com/romatroskin/social_share_plugin,它还提供回调
  • @chunhunghan 有没有办法在 facebook 上分享文字和图片
  • @azhar 我在 stackoverflow 上有类似的问题。但我在 pub.dev 上没有找到相关的包。
  • 我也有类似的挑战。 shareFiles() 方法不向 Facebook 共享文本和图像。它适用于 WhatsApp,但不适用于 Facebook。
【解决方案2】:

允许用户在您的应用 UI 中选择他们的社交平台已不再可行。最好让用户在操作系统中启用他们的平台,然后让 iOS 中的 Share API 或 Activity 视图来完成其余的工作。只需提供带有标签等结构正确的 URL。这是一个很好的资源:@​​987654321@

【讨论】:

    猜你喜欢
    • 2020-05-06
    • 1970-01-01
    • 2012-03-20
    • 1970-01-01
    • 1970-01-01
    • 2017-09-08
    • 1970-01-01
    • 1970-01-01
    • 2012-05-07
    相关资源
    最近更新 更多