This is the official documentation for the Amplitude Analytics Flutter SDK. The Flutter SDK lets you send events from your Flutter application to Amplitude.
Go to the pubspec.yaml
file and add Amplitude SDK as a dependency.
1dependencies:2 amplitude_flutter: ^4.0.0-beta.7
Run flutter pub get
in the terminal to install the SDK.
Add platform :ios, '13.0'
to your Podfile. Run pod install
in the ios directory of your Flutter project to update the CocoaPods dependencies.
To enable Bitcode, follow Flutter's documentation.
Add platform :osx, '10.15'
to your Podfile. Run pod install
in the macos directory of your Flutter project to update the CocoaPods dependencies.
Ensure your app has the com.apple.security.network.client
entitlement to be able to send requests. Manually edit the macos/Runner/Release.entitlements
and macos/Runner/DebugProfile.entitlements
files to include:
1<key>com.apple.security.network.client</key>2<true/>
See Flutter's documentation for more information.
The Flutter SDK uses Dart's JavaScript interoperability to enable Browser SDK 2 for Flutter Web. This requires that you make the SDK available within the global JavaScript scope. Add the following Browser SDK 2 snippet to web/index.html
in your Flutter project:
1<script type="text/javascript"> 2 !function(){"use strict";!function(e,t){var r=e.amplitude||{_q:[],_iq:{}} 3 ;if(r.invoked)e.console&&console.error&&console.error("Amplitude snippet has been loaded.") 4 ;else{var n=function(e,t){e.prototype[t]=function(){return this._q.push({name:t,args:Array.prototype.slice.call(arguments,0)}),this}} 5 ,s=function(e,t,r){return function(n){e._q.push({name:t,args:Array.prototype.slice.call(r,0),resolve:n})}} 6 ,o=function(e,t,r){e._q.push({name:t,args:Array.prototype.slice.call(r,0)})} 7 ,i=function(e,t,r){e[t]=function(){if(r)return{promise:new Promise(s(e,t,Array.prototype.slice.call(arguments)))};o(e,t,Array.prototype.slice.call(arguments))}} 8 ,a=function(e){for(var t=0;t<g.length;t++)i(e,g[t],!1);for(var r=0;r<m.length;r++)i(e,m[r],!0)} 9 ;r.invoked=!0;var c=t.createElement("script")10 ;c.type="text/javascript",c.integrity="sha384-R0H1kXlk6r2aEQMtwVcPolpk0NAuIqM/8NlxAv24Gr3/PBJPl+9elu0bc3o/FDjR",c.crossOrigin="anonymous",c.async=!011 ,c.src="https://cdn.amplitude.com/libs/analytics-browser-2.11.10-min.js.gz"12 ,c.onload=function(){e.amplitude.runQueuedFunctions||console.log("[Amplitude] Error: could not load SDK")}13 ;var l=t.getElementsByTagName("script")[0];l.parentNode.insertBefore(c,l);for(var u=function(){return this._q=[],this}14 ,p=["add","append","clearAll","prepend","set","setOnce","unset","preInsert","postInsert","remove","getUserProperties"],d=0;d<p.length;d++)n(u,p[d]);r.Identify=u15 ;for(var f=function(){return this._q=[],this},v=["getEventProperties","setProductId","setQuantity","setPrice","setRevenue","setRevenueType","setEventProperties"],y=0;y<v.length;y++)n(f,v[y]);r.Revenue=f;var g=["getDeviceId","setDeviceId","getSessionId","setSessionId","getUserId","setUserId","setOptOut","setTransport","reset","extendSession"],m=["init","add","remove","track","logEvent","identify","groupIdentify","setGroup","revenue","flush"]16 ;a(r),r.createInstance=function(e){return r._iq[e]={_q:[]},a(r._iq[e]),r._iq[e]},e.amplitude=r}}(window,document)}();17</script>
Before you instrument your application, initialize the SDK with your Amplitude project's API key.
1import 'package:amplitude_flutter/amplitude.dart'; 2import 'package:amplitude_flutter/configuration.dart'; 3import 'package:amplitude_flutter/events/base_event.dart'; 4 5class YourClass { 6 Future<void> exampleForAmplitude() async { 7 // Create and initailize the instance 8 final Amplitude analytics = Amplitude(Configuration( 9 apiKey: 'YOUR-API-KEY',10 ));11 12 // Wait until the SDK is initialized13 await amplitude.isBuilt;14 15 // Track an event16 amplitude.track(BaseEvent(17 eventType: 'BUTTON_CLICKED',18 eventProperties: {'Hover Time': '100ms'},19 ));20 21 // Send events to the server22 amplitude.flush()23 }24}
Name | Description | Default Value |
---|---|---|
apiKey |
String . The apiKey of your project. |
null |
flushQueueSize |
int . SDK attempts to upload once unsent event count exceeds the event upload threshold or reaches flushIntervalMillis interval. |
30 |
flushIntervalMillis |
int . The amount of time SDK attempts to upload the unsent events to the server or reaches the flushQueueSize threshold. The value is in milliseconds. |
30000 |
instanceName |
String . The name of the instance. Instances with the same name shares storage and identity. For isolated storage and identity use a unique instanceName for each instance. |
$default_instance |
optOut |
bool . Opt the user out of tracking. |
false |
logLevel |
LogLevel The log level. LogLevel.off , LogLevel.error , LogLevel.warn , LogLevel.log , LogLevel.debug |
LogLevel.warn |
minIdLength |
int . The minimum length for user id or device id. |
5 |
partnerId |
int . The partner id for partner integration. |
null |
flushMaxRetries |
int . Maximum retry times. |
5 |
useBatch |
bool . Whether to use batch API. |
false |
serverZone |
ServerZone . ServerZone.us or ServerZone.eu . The server zone to send to. Adjust server URL based on this config. |
ServerZone.us |
serverUrl |
String . The server URL events upload to. |
https://api2.amplitude.com/2/httpapi |
minTimeBetweenSessionsMillis |
int . The amount of time for session timeout. The value is in milliseconds. Defaults to 300,000 (5 minutes) for iOS/Android and 1,800,000 (30 minutes) for Web. Overriding this value changes the session timeout for all platforms. This maps to minTimeBetweenSessionsMillis for iOS/Android and sessionTimeout for Web. |
300000 |
trackingOptions |
TrackingOptions . Options to control the values tracked in SDK. |
enable |
Name | Description | Default Value |
---|---|---|
defaultTracking |
DefaultTrackingOptions . Options to control the default events tracking. |
Check Tracking default events. |
enableCoppaControl |
bool . Whether to enable COPPA control for tracking options. |
false |
flushEventsOnClose |
bool . Flush unsent events on app close. |
true |
identifyBatchIntervalMillis |
int . The amount of time SDK attempts to batch intercepted identify events. The value is in milliseconds |
30000 |
migrateLegacyData |
bool . Whether to migrate maintenance Android SDK and maintenance iOS SDK data (events, user/device ID). Learn more at the configuration section of the underlying Kotlin SDK and Swift SDK. |
true |
Name | Description | Default Value |
---|---|---|
deviceId |
String . The device ID to use for this device. If you don't provide a deviceId , Amplitude generates one. |
null |
Name | Description | Default Value |
---|---|---|
locationListening |
bool . Whether to enable Android location service. Learn more here. |
true |
useAdvertisingIdForDeviceId |
bool . Whether to use advertising id as device id. Check here for required module and permission. |
false |
useAppSetIdForDeviceId |
bool . Whether to use app set id as device id. Check here for required module and permission. |
false |
Name | Description | Default Value |
---|---|---|
appVersion |
String . Sets an app version for events tracked. This can be the version of your application. For example: "1.0.0". |
null |
cookieOptions.domain |
String . Sets the domain property of cookies created. |
null |
cookieOptions.expiration |
int . Sets expiration of cookies created in days. |
365 days |
cookieOptions.sameSite |
String . Sets SameSite property of cookies created. |
null |
cookieOptions.secure |
bool . Sets Secure property of cookies created. |
null |
cookieOptions.upgrade |
bool . Sets upgrading from cookies created by maintenance Browser SDK. If true , new Browser SDK deletes cookies created by maintenance Browser SDK. If false , Browser SDK keeps cookies created by maintenance Browser SDK. |
null |
identityStorage |
String . Sets storage API for user identity. Options include cookie for document.cookie , localStorage for localStorage , or none to opt-out of persisting user identity. |
cookie |
userId |
String . Sets an identifier for the tracked user. Must have a minimum length of 5 characters unless overridden with the minIdLength option. |
null |
transport |
String . Sets request API to use by name. Options include fetch for fetch , xhr for XMLHTTPRequest , or beacon for navigator.sendBeacon . |
fetch |
fetchRemoteConfig |
bool . Whether the SDK fetches remote configuration. See here for more information. |
false |
To support high-performance environments, the SDK sends events in batches. Every event logged by the track
method queues in memory. The SDK flushes in batches in the background. Customize batch behavior with flushQueueSize
and flushIntervalMillis
. By default, the serverUrl
is https://api2.amplitude.com/2/httpapi
.
If you need to send large batches of data at once, set useBatch
to true
to set setServerUrl
to the batch event upload API https://api2.amplitude.com/batch
. Both the regular mode and the batch mode use the same events upload threshold and flush time intervals.
1final Amplitude analytics = Amplitude(Configuration(2 apiKey: 'YOUR-API-KEY',3 flushIntervalMillis: 50000,4 flushQueueSize: 20,5));
You can configure the server zone when initializing the client for sending data to Amplitude's EU servers. The SDK sends data based on the server zone if it's set.
For EU data residency, the project must be set up inside Amplitude EU. You must initialize the SDK with the API key from Amplitude EU.
1final Amplitude analytics = Amplitude(Configuration(2 apiKey: 'YOUR-API-KEY',3 serverZone: ServerZone.eu,4));
Events represent how users interact with your application. For example, "Song Played" may be an action you want to track.
1amplitude.track(BaseEvent('Song Played'));
You can also optionally include event properties.
1amplitude.track(BaseEvent('Song Played', eventProperties: {'title': 'Happy Birthday'}));
Refer to the BaseEvent interface for all available fields.
Identify is for setting the user properties of a particular user without sending any event. The SDK supports the operations set
, setOnce
, unset
, add
, append
, prepend
, preInsert
, postInsert
, and remove
on individual user properties. Declare the operations with a provided Identify interface. You can chain together multiple operations in a single Identify object. The Identify object is then passed to the Amplitude client to send to the server.
If you send the Identify call after the event, the results of operations are visible immediately in the dashboard user's profile area, but it doesn't appear in chart results until the SDK sends another event after the Identify call. As a result, the identify call only affects events going forward. For more information, see User Properties and Events.
You can handle the identity of a user using the identify methods. Proper use of these methods can connect events to the correct user as they move across devices, browsers, and other platforms. Send an identify call containing those user property operations to Amplitude server to tie a user's events with specific user properties.
1final Identify identify = Identify()2 ..set('color', 'green')3amplitude.identify(identify)
The SDK can track more default events. You can configure it to track the following events by default:
Name | Type | Default Value | Description |
---|---|---|---|
config.defaultTracking.sessions |
Optional. bool |
true |
Enables session tracking. If value is true , Amplitude tracks session start and session end events otherwise, Amplitude doesn't track session events. When this setting is false , Amplitude tracks sessionId only.See Tracking sessions for more information. |
config.defaultTracking.appLifecycles |
Optional. bool |
false |
Enables application lifecycle events tracking. If value is true , Amplitude tracks application installed, application updated, application opened, and application backgrounded events.Event properties tracked includes: [Amplitude] Version ,[Amplitude] Build ,[Amplitude] Previous Version , [Amplitude] Previous Build , [Amplitude] From Background See Tracking application lifecycles for more information. |
config.defaultTracking.deepLinks |
Optional. bool |
false |
Only available on Android. It enables deep link tracking. If value is true , Amplitude tracks deep link opened events.Event properties tracked includes: [Amplitude] Link URL , [Amplitude] Link Referrer See Tracking deep links for more information. |
You can enable Amplitude to start tracking all events mentioned above, use the code sample below. Otherwise, you can omit the configuration to keep only session tracking enabled.
1Amplitude(2 Configuration(3 apiKey: 'YOUR-API-KEY',4 defaultTracking: DefaultTrackingOptions.all()5 )6);
Amplitude may add more events in a future version, and this configuration enables tracking for those events as well.
Similarly, you can prevent Amplitude from track default events with the following code sample:
1Amplitude(2 Configuration(3 apiKey: 'YOUR-API-KEY',4 defaultTracking: DefaultTrackingOptions.none()5 )6);
You can also customize the tracking with DefaultTrackingOptions
.
1Amplitude( 2 Configuration( 3 apiKey: 'YOUR-API-KEY', 4 defaultTracking: DefaultTrackingOptions( 5 sessions: false, 6 appLifecycles: true, 7 deepLinks: true, 8 ) 9 )10);
When you set configuration.defaultTracking.sessions: true
, you instruct Amplitude to track session events.
1Amplitude(2 Configuration(3 apiKey: 'YOUR-API-KEY',4 defaultTracking: DefaultTrackingOptions(5 sessions: true,6 )7 )8);
When you set configuration.defaultTracking.appLifecycles
to true
, Amplitude tracks application lifecycle events.
1Amplitude(2 Configuration(3 apiKey: 'YOUR-API-KEY',4 defaultTracking: DefaultTrackingOptions(5 appLifecycles: true,6 )7 )8);
After enabling this setting, Amplitude tracks the following events:
[Amplitude] Application Installed
, this event fires when a user opens the application for the first time right after installation.[Amplitude] Application Updated
, this event fires when a user opens the application after updating the application.[Amplitude] Application Opened
, this event fires when a user launches or foregrounds the application after the first open.[Amplitude] Application Backgrounded
, this event fires when a user backgrounds the application.Deep link tracking is available on Android.
When you set configuration.defaultTracking.deepLinks
to true
, Amplitude tracks events related to deep links in your application.
1Amplitude(2 Configuration(3 apiKey: 'YOUR-API-KEY',4 defaultTracking: DefaultTrackingOptions(5 deepLinks: true,6 )7 )8);
After enabling this setting, Amplitude tracks the [Amplitude] Deep Link Opened
event with the URL and referrer information.
Amplitude supports assigning users to groups and performing queries, such as Count by Distinct, on those groups. If at least one member of the group has performed the specific event, then the count includes the group.
For example, you want to group your users based on what organization they're in by using an 'orgId'. Joe is in 'orgId' '10', and Sue is in 'orgId' '15'. Sue and Joe both perform a certain event. You can query their organizations in the Event Segmentation Chart.
When setting groups, define a groupType
and groupName
. In the previous example, 'orgId' is the groupType
and '10' and '15' are the values for groupName
. Another example of a groupType
could be 'sport' with groupName
values like 'tennis' and 'baseball'.
Setting a group also sets the groupType:groupName
as a user property, and overwrites any existing groupName
value set for that user's groupType
, and the corresponding user property value. groupType
is a string, and groupName
can be either a string or an array of strings to indicate that a user is in multiple groups.
If Joe is in 'orgId' '15', then the groupName
would be '15'.
1// set group with a single group name2amplitude.setGroup('orgId', '15');
If Joe is in 'sport' 'tennis' and 'soccer', then the groupName
would be '["tennis", "soccer"]'.
1// set group with multiple group names2amplitude.setGroup('sport', ['tennis', 'soccer']);
You can also set event-level groups by passing an Event
Object with groups
to track
. With event-level groups, the group designation applies only to the specific logged event, and doesn't persist on the user unless you explicitly set it with setGroup
.
1amplitude.track(BaseEvent('event type',2 eventProperties: {'event property': 'event property value'},3 groups: {'ordId': '15'}));
Use the Group Identify API to set or update the properties of particular groups. Keep these considerations in mind:
The groupIdentify
method accepts a group type string parameter and group name object parameter, and an Identify object that's applied to the group.
1final groupType = 'plan';2final groupName = 'enterprise';3 4final identify = Identify().set('key', 'value');5amplitude.groupIdentify(groupType, groupName, identify);
Amplitude can track revenue generated by a user. Revenue is tracked through distinct revenue objects, which have special fields that are used in Amplitude's Event Segmentation and Revenue LTV charts. This allows Amplitude to automatically display data relevant to revenue in the platform. Revenue objects support the following special properties, as well as user-defined properties through the eventProperties
field.
1final revenue = Revenue()2 ..productId = 'com.company.productId'3 ..price = 3.994 ..quantity = 3;5amplitude.revenue(revenue);
Name | Description |
---|---|
productId |
Optional. String. An identifier for the product. Amplitude recommends something like the Google Play Store product ID. Defaults to null . |
quantity |
Required. Integer. The quantity of products purchased. Note: revenue = quantity * price. Defaults to 1 |
price |
Required. Double. The price of the products purchased, and this can be negative. Note: revenue = quantity * price. Defaults to null . |
revenueType |
Optional, but required for revenue verification. String. The revenue type (for example, tax, refund, income). Defaults to null . |
receipt |
Optional. String. The receipt identifier of the revenue. For example, "123456". Defaults to null . |
receiptSignature |
Optional, but required for revenue verification. String. Defaults to null . |
If your app has its login system that you want to track users with, call setUserId
at any time.
1amplitude.setUserId('user@amplitude.com');
You can assign a new device ID using deviceId
. When setting a custom device ID, make sure the value is sufficiently unique. Amplitude recommends using a UUID.
1amplitude.setDeviceId('your-unique-device-id');
reset
is a shortcut to anonymize users after they log out, by:
userId
to null
deviceId
to a new value based on current configurationWith an empty userId
and a completely new deviceId
, the current user would appear as a brand new user in dashboard.
1amplitude.reset();
Thanks for your feedback!
July 23rd, 2024
Need help? Contact Support
Visit Amplitude.com
Have a look at the Amplitude Blog
Learn more at Amplitude Academy
© 2025 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.