Меня очень смущает, почему баннер отладки flutter находится в выпущенном приложении. У меня небольшая проблема. После сборки flutter build apk --flavor prod
, когда я установил apk на свой телефон, на нем все еще отображается баннер отладки. Есть идеи, почему?
// app.dart
class App extends StatelessWidget {
@override
Widget build(BuildContext context) {
AppThemes.context = context;
return MultiProvider(
providers: providers,
child: Consumer<FirebaseAnalytics>(builder: (context, analytics, child) {
return MaterialApp(
debugShowCheckedModeBanner: false,
title: Provider.of<AppConfig>(context).appTitle,
theme: AppThemes.defaultTheme,
localizationsDelegates: [
S.delegate,
GlobalMaterialLocalizations.delegate,
],
supportedLocales: S.delegate.supportedLocales,
navigatorObservers: [
FirebaseAnalyticsObserver(
analytics: analytics,
nameExtractor: analyticsNameExtractor,
)
],
navigatorKey: NavigationService.navigatorKey,
onGenerateRoute: AppRoutes.onGenerateRoute,
home: AuthHomePage(),
);
}),
);
}
}
Я также вижу еще одну сумасшедшую проблему, когда я запускаю экземпляр prod flutter run --flavor prod
, он работает со всем экраном, но с выпущенным apk один из экранов отображается серым, если я должен был догадаться, что не могу получить данные из firebase, я думаю, каким-либо способом отладить это?
Я использую https://github.com/lohanidamodar/flutter_firebase_starter
EDIT android / app / build. град
def localProperties = new Properties()
def localPropertiesFile = rootProject.file('local.properties')
if (localPropertiesFile.exists()) {
localPropertiesFile.withReader('UTF-8') { reader ->
localProperties.load(reader)
}
}
def flutterRoot = localProperties.getProperty('flutter.sdk')
if (flutterRoot == null) {
throw new GradleException("Flutter SDK not found. Define location with flutter.sdk in the local.properties file.")
}
def flutterVersionCode = localProperties.getProperty('flutter.versionCode')
if (flutterVersionCode == null) {
flutterVersionCode = '1'
}
def flutterVersionName = localProperties.getProperty('flutter.versionName')
if (flutterVersionName == null) {
flutterVersionName = '1.0'
}
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"
def keystoreProperties = new Properties()
def keystorePropertiesFile = rootProject.file('key.properties')
if (keystorePropertiesFile.exists()) {
keystoreProperties.load(new FileInputStream(keystorePropertiesFile))
}
android {
compileSdkVersion 28
sourceSets {
main.java.srcDirs += 'src/main/kotlin'
}
lintOptions {
disable 'InvalidPackage'
}
defaultConfig {
multiDexEnabled true
// TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
applicationId "com.example.android"
minSdkVersion 16
targetSdkVersion 28
versionCode flutterVersionCode.toInteger()
versionName flutterVersionName
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
flavorDimensions "app"
productFlavors {
dev {
dimension "app"
applicationIdSuffix ".dev"
}
prod {
dimension "app"
}
}
signingConfigs {
release {
keyAlias keystoreProperties['keyAlias']
keyPassword keystoreProperties['keyPassword']
storeFile file(keystoreProperties['storeFile'])
storePassword keystoreProperties['storePassword']
}
}
buildTypes {
release {
// TODO: Add your own signing config for the release build.
// Signing with the debug keys for now, so `flutter run --release` works.
signingConfig signingConfigs.release
}
}
}
flutter {
source '../..'
}
dependencies {
implementation 'androidx.multidex:multidex:2.0.1'
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test:runner:1.1.1'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
}
apply plugin: 'io.fabric'
apply plugin: 'com.google.gms.google-services'