Не могу создать пользовательские часы цветов - PullRequest
0 голосов
/ 20 сентября 2018

Я пытаюсь использовать пользовательскую цветовую тему для приложения.

Вот файл main.dart

import 'package:flutter/material.dart';

import 'pages/HomePage.dart';

void main() => runApp(new MyApp());

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',
      debugShowCheckedModeBanner: false,
      theme: new ThemeData(
        // This is the theme of your application.
        //
        // Try running your application with "flutter run". You'll see the
        // application has a blue toolbar. Then, without quitting the app, try
        // changing the primarySwatch below to Colors.green and then invoke
        // "hot reload" (press "r" in the console where you ran "flutter run",
        // or press Run > Flutter Hot Reload in IntelliJ). Notice that the
        // counter didn't reset back to zero; the application is not restarted.
        primarySwatch: MaterialColor(0xFF990000, {
          50: Color(0xFF990001),
          300: Color(0xFF990002),
          900: Color(0xFF990003)
        }),
      ),
      home: new HomePage(),
    );
  }
}

Я получаю следующую ошибку:

трепетание: ══╡ ИСКЛЮЧЕНИЕ ПРОВЕДЕНО БИБЛИОТЕКОЙ ВИДЖЕТОВ ╞══════════════════════════════════════════════════════════ flutter: следующее MySuchMethodError было сгенерировано при создании MyApp (dirty): flutter: метод 'computeLuminance' был вызван для null.флаттер: приемник: ноль флаттер: пробный вызов: computeLuminance ()

Что я не так делаю?

Ответы [ 3 ]

0 голосов
/ 24 октября 2018

Вы должны определить все значения, если хотите, чтобы оно работало, у меня была та же ошибка, когда я определил только одно или два значения.

Из официальной документации мы находим, что

Класс MaterialColor Определяет отдельный цвет, а также образец цвета с десятью оттенками цвета.

, например:

 primarySwatch: MaterialColor(0xFFFFFFFF, {
  50:  Color(0xFFFFFFFF),
  100: Color(0xFFFFFFFF),
  200: Color(0xFFFFFFFF),
  300: Color(0xFFFFFFFF),
  400: Color(0xFFFFFFFF),
  500: Color(0xFFFFFFFF),
  600: Color(0xFFFFFFFF),
  700: Color(0xFFFFFFFF),
  800: Color(0xFFFFFFFF),
  900: Color(0xFFFFFFFF),
    });
0 голосов
/ 27 мая 2019

Вам необходимо создать один MaterialColor объект в целом, предоставляя все значения цвета для десяти различных значений яркости.Пожалуйста, рассмотрите возможность использования этого решения для лучшего подхода.

Флаттер: создание пользовательского образца цвета для MaterialColor

0 голосов
/ 20 сентября 2018

Вы не можете назначить MaterialColor на primaryswatch заражать primaryswatch, используемый для назначения различных типов цветов, таких как primaryColor, primaryColorLight / Dark, accentColor и т. Д.

youможно получить более подробную информацию о похожих типах вопросов. Как использовать различные оттенки цветового образца в Flutter?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...