Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hukusuke1007/stop_watch_timer
This is Stop Watch Timer for flutter plugin.🏃♂️
https://github.com/hukusuke1007/stop_watch_timer
flutter flutter-package flutter-plugin timer
Last synced: 2 days ago
JSON representation
This is Stop Watch Timer for flutter plugin.🏃♂️
- Host: GitHub
- URL: https://github.com/hukusuke1007/stop_watch_timer
- Owner: hukusuke1007
- License: mit
- Created: 2020-01-30T08:02:15.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-08-24T00:35:22.000Z (5 months ago)
- Last Synced: 2025-01-08T05:18:52.750Z (9 days ago)
- Topics: flutter, flutter-package, flutter-plugin, timer
- Language: Dart
- Homepage: https://pub.dev/packages/stop_watch_timer
- Size: 115 MB
- Stars: 105
- Watchers: 3
- Forks: 59
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# stop_watch_timer
[![Never inc][logo_black]][never_link_light]
Developed with 💙 by [Never inc](https://neverjp.com/).
---
Simple CountUp timer / CountDown timer. It easily create app of stopwatch.
[https://pub.dev/packages/stop_watch_timer](https://pub.dev/packages/stop_watch_timer)
![./img/countup_timer_demo](img/countup_timer_demo.gif) ![./img/countdown_timer_demo](img/countdown_timer_demo.gif)
## Example code
See the example directory for a complete sample app using stop_watch_timer.[example](https://github.com/hukusuke1007/stop_watch_timer/tree/master/example)
## Installation
Add this to your package's pubspec.yaml file:
```
dependencies:
stop_watch_timer:
```## Features
This is StopWatchMode.
- CountUp
- CountDown### CountUp
This is default mode. If you' d like to set it explicitly, set StopWatchMode.countUp to mode.
```dart
final stopWatchTimer = StopWatchTimer(
mode: StopWatchMode.countUp
);
```[example code](https://github.com/hukusuke1007/stop_watch_timer/tree/master/example/lib/count_up_timer_page.dart)
### CountDown
Can be set StopWatchMode.countDown mode and preset millisecond.
```dart
final stopWatchTimer = StopWatchTimer(
mode: StopWatchMode.countDown,
presetMillisecond: StopWatchTimer.getMilliSecFromMinute(1), // millisecond => minute.
);
```[example code](https://github.com/hukusuke1007/stop_watch_timer/tree/master/example/lib/count_down_timer_page.dart)
This is helper functions for presetTime.
```dart
/// Get millisecond from hour
final value = StopWatchTimer.getMilliSecFromHour(1);/// Get millisecond from minute
final value = StopWatchTimer.getMilliSecFromMinute(60);/// Get millisecond from second
final value = StopWatchTimer.getMilliSecFromSecond(60 * 60);
```## Usage
```dart
import 'package:stop_watch_timer/stop_watch_timer.dart'; // Import stop_watch_timerclass MyApp extends StatefulWidget {
@override
_MyAppState createState() => _MyAppState();
}class _MyAppState extends State {
final StopWatchTimer _stopWatchTimer = StopWatchTimer(); // Create instance.
@override
void initState() {
super.initState();
}@override
void dispose() async {
super.dispose();
await _stopWatchTimer.dispose(); // Need to call dispose function.
}@override
Widget build(BuildContext context) {
...
}
}
```To operation stop watch.
```dart
// Start timer.
_stopWatchTimer.onStartTimer();// Stop timer.
_stopWatchTimer.onStopTimer();// Reset timer
_stopWatchTimer.onResetTimer();// Lap time
_stopWatchTimer.onAddLap();
```Can be set preset time. This case is "00:01.23".
```dart
// Set Millisecond.
_stopWatchTimer.setPresetTime(mSec: 1234);
```When timer is idle state, can be set this.
```dart
// Set Hours. (ex. 1 hours)
_stopWatchTimer.setPresetHoursTime(1);// Set Minute. (ex. 30 minute)
_stopWatchTimer.setPresetMinuteTime(30);// Set Second. (ex. 120 second)
_stopWatchTimer.setPresetSecondTime(120);
```### Using the stream to get the time
```dart
_stopWatchTimer.rawTime.listen((value) => print('rawTime $value'));
_stopWatchTimer.minuteTime.listen((value) => print('minuteTime $value'));
_stopWatchTimer.secondTime.listen((value) => print('secondTime $value'));
_stopWatchTimer.records.listen((value) => print('records $value'));
_stopWatchTimer.fetchStopped.listen((value) => print('stopped from stream'));
_stopWatchTimer.fetchEnded.listen((value) => print('ended from stream'));
```
Display time formatted stop watch. Using function of "rawTime" and "getDisplayTime".
```dart
final raw = 3000 // 3sec
final displayTime = StopWatchTimer.getDisplayTime(raw); // 00:00:03.00
```### Using the StreamBuilder to get the time
Example code using stream builder.
```dart
StreamBuilder(
stream: _stopWatchTimer.rawTime,
initialData: 0,
builder: (context, snap) {
final value = snap.data;
final displayTime = StopWatchTimer.getDisplayTime(value);
return Column(
children: [
Padding(
padding: const EdgeInsets.all(8),
child: Text(
displayTime,
style: TextStyle(
fontSize: 40,
fontFamily: 'Helvetica',
fontWeight: FontWeight.bold
),
),
),
Padding(
padding: const EdgeInsets.all(8),
child: Text(
value.toString(),
style: TextStyle(
fontSize: 16,
fontFamily: 'Helvetica',
fontWeight: FontWeight.w400
),
),
),
],
);
},
),
),
```Notify from "secondTime" every second.
```dart
_stopWatchTimer.secondTime.listen((value) => print('secondTime $value'));
```Example code using stream builder.
```dart
StreamBuilder(
stream: _stopWatchTimer.secondTime,
initialData: 0,
builder: (context, snap) {
final value = snap.data;
print('Listen every second. $value');
return Column(
children: [
Padding(
padding: const EdgeInsets.all(8),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
const Padding(
padding: EdgeInsets.symmetric(horizontal: 4),
child: Text(
'second',
style: TextStyle(
fontSize: 17,
fontFamily: 'Helvetica',
),
),
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 4),
child: Text(
value.toString(),
style: TextStyle(
fontSize: 30,
fontFamily: 'Helvetica',
fontWeight: FontWeight.bold
),
),
),
],
)
),
],
);
},
),
```Notify from "minuteTime" every minute.
```dart
_stopWatchTimer.minuteTime.listen((value) => print('minuteTime $value'));
```Example code using stream builder.
```dart
StreamBuilder(
stream: _stopWatchTimer.minuteTime,
initialData: 0,
builder: (context, snap) {
final value = snap.data;
print('Listen every minute. $value');
return Column(
children: [
Padding(
padding: const EdgeInsets.all(8),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
const Padding(
padding: EdgeInsets.symmetric(horizontal: 4),
child: Text(
'minute',
style: TextStyle(
fontSize: 17,
fontFamily: 'Helvetica',
),
),
),
Padding(
padding: const EdgeInsets.symmetric(horizontal: 4),
child: Text(
value.toString(),
style: TextStyle(
fontSize: 30,
fontFamily: 'Helvetica',
fontWeight: FontWeight.bold
),
),
),
],
)
),
],
);
},
),
```Notify lap time.
```dart
_stopWatchTimer.records.listen((value) => print('records $value'));
```Example code using stream builder.
```dart
StreamBuilder>(
stream: _stopWatchTimer.records,
initialData: const [],
builder: (context, snap) {
final value = snap.data;
return ListView.builder(
scrollDirection: Axis.vertical,
itemBuilder: (BuildContext context, int index) {
final data = value[index];
return Column(
children: [
Padding(
padding: const EdgeInsets.all(8),
child: Text(
'${index + 1} ${data.displayTime}',
style: TextStyle(
fontSize: 17,
fontFamily: 'Helvetica',
fontWeight: FontWeight.bold
),
),
),
const Divider(height: 1,)
],
);
},
itemCount: value.length,
);
},
),```
### Using the Callback to get the time
```dart
final _stopWatchTimer = StopWatchTimer(
onChange: (value) {
final displayTime = StopWatchTimer.getDisplayTime(value);
print('displayTime $displayTime');
},
onChangeRawSecond: (value) => print('onChangeRawSecond $value'),
onChangeRawMinute: (value) => print('onChangeRawMinute $value'),
);
```### Parsing Time
Can be used [getDisplayTime](https://github.com/hukusuke1007/stop_watch_timer/blob/master/lib/stop_watch_timer.dart#L72) func. It display time like a real stopwatch timer.
- Hours
- Minute
- Second
- MillisecondFor example, 1 hours and 30 minute and 50 second and 20 millisecond => "01:30:50.20"
And can be set enable/disable display time and change split character.
[logo_black]: ./img/logo_blk.png
[never_link_light]: https://neverjp.com