一统天下 flutter https://github.com/webabcd/flutter_demo
作者 webabcd
一统天下 flutter - UI: 主题基础
示例如下:
lib\ui\theme.dart
/*
* 主题基础
*/
import 'package:flutter/material.dart';
class ThemeDemo extends StatefulWidget {
const ThemeDemo({Key? key}) : super(key: key);
@override
_ThemeDemoState createState() => _ThemeDemoState();
}
class _ThemeDemoState extends State<ThemeDemo> {
@override
Widget build(BuildContext context) {
return MaterialApp(
/// 通过 MaterialApp 的 theme 定义整个应用程序的主题
/// ThemeData 就是自定义主题对象
theme: ThemeData(
textTheme: const TextTheme(
displayLarge: TextStyle(fontSize: 48.0, fontWeight: FontWeight.bold, color: Colors.white),
),
/// 通过 copyWith() 可以在继承指定的主题的基础上,自定义你需要修改的样式
colorScheme: Theme.of(context).colorScheme.copyWith(background: Colors.red),
),
home: const _MyHomePage(
title: "title",
),
);
}
}
class _MyHomePage extends StatelessWidget {
final String title;
const _MyHomePage({super.key, required this.title});
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(title),
),
backgroundColor: Colors.green,
body: Column(
children: [
Container(
width: double.infinity,
child: Text('Text'),
),
Container(
width: double.infinity,
/// 通过 Theme.of() 引用主题
color: Theme.of(context).colorScheme.background,
child: Text('Text', style: Theme.of(context).textTheme.displayLarge),
),
/// 如果只想在某一个部分使用自定义主题,则可以使用名为 Theme 的 Widget
Theme(
/// 指定一个 ThemeData 类型的对象
data: Theme.of(context).copyWith(
textTheme: const TextTheme(
displayLarge: TextStyle(fontSize: 72.0, color: Colors.yellow),
),
),
/// 注:此处你无法直接使用 Theme 的 data 中定义的样式,需要借助 Builder
child:Builder(
builder: (BuildContext context) {
return Container(
width: double.infinity,
child: Text('Text', style: Theme.of(context).textTheme.displayLarge),
);
},
),
),
],
),
);
}
}
标签:const,title,Text,Theme,一统天下,UI,context,flutter From: https://www.cnblogs.com/webabcd/p/flutter_lib_ui_theme.html一统天下 flutter https://github.com/webabcd/flutter_demo
作者 webabcd