If Flutter, if we want to randomly to set the component's color, we can use Random()
to do it. It is not a very useful effect, but it is very funny.
Basically, if you know how to use Random()
and Colors
, you can make it easily.
If you are interesting in developing Flutter application, you can refer:
How to User Random
If we want to use Random()
, we need to import 'dart:math'
first.
import 'dart:math'; void main() { for (int i=0; i<10; i++){ print(Random().nextInt(2)); } }
Output:
0
0
1
1
1
0
0
1
1
0
in nextInt(n)
, it will generate a random number between 0 to n-1 and its data type is Int
.
Set the component's color
Suppose we have the following four Container:
import 'package:flutter/material.dart'; void main() => runApp(testPage()); class testPage extends StatelessWidget{ @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( body: Column( children: <Widget>[ Container( width: 100, height: 100, color: Colors.red, ), Container( width: 100, height: 100, color: Colors.brown, ), Container( width: 100, height: 100, color: Colors.blue, ), Container( width: 100, height: 100, color: Colors.yellow, ) ], ) ), ); } }
Output:
data:image/s3,"s3://crabby-images/0788e/0788e65d0287b5723444912396b43b29496c5b80" alt=""
And we customize a color class:
Color MyColor(){ return Color.fromARGB(255, 120, 120, 120); }
Then set all of Container the same color.
class testPage extends StatelessWidget{ @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( body: Column( children: <Widget>[ Container( width: 100, height: 100, color: MyColor(), ), Container( width: 100, height: 100, color: MyColor(), ), Container( width: 100, height: 100, color: MyColor(), ), Container( width: 100, height: 100, color: MyColor(), ) ], ) ), ); } }
Output:
data:image/s3,"s3://crabby-images/e4e17/e4e173ab5b18ab8105383a80bcc90273517b9a59" alt=""
As you can see, we have the same color in all of Container.
But we can set random color.
Color MyColor(){ return Color.fromARGB(255, Random().nextInt(256), Random().nextInt(256), Random().nextInt(256)); }
Output:
data:image/s3,"s3://crabby-images/1a077/1a077031faefe742261305456f27c785b61d32ae" alt=""
data:image/s3,"s3://crabby-images/13d15/13d15df1b08d51f4d2c5ff24cbc4e7f0667bde03" alt=""
data:image/s3,"s3://crabby-images/1d820/1d820625ecf6c476bea56a8893c79db88903941c" alt=""
data:image/s3,"s3://crabby-images/aefcc/aefcca382a10ed342595e48b13a00cec8c62d811" alt=""
Every time we hot reload, the Container will be a new random color component.
Complete Code
import 'dart:math'; import 'package:flutter/material.dart'; void main() => runApp(testPage()); Color MyColor(){ return Color.fromARGB(255, Random().nextInt(256), Random().nextInt(256), Random().nextInt(256)); } class testPage extends StatelessWidget{ @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( body: Column( children: <Widget>[ Container( width: 100, height: 100, color: MyColor(), ), Container( width: 100, height: 100, color: MyColor(), ), Container( width: 100, height: 100, color: MyColor(), ), Container( width: 100, height: 100, color: MyColor(), ) ], ) ), ); } }