Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Cleaned up README.md #51

Merged
merged 3 commits into from
Jul 8, 2019
Merged
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
215 changes: 36 additions & 179 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,11 @@ I'm really sorry to announce this, but my schedules have been too tight for me t
# admob_flutter
[![version](https://img.shields.io/badge/Awesome-Flutter-blue.svg?longCache=true&style=flat-square)](https://github.com/Solido/awesome-flutter/)
[![version](https://img.shields.io/pub/v/admob_flutter.svg?style=flat-square)](https://pub.dartlang.org/packages/admob_flutter)
[![GitHub stars](https://img.shields.io/github/stars/YoussefKababe/admob_flutter.svg?style=social&label=Star)](https://github/YoussefKababe/admob_flutter)
[![GitHub forks]( https://img.shields.io/github/forks/YoussefKababe/admob_flutter.svg?style=social&label=Forks)](https://github/YoussefKababe/admob_flutter)
[![GitHub issues]( https://img.shields.io/github/issues/YoussefKababe/admob_flutter.svg?style=social&label=Issues)](https://github/YoussefKababe/admob_flutter)



![Demo](https://i.imgur.com/zJC41es.gif)

Expand All @@ -16,202 +21,54 @@ This is an early version of the plugin, my primary goal was to overcome the bann

# Installation

Add this to your pubspec.yml dependencies:

```yaml
admob_flutter: "^0.3.1"
```
### Supported Platforms
- `0.3.0` >= iOS
- `0.2.0` >= AndroidX
- FlutterSdk >=2.1.0 < 3.0.0

## Android
### Update your AndroidManifest.xml

Add your AdMob App ID to your app's AndroidManifest.xml file by adding the <meta-data> tag shown below. You can find your App ID in the AdMob UI. For android:value insert your own AdMob App ID in quotes, as shown below.

You can use this test App ID from Admob for development:
```
ca-app-pub-3940256099942544~3347511713
```

```xml
<manifest>
<application>
<meta-data
android:name="com.google.android.gms.ads.APPLICATION_ID"
android:value="ca-app-pub-3940256099942544~3347511713"/>
</application>
</manifest>
```
## iOS
Update your `Info.plist` per [Firebase instructions](https://developers.google.com/admob/ios/quick-start#update_your_infoplist).
```xml
<key>GADApplicationIdentifier</key>
<string>ca-app-pub-3940256099942544~1458002511</string>
```
and add
```xml
<key>io.flutter.embedded_views_preview</key>
<true/>
```

# How to use
### Initialize the plugin

First thing to do before attempting to show any ads is to initialize the plugin. You can do this in the earliest starting point of your app, your `main` function:
1. Depend on it
Add this to your package's pubspec.yaml file:

```dart
import 'package:admob_flutter/admob_flutter.dart';
dependencies:
admob_flutter: "^0.3.1"

void main() {
Admob.initialize(getAppId());
runApp(MyApp());
}
```

### Showing Banner Ads
2. Install it
You can install packages from the command line:

This plugin uses Native Platform Views to show Admob banner ads thus, same as any other widget, there's no limitations on where to place your banners.
with Flutter:

```dart
AdmobBanner(
adUnitId: getBannerAdUnitId(),
adSize: AdmobBannerSize.BANNER,
)
$ flutter pub get
```

### Banner Ads sizes

The plugin provides all banner sizes supported by Admob, and will wrap the banner with a correctly sized `Container` so you don't worry about your ad displaying incorrectly:

- `AdmobBannerSize.Banner`: 320x50
- `AdmobBannerSize.LARGE_BANNER`: 320x100
- `AdmobBannerSize.MEDIUM_RECTANGLE`: 300x250
- `AdmobBannerSize.FULL_BANNER`: 468x60
- `AdmobBannerSize.LEADERBOARD`: 728x90
- `AdmobBannerSize.SMART_BANNER`: Wrap in a container with a size of your choice
Alternatively, your editor might support flutter pub get. Check the docs for your editor to learn more.

### Listening to Banner Ads events

You can attach a listener to your ads in order to customize their behavior like this:

```dart
AdmobBanner(
adUnitId: getBannerAdUnitId(),
adSize: AdmobBannerSize.BANNER,
listener: (AdmobAdEvent event, Map<String, dynamic> args) {
switch (event) {
case AdmobAdEvent.loaded:
print('Admob banner loaded!');
break;

case AdmobAdEvent.opened:
print('Admob banner opened!');
break;

case AdmobAdEvent.closed:
print('Admob banner closed!');
break;

case AdmobAdEvent.failedToLoad:
print('Admob banner failed to load. Error code: ${args['errorCode']}');
break;
}
}
)
```

### Showing Interstitial Ads

```dart
// First, create an interstitial ad
AdmobInterstitial interstitialAd = AdmobInterstitial(
adUnitId: getInterstitialAdUnitId(),
);

// Interstitials must be loaded before shown.
// Make sure to always load them ahead so they can be
// available to be shown immediately to the user
interstitialAd.load();

// Check if the ad is loaded and then show it
if (await interstitialAd.isLoaded) {
interstitialAd.show();
}

// Finally, make sure you dispose the ad if you're done with it
interstitialAd.dispose();
```

### Listening to Interstitial Ads events

Same as banner ads, you can attach a listener to interstitials too. For example if you wish to:
- Show the interstitial as soon as it is loaded
- Load a new ad and show it as soon as the old one is closed
- Get your users stuck in an interstitial ads loop to maximize revenue
- Get your Admob account banned and lose all your earnings

You can do something like this (Don't do it!):
3. Import it
Now in your Dart code, you can use:

```dart
AdmobInterstitial interstitialAd;

interstitialAd = AdmobInterstitial(
adUnitId: getInterstitialAdUnitId(),
listener: (AdmobAdEvent event, Map<String, dynamic> args) {
if (event == AdmobAdEvent.loaded) interstitialAd.show();
if (event == AdmobAdEvent.closed) interstitialAd.load();
if (event == AdmobAdEvent.failedToLoad) {
// Start hoping they didn't just ban your account :)
print("Error code: ${args['errorCode']}");
}
},
);
import 'package:admob_flutter/admob_flutter.dart';
```


### Showing Reward Ads

```dart
// First, create a reward ad
AdmobReward rewardAd = AdmobReward(
adUnitId: getRewardBasedVideoAdUnitId(),
);

// Reward ads must be loaded before shown.
// Make sure to always load them ahead so they can be
// available to be shown immediately to the user
rewardAd.load();

// Check if the ad is loaded and then show it
if (await rewardAd.isLoaded) {
rewardAd.show();
}

// Finally, make sure you dispose the ad if you're done with it
rewardAd.dispose();
```
### Supported Platforms
- `0.3.0` >= iOS
- `0.2.0` >= AndroidX
- FlutterSdk >=2.1.0 < 3.0.0

### Listening to Reward Ads events
### Supported Admob features
- Banner Ads
- Interstitial Ads
- Reward Ads
- Native Ads (Coming soon)
- Using targeting info (Coming soon)
edeuss marked this conversation as resolved.
Show resolved Hide resolved

Listening to reward ads events works the same as with banners and interstitials, except that rewards have some additional events. One of them is the `rewarded` event which you should listen to so you know whether your users have earned the reward or not:
### View the rest documentation on the [repository Wiki](https://github.com/YoussefKababe/admob_flutter/wiki)!

```dart
AdmobReward rewardAd = AdmobReward(
adUnitId: getRewardBasedVideoAdUnitId(),
listener: (AdmobAdEvent event, Map<String, dynamic> args) {
if (event == AdmobAdEvent.rewarded) {
print('User was rewarded!');
print('Reward type: ${args['type']}');
print('Reward amount: ${args['amount']}');
}
},
);
```
# Pull Requests

### Showing Native Ads
**Coming soon!**
I welcome and encourage all pull requests. Here are some basic rules to follow to ensure timely addition of your request:

### Using targeting info
**Coming soon!**
1. Match the document style as closely as possible.
2. Please keep PR titles easy to read and descriptive of changes, this will make them easier to review/merge.
3. Pull requests _must_ be made against `master` branch for this repository.
4. Check for existing [issues](https://github.com/iampawan/FlutterExampleApps/issues) first, before filing an issue.
5. Have fun!