English | 中文简体
Scroll animation numbers widget, any number that need animation effects and easy to use.
// only show
AnimatedDigitWidget(
value: 9999
),
// simple state control
int value = 9999;
AnimatedDigitWidget(
value: value
textStyle: TextStyle(color: Colors.pink),
),
setState((){
value = 191919;
});
Built-in accuracy calculation
AnimatedDigitController _controller = AnimatedDigitController(10240.987);
AnimatedDigitWidget(
controller: _controller,
textStyle: TextStyle(color: Colors.pink),
fractionDigits: 2, // number of decimal places reserved, not rounded
enableSeparator: true, // like this 10,240.98
),
// UI Result => 10,240.98
// increment
_controller.addValue(1314);
// minus
_controller.minusValue(1314); // from v3.1.0 added
// times
_controller.timesValue(1314); // from v3.1.0 added
// divide
_controller.divideValue(1314); // from v3.1.0 added
// reset
_controller.resetValue(1314);
// last
_controller.dispose();
AnimatedDigitWidget(
value: 12531.98, // or use controller
),
AnimatedDigitWidget(
value: 12531.98, // or use controller
enableSeparator: true,
),
AnimatedDigitWidget(
value: 12531.98, // or use controller
fractionDigits: 2,
enableSeparator: true,
),
SingleDigitProvider(
data: SingleDigitData(
useTextSize: true,
builder: (size, value, isNumber, child) {
return isNumber ? child : FlutterLogo();
},
),
child: AnimatedDigitWidget(
value: 12531.98, // or use controller
textStyle: TextStyle(color: Colors.pink[200], fontSize: 30),
separateLength: 1,
separateSymbol: "#",
enableSeparator: true,
),
),
AnimatedDigitWidget(
value: 12531.98, // or use controller
textStyle: TextStyle(color: Colors.orangeAccent.shade700, fontSize: 30),
fractionDigits: 2,
enableSeparator: true,
separateSymbol: "·",
separateLength: 3,
decimalSeparator: ",",
prefix: "\$",
suffix: "€",
),
Wrap a SingleDigitProvider
, then add a ValueColor
object to valueChangeColors
in SingleDigitData
, which is an array, you can add more ...,but always take the last eligible
int value = 9999; // or use Controller.value
SingleDigitProvider(
data: SingleDigitData(
valueChangeColors: [
ValueColor(
//When value <= 0 , the color changes to red
condition: () => value <= 0,
color: Colors.red,
),
// you can add more ...,but always take the last eligible.
],
),
child: AnimatedDigitWidget(
value: value,
textStyle: TextStyle(
color: Colors.orange[200],
fontSize: 30,
),
),
),
🐳 Widget Params & Documentation
⚠️ value
andcontroller
cannot be bothnull
.⚠️ controller
has higher priority.
controller
- digit controller, The displayed number can be controlled viaaddValue
andresetValue
.
value
- the display number.
textStyle
- the numbers text style.boxDecoration
- Use withdecoration
ofContainer
.
- fractionDigits - the fraction digits,
int
, default0
.- 🖌 Example (
1000520.98765
): 0
=>1000520
;1
=>1000520.9
;2
=>1000520.98
;3
=>1000520.987
;N
=>1000520.[N]
;
- 🖌 Example (
The default
0
means an integer, when it is a decimal, if the value is less than thefractionDigits
, it will be filled with0
to the right, and the truncation method is used, so there is no rounding.
decimalSeparator
- the decimal separator,can be replaced by other symbols in place of decimal separators, default.
.
enableSeparator
- enable digit separator. defaultfalse
not enable, onlytrue
,separateLength
andseparateSymbol
valid.- 🖌 Example (
true
):1000520
=>1,000,520
(seealsoseparateLength
orseparateSymbol
)
- 🖌 Example (
separateSymbol
- the numbers separator symbol (only enableSeparator is true), make numbers much easier to read, default,
.- 🖌 Example (
1000520
): ,
=>1,000,520
'
=>1'000'520
-
=>1-000-520
- 🖌 Example (
separateLength
- the numbers separator length (only enableSeparator is true),separateSymbol
by separator length insert, default3
.- 🖌 Example (
1000520
): 1
=>1,0,0,0,5,2,0
2
=>1,00,05,20
3
=>1,000,520
- 🖌 Example (
duration
- the animate duration, default Duration(milliseconds: 300).curve
- the animate curve, default Curves.easeInOut. look animate curve.loop
- enable loop scroll animate. default true, always scroll down, not scroll up from 9 -> 0;false
, scroll up and down.
autoSize
- the default true is to automatically expand and contract according to the size of the (number
/symbol
) itself, false, the text size of the number0
is used as the container size of each number, which can ensure the same width, but it seems that there is a slight interval between1
and other numbers 😊 .
animateAutoSize
- the animation resizing. defaulttrue
,false
will change directly to the size of the number/symbol.
prefix
- the text to display in front of the counter.suffix
- the text to display after the counter.