3_flutter_黑色主题,Listview(列表),GridView(网格)

本文详细介绍了如何在Flutter中实现黑色主题,包括静态和动态主题切换,并展示了Listview和GridView的使用方法,以及如何在GridView中填充内容和添加点击事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1_黑色主题


import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}
class MyApp extends StatelessWidget {

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      theme: ThemeData(
        brightness:Brightness.dark,
        primarySwatch: Colors.blue,
        primaryColor: const Color(0xFF212121),
        accentColor: const Color(0xFF64ffda),
        canvasColor: const Color(0xFF303030),
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key}) : super(key: key);
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('黑色主题'),
      ),
    );
  }
}
复制代码

1.1_动态黑色主题

import 'package:flutter/material.dart';

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

class MyApp extends StatefulWidget {  
  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {  
  bool darkTheme=false;
  @override
  Widget build(BuildContext context) { 
    return MaterialApp(
      theme: darkTheme ? ThemeData.dark() :ThemeData.light(),
      home: Scaffold(
        appBar: AppBar(
          title: Text('动态黑色主题'),
        ),

        body: Container(
          child: Column(
            children: <Widget>[
    
           ListTile(
             leading: Icon(Icons.accessibility),
             title: Text('黑色主题'),
             trailing: Switch(
               value: darkTheme,
           onChanged: (value){
             setState(() {
               darkTheme=value;
             });
           },
         ),
       ),

        ],
      )
    ),
      ),
    );
        
   
  }
}
复制代码

2_Listview(列表)


import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}
class MyApp extends StatelessWidget {

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Generated App',
      theme: ThemeData(
        primarySwatch: Colors.blue,
        primaryColor: const Color(0xFF2196f3),
        accentColor: const Color(0xFF2196f3),
        canvasColor: const Color(0xFFfafafa),
        fontFamily: 'Merriweather',
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('App Name'),
      ),
      body: ListView(children: List.generate(10, (idx){
        return Card(child: Container(
          height: 150,
          color: Colors.greenAccent,
          child: Text('$idx'),
        ),);
      }),),
    );
  }
}
复制代码

2.1基本列表

import 'package:flutter/material.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    final title = 'Basic List';

    return MaterialApp(
      title: title,
      home: Scaffold(
        appBar: AppBar(
          title: Text(title),
        ),
        body: ListView(
          children: <Widget>[
            ListTile(
              leading: Icon(Icons.map),
              title: Text('Map'),
            ),
            ListTile(
              leading: Icon(Icons.photo_album),
              title: Text('Album'),
            ),
            ListTile(
              leading: Icon(Icons.phone),
              title: Text('Phone'),
            ),
          ],
        ),
      ),
    );
  }
}
复制代码

3_GridView(网格)


import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}
class MyApp extends StatelessWidget {

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Generated App',
      theme: ThemeData(
        primarySwatch: Colors.blue,
        primaryColor: const Color(0xFF2196f3),
        accentColor: const Color(0xFF2196f3),
        canvasColor: const Color(0xFFfafafa),
        fontFamily: 'Merriweather',
      ),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('App Name'),
      ),
      
      body: GridView.count(
        crossAxisCount: 2,
        childAspectRatio: 2/3,
      children: List.generate(100, (idx){
        return Card(child: Container(
          color: Colors.greenAccent,
          child: Text('$idx'),
        ),);
      }),),

    );
  }
}
复制代码

3.1_网格视图填入内容(图标+文字+图标颜色)

import 'package:flutter/material.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(   
      home:Scaffold( 
      appBar: AppBar(title: Text('双行card'),),
body: Container(
  child: GridView.count(
      primary: true,
      padding: const EdgeInsets.all(1.0),
      crossAxisCount: 2,
      mainAxisSpacing: 1.0,
      crossAxisSpacing: 1.0,
      children: <Widget>[
      MyGridView (icon: Icons.home,teks: "欢迎",warnaIcon: Colors.brown,),
      MyGridView (icon: Icons.favorite,teks: "大家",warnaIcon: Colors.pink,),
      MyGridView (icon: Icons.place,teks: "阅读",warnaIcon: Colors.blue,), 
      MyGridView (icon: Icons.settings,teks: "莫狄",warnaIcon: Colors.black,),
      MyGridView (icon: Icons.access_time,teks: "博客",warnaIcon: Colors.yellow,), 
      MyGridView (icon: Icons.accessibility,teks: "谢谢",warnaIcon: Colors.red,),
      MyGridView (icon: Icons.add,teks: "观看",warnaIcon: Colors.green,), 
      MyGridView (icon: Icons.airplay,teks: "!!!",warnaIcon: Colors.teal,),
      ],
    ),
),
    ),
    );
 
  }
}

class MyGridView  extends StatelessWidget{
  MyGridView ({this.icon,this.teks,this.warnaIcon});

  final IconData icon;
  final String teks;
  final Color warnaIcon;

  @override
  Widget build(BuildContext context){
    return Container(
child: Card(
  elevation: 1.5,
  child: Column(
    crossAxisAlignment: CrossAxisAlignment.stretch,
    mainAxisSize: MainAxisSize.min,
    verticalDirection: VerticalDirection.down,
    children: <Widget>[
      Icon(icon,
      size: 130.0,
      color: warnaIcon),
      Center(
        child:Text(teks),
      ), 
    ],
  ),
),
    );
  }
}
复制代码

3.2_点击事件

不要在MaterialApp里面写,分开写

import 'package:flutter/material.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(   
      home:Scaffold( 
      appBar: AppBar(title: Text('双行card'),),
body: myapp1(),
    ),
    );
 
  }
}
class myapp1 extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body:Container(
  child: GridView.count(
      primary: true,
      padding: const EdgeInsets.all(1.0),
      crossAxisCount: 2,
      mainAxisSpacing: 1.0,
      crossAxisSpacing: 1.0,
      children: <Widget>[
       InkWell( 
         child:MyGridView (icon: Icons.home,teks: "欢迎",warnaIcon: Colors.brown,),
    onTap: () { 
        Navigator.push(
              context,
              MaterialPageRoute(builder: (context) => SecondScreen()),
            );
    },),


     InkWell(
          child:MyGridView (icon: Icons.favorite,teks: "大家",warnaIcon: Colors.pink,),
    onTap: () {
        Navigator.push(
              context,
              MaterialPageRoute(builder: (context) => SecondScreen1()),
            );
    },),


     InkWell(
          child:MyGridView (icon: Icons.place,teks: "阅读",warnaIcon: Colors.blue,),
    onTap: () {
        Navigator.push(
              context,
              MaterialPageRoute(builder: (context) => SecondScreen1()),
            );
    },),  

      MyGridView (icon: Icons.settings,teks: "莫狄",warnaIcon: Colors.black,),
      MyGridView (icon: Icons.access_time,teks: "博客",warnaIcon: Colors.yellow,), 
      MyGridView (icon: Icons.accessibility,teks: "谢谢",warnaIcon: Colors.red,),
      MyGridView (icon: Icons.add,teks: "观看",warnaIcon: Colors.green,), 
      MyGridView (icon: Icons.airplay,teks: "!!!",warnaIcon: Colors.teal,),
      ],
    ),
),
    );
  }
}
class MyGridView  extends StatelessWidget{
  MyGridView ({this.icon,this.teks,this.warnaIcon});

  final IconData icon;
  final String teks;
  final Color warnaIcon;

  @override
  Widget build(BuildContext context){
    return Container(
       child:InkWell(
         child: Card(
  elevation: 1.5,
 
    child: Column(
    crossAxisAlignment: CrossAxisAlignment.stretch,
    mainAxisSize: MainAxisSize.min,
    verticalDirection: VerticalDirection.down,
    children: <Widget>[
      Icon(icon,
      size: 130.0,
      color: warnaIcon),
      Center(
        child:Text(teks),
      ), 
    ],
  ),
),
   ),
    );
  }
}

class SecondScreen extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("新页面"),
      ),
      body: Center(
        child: RaisedButton(
          onPressed: () {
            Navigator.pop(context);
          },
          child: Text('Go back!'),
        ),
      ),
    );
  }
}

class SecondScreen1 extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("新页面1"),
      ),
      body: Center(
        child: RaisedButton(
          onPressed: () {
            Navigator.pop(context);
          },
          child: Text('Go back!'),
        ),
      ),
    );
  }
}

复制代码

3.3_网格视图填入内容(图片+文字)

import 'package:flutter/material.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(   
      home:Scaffold( 
      appBar: AppBar(title: Text('双行card'),),
body: Myapp1(),
    ),
    );
 
  }
}
class  Myapp1 extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body:Container(
  child: GridView.count(
      primary: true,
      padding: const EdgeInsets.all(1.0),
      crossAxisCount: 2,
      childAspectRatio: 2/3,
      mainAxisSpacing: 1.0,
      crossAxisSpacing: 1.0,
      children: <Widget>[
       InkWell( 
         child:MyGridView (image: "capacitor.png",teks: "莫狄"),
    onTap: () { 
        Navigator.push(
              context,
              MaterialPageRoute(builder: (context) => SecondScreen()),
            );
    },),


     InkWell(
          child:MyGridView (image: "capacitor.png",teks: "莫狄"),
    onTap: () {
        Navigator.push(
              context,
              MaterialPageRoute(builder: (context) => SecondScreen1()),
            );
    },),

     InkWell(
          child:MyGridView (image: "capacitor.png",teks: "莫狄"),
    onTap: () {
        Navigator.push(
              context,
              MaterialPageRoute(builder: (context) => SecondScreen1()),
            );
    },),  

      MyGridView (image: "capacitor.png",teks: "莫狄"),
      MyGridView (image: "capacitor.png",teks: "博客"), 
      MyGridView (image: "capacitor.png",teks: "谢谢"),
      MyGridView (image: "capacitor.png",teks: "观看"), 
      MyGridView (image: "capacitor.png",teks: "!!!"),
      ],
    ),
),
    );
  }
}
class MyGridView  extends StatelessWidget{
  MyGridView ({this.image,this.teks});

  final String  image;
  final String teks;

  @override
  Widget build(BuildContext context){
    return Container(
       child:InkWell(
         child: Card(
  elevation: 1.5,
 
    child: Column(
    crossAxisAlignment: CrossAxisAlignment.stretch,
    mainAxisSize: MainAxisSize.min,
    verticalDirection: VerticalDirection.down,
    children: <Widget>[
      Image(image: AssetImage('lib/images/' + image)),
      Center(
        child:Text(teks),
      ), 
    ],
  ),
),
   ),
    );
  }
}

class SecondScreen extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("新页面"),
      ),
      body: Center(
        child: RaisedButton(
          onPressed: () {
            Navigator.pop(context);
          },
          child: Text('Go back!'),
        ),
      ),
    );
  }
}

class SecondScreen1 extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("新页面1"),
      ),
      body: Center(
        child: RaisedButton(
          onPressed: () {
            Navigator.pop(context);
          },
          child: Text('Go back!'),
        ),
      ),
    );
  }
}
复制代码

转载于:https://juejin.im/post/5c713b896fb9a049e702bc29

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值