Flutter插件flutter_gromore_plugin的使用

flutter_gromore_plugin #

gromore flutter 插件

开始使用 #

本项目是一个用于 Flutter 的插件包起点, 这是一个专门的包,包括针对 Android 和/或 iOS 的平台特定实现代码。

有关 Flutter 开发的帮助,请参阅 在线文档,其中包含教程、示例、移动开发指南以及完整的 API 参考。

example/lib/main.dart

import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter_gromore_plugin/flutter_gromore_plugin.dart'; // 引入插件

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

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

@override State<MyApp> createState() => _MyAppState(); }

class _MyAppState extends State<MyApp> { String _platformVersion = ‘Unknown’; // 存储平台版本信息

@override void initState() { super.initState(); initPlatformState(); // 初始化平台状态 }

// 平台消息是异步的,因此我们在异步方法中进行初始化。 Future<void> initPlatformState() async { String platformVersion; try { platformVersion = await FlutterGromorePlugin.getPlatformVersion(); // 调用插件方法获取平台版本 } catch (e) { platformVersion = ‘Failed to get platform version: $e’; }

if (!mounted) return;

setState(() {
  _platformVersion = platformVersion; // 更新UI
});

}

@override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( appBar: AppBar( title: const Text(‘插件示例应用’), ), body: Center( child: Text(‘运行在: $_platformVersion’), // 显示平台版本信息 ), ), ); } }

```

Flutter插件flutter_gromore_plugin完整示例Demo

在上述代码中,我们创建了一个简单的 Flutter 应用程序,该应用程序使用 flutter_gromore_plugin 插件来获取平台版本信息。以下是代码的详细解释:

  1. 导入必要的库

    import 'package:flutter/material.dart';
    import 'dart:async';
    import 'package:flutter_gromore_plugin/flutter_gromore_plugin.dart'; // 引入插件
    
  2. 主函数

    void main() {
      runApp(const MyApp());
    }
    
  3. 创建 MyApp

    class MyApp extends StatefulWidget {
      const MyApp({super.key});
    
      [@override](/user/override)
      State&lt;MyApp&gt; createState() =&gt; _MyAppState();
    }
    
  4. 创建 _MyAppState

    class _MyAppState extends State&lt;MyApp&gt; {
      String _platformVersion = 'Unknown'; // 存储平台版本信息
    
      [@override](/user/override)
      void initState() {
        super.initState();
        initPlatformState(); // 初始化平台状态
      }
    
  5. 异步初始化方法

    Future&lt;void&gt; initPlatformState() async {
      String platformVersion;
      try {
        platformVersion = await FlutterGromorePlugin.getPlatformVersion(); // 调用插件方法获取平台版本
      } catch (e) {
        platformVersion = 'Failed to get platform version: $e';
      }
    
      if (!mounted) return;
    
      setState(() {
        _platformVersion = platformVersion; // 更新UI
      });
    }
    
  6. 构建应用界面

    [@override](/user/override)
    Widget build(BuildContext context) {
      return MaterialApp(
        home: Scaffold(
          appBar: AppBar(
            title: const Text('插件示例应用'),
          ),
          body: Center(
            child: Text('运行在: $_platformVersion'), // 显示平台版本信息
          ),
        ),
      );
    }
    

更多关于Flutter插件flutter_gromore_plugin的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter插件flutter_gromore_plugin的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


flutter_gromore_plugin 是一个用于在 Flutter 应用中集成 Gromore 广告的插件。Gromore 是由字节跳动(ByteDance)推出的广告聚合平台,能够帮助开发者更高效地管理和展示广告。通过 flutter_gromore_plugin,开发者可以在 Flutter 应用中轻松集成 Gromore 广告,包括横幅广告、插屏广告、激励视频广告等。

1. 安装插件

首先,你需要在 pubspec.yaml 文件中添加 flutter_gromore_plugin 依赖:

dependencies:
  flutter:
    sdk: flutter
  flutter_gromore_plugin: ^最新版本

然后运行 flutter pub get 来安装插件。

2. 初始化插件

在使用插件之前,你需要初始化 Gromore 广告 SDK。通常,你可以在应用的 main 函数中进行初始化:

import 'package:flutter_gromore_plugin/flutter_gromore_plugin.dart';

void main() async {
  WidgetsFlutterBinding.ensureInitialized();
  
  // 初始化 Gromore 广告 SDK
  await FlutterGromorePlugin.init(
    appId: '你的AppID',
    useTextureView: true, // 是否使用TextureView
    appName: '你的应用名称',
    allowShowNotify: true, // 是否允许显示通知
    debug: true, // 是否开启调试模式
  );
  
  runApp(MyApp());
}

3. 加载和展示广告

flutter_gromore_plugin 支持多种广告类型,以下是几种常见广告的加载和展示示例:

3.1 横幅广告

import 'package:flutter_gromore_plugin/flutter_gromore_plugin.dart';

class BannerAdExample extends StatefulWidget {
  [@override](/user/override)
  _BannerAdExampleState createState() => _BannerAdExampleState();
}

class _BannerAdExampleState extends State<BannerAdExample> {
  FlutterGromoreBannerAd? _bannerAd;

  [@override](/user/override)
  void initState() {
    super.initState();
    _loadBannerAd();
  }

  void _loadBannerAd() {
    _bannerAd = FlutterGromoreBannerAd(
      adUnitId: '你的横幅广告单元ID',
      adSize: AdSize.BANNER,
      listener: (AdEvent event, {int? code, String? message}) {
        // 处理广告事件
        if (event == AdEvent.loaded) {
          setState(() {});
        }
      },
    )..load();
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Banner Ad Example'),
      ),
      body: Center(
        child: _bannerAd != null && _bannerAd!.isLoaded
            ? AdWidget(ad: _bannerAd!)
            : Text('Loading banner ad...'),
      ),
    );
  }

  [@override](/user/override)
  void dispose() {
    _bannerAd?.dispose();
    super.dispose();
  }
}

3.2 插屏广告

import 'package:flutter_gromore_plugin/flutter_gromore_plugin.dart';

class InterstitialAdExample extends StatefulWidget {
  [@override](/user/override)
  _InterstitialAdExampleState createState() => _InterstitialAdExampleState();
}

class _InterstitialAdExampleState extends State<InterstitialAdExample> {
  FlutterGromoreInterstitialAd? _interstitialAd;

  [@override](/user/override)
  void initState() {
    super.initState();
    _loadInterstitialAd();
  }

  void _loadInterstitialAd() {
    _interstitialAd = FlutterGromoreInterstitialAd(
      adUnitId: '你的插屏广告单元ID',
      listener: (AdEvent event, {int? code, String? message}) {
        // 处理广告事件
        if (event == AdEvent.loaded) {
          setState(() {});
        }
      },
    )..load();
  }

  void _showInterstitialAd() {
    if (_interstitialAd != null && _interstitialAd!.isLoaded) {
      _interstitialAd!.show();
    }
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Interstitial Ad Example'),
      ),
      body: Center(
        child: ElevatedButton(
          onPressed: _showInterstitialAd,
          child: Text('Show Interstitial Ad'),
        ),
      ),
    );
  }

  [@override](/user/override)
  void dispose() {
    _interstitialAd?.dispose();
    super.dispose();
  }
}

3.3 激励视频广告

import 'package:flutter_gromore_plugin/flutter_gromore_plugin.dart';

class RewardedAdExample extends StatefulWidget {
  [@override](/user/override)
  _RewardedAdExampleState createState() => _RewardedAdExampleState();
}

class _RewardedAdExampleState extends State<RewardedAdExample> {
  FlutterGromoreRewardedAd? _rewardedAd;

  [@override](/user/override)
  void initState() {
    super.initState();
    _loadRewardedAd();
  }

  void _loadRewardedAd() {
    _rewardedAd = FlutterGromoreRewardedAd(
      adUnitId: '你的激励视频广告单元ID',
      listener: (AdEvent event, {int? code, String? message}) {
        // 处理广告事件
        if (event == AdEvent.loaded) {
          setState(() {});
        } else if (event == AdEvent.rewarded) {
          // 处理奖励逻辑
        }
      },
    )..load();
  }

  void _showRewardedAd() {
    if (_rewardedAd != null && _rewardedAd!.isLoaded) {
      _rewardedAd!.show();
    }
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Rewarded Ad Example'),
      ),
      body: Center(
        child: ElevatedButton(
          onPressed: _showRewardedAd,
          child: Text('Show Rewarded Ad'),
        ),
      ),
    );
  }

  [@override](/user/override)
  void dispose() {
    _rewardedAd?.dispose();
    super.dispose();
  }
}
回到顶部