Google AdSense plugin for Flutter Web
This package initializes AdSense on your website and provides an ad unit Widget
that can be configured and placed in the desired location in your Flutter web app UI, without having to directly modify the HTML markup of the app directly.
This package is currently in early access and is provided as-is. While it's open source and publicly available, it's likely that you'll need to make additional customizations and configurations to fully integrate it with your Flutter Web App. Please express interest joining Early Access program using this form
To start displaying ads, initialize AdSense with your Publisher ID (only use numbers).
import 'package:google_adsense/experimental/ad_unit_widget.dart';
import 'package:google_adsense/google_adsense.dart';
void main() async {
// Call `initialize` with your Publisher ID (pub-0123456789012345)
// (See: https://support.google.com/adsense/answer/105516)
await adSense.initialize('0123456789012345');
runApp(const MyApp());
}
In order to start displaying Auto ads:
- Configure this feature in your AdSense Console.
Auto ads should start showing just with the call to initialize
, when available.
If you want to display ad units within your app content, continue to the next step
To display an Ad unit in your Flutter application:
- Create ad units in your AdSense account. This will provide an HTML snippet, which you need to translate to Dart.
- Pick the
AdUnitConfiguration
for your ad type:
Ad Unit Type | AdUnitConfiguration constructor method |
---|---|
Display Ads | AdUnitConfiguration.displayAdUnit(...) |
In-feed Ads | AdUnitConfiguration.inFeedAdUnit(...) |
In-article Ads | AdUnitConfiguration.inArticleAdUnit(...) |
Multiplex Ads | AdUnitConfiguration.multiplexAdUnit(...) |
- The data-attributes from the generated snippet are available through the
AdUnitConfiguration
object. Their Dart name is created as follows:
- The
data-
prefix is removed. kebab-case
becomescamelCase
The only exception to this is data-ad-client
, that is passed to adSense.initialize
,
instead of through an AdUnitConfiguration
object.
For example snippet below:
<ins class="adsbygoogle"
style="display:block"
data-ad-client="ca-pub-0123456789012345"
data-ad-slot="1234567890"
data-ad-format="auto"
data-full-width-responsive="true"></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
translates into:
// Call `initialize` with your Publisher ID (pub-0123456789012345)
// (See: https://support.google.com/adsense/answer/105516)
await adSense.initialize('0123456789012345');
and:
AdUnitWidget(
configuration: AdUnitConfiguration.displayAdUnit(
// TODO: Replace with your Ad Unit ID
adSlot: '1234567890',
// Remove AdFormat to make ads limited by height
adFormat: AdFormat.AUTO,
),
),
To modify your responsive ad code:
- Make sure to follow AdSense policies
- Use Flutter instruments for adaptive and responsive design
For example, when not using responsive AdFormat
it is recommended to wrap adUnit widget in the Container
with width and/or height constraints.
Note some policies and restrictions related to ad unit sizing:
Container(
constraints:
const BoxConstraints(maxHeight: 100, maxWidth: 1200),
padding: const EdgeInsets.only(bottom: 10),
child: AdUnitWidget(
configuration: AdUnitConfiguration.displayAdUnit(
// TODO: Replace with your Ad Unit ID
adSlot: '1234567890',
// Do not use adFormat to make ad unit respect height constraint
// adFormat: AdFormat.AUTO,
),
),
),
Make sure to set correct values to adSlot and adClient arguments
- When happening in testing/staging environment it is likely related to the fact that ads are only filled when requested from an authorized domain. If you are testing locally and running your web app on
localhost
, you need to:- Set custom domain name on localhost by creating a local DNS record that would point
127.0.0.1
and/orlocalhost
toyour-domain.com
. On mac/linux machines this can be achieved by adding the following records to you /etc/hosts file:127.0.0.1 your-domain.com
localhost your-domain.com
- Specify additional run arguments in IDE by editing
Run/Debug Configuration
or by passing them directly toflutter run
command:
--web-port=8080
--web-hostname=your-domain.com
- Set custom domain name on localhost by creating a local DNS record that would point
- When happening in production it might be that your domain was not yet approved or was disapproved. Login to your AdSense account to check your domain approval status
There is no deterministic way to make sure your ads are 100% filled even when testing. Some of the way to increase the fill rate:
- Ensure your ad units are correctly configured in AdSense
- Try setting
adTest
parameter totrue
- Try setting AD_FORMAT to
auto
(default setting) - Try setting FULL_WIDTH_RESPONSIVE to
true
(default setting) - Try resizing the window or making sure that ad unit Widget width is less than ~1200px