как убрать отладочный баннер на выпуске с флаттером? - PullRequest
1 голос
/ 16 июня 2020

Меня очень смущает, почему баннер отладки 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'

1 Ответ

0 голосов
/ 17 июня 2020

Разобрался, проблема заключалась в баннере, поскольку я не передавал имя файла, которое он должен был использовать. Мой главный файл продукта был назван main_prod.dart. Чтобы исправить это, мне пришлось запустить flutter build apk --flavor prod -t lib/main_prod.dart. Для справки попробуйте это .

Пустая проблема возникла из-за предупреждения Incorrect use of ParentDataWidget.. Оказалось, что я использовал виджет Expanded за пределами Column. Этот мне помог.

...