mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
Bumps the Dart version to 3.8 across the repo (excluding engine/src/flutter/third_party) and applies formatting updates from Dart 3.8. ## Pre-launch Checklist - [x] I read the [Contributor Guide] and followed the process outlined there for submitting PRs. - [x] I read the [Tree Hygiene] wiki page, which explains my responsibilities. - [x] I read and followed the [Flutter Style Guide], including [Features we expect every widget to implement]. - [x] I signed the [CLA]. - [ ] I listed at least one issue that this PR fixes in the description above. - [ ] I updated/added relevant documentation (doc comments with `///`). - [x] I added new tests to check the change I am making, or this PR is [test-exempt]. - [x] I followed the [breaking change policy] and added [Data Driven Fixes] where supported. - [x] All existing and new tests are passing. If you need help, consider asking for advice on the #hackers-new channel on [Discord]. <!-- Links --> [Contributor Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#overview [Tree Hygiene]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md [test-exempt]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#tests [Flutter Style Guide]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md [Features we expect every widget to implement]: https://github.com/flutter/flutter/blob/main/docs/contributing/Style-guide-for-Flutter-repo.md#features-we-expect-every-widget-to-implement [CLA]: https://cla.developers.google.com/ [flutter/tests]: https://github.com/flutter/tests [breaking change policy]: https://github.com/flutter/flutter/blob/main/docs/contributing/Tree-hygiene.md#handling-breaking-changes [Discord]: https://github.com/flutter/flutter/blob/main/docs/contributing/Chat.md [Data Driven Fixes]: https://github.com/flutter/flutter/blob/main/docs/contributing/Data-driven-Fixes.md
93 lines
2.1 KiB
Dart
93 lines
2.1 KiB
Dart
// Copyright 2014 The Flutter Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
import 'dart:typed_data';
|
|
import 'dart:ui';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
class DrawPointsPage extends StatefulWidget {
|
|
const DrawPointsPage({super.key});
|
|
|
|
@override
|
|
State<DrawPointsPage> createState() => _DrawPointsPageState();
|
|
}
|
|
|
|
class _DrawPointsPageState extends State<DrawPointsPage> with SingleTickerProviderStateMixin {
|
|
late final AnimationController controller;
|
|
double tick = 0.0;
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
controller = AnimationController(vsync: this, duration: const Duration(hours: 1));
|
|
controller.addListener(() {
|
|
setState(() {
|
|
tick += 1;
|
|
});
|
|
});
|
|
controller.forward(from: 0);
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
controller.dispose();
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return CustomPaint(
|
|
size: const Size(500, 500),
|
|
painter: PointsPainter(tick),
|
|
child: Container(),
|
|
);
|
|
}
|
|
}
|
|
|
|
class PointsPainter extends CustomPainter {
|
|
PointsPainter(this.tick);
|
|
|
|
final double tick;
|
|
|
|
final Float32List data = Float32List(8000);
|
|
|
|
static const List<Color> kColors = <Color>[
|
|
Colors.red,
|
|
Colors.blue,
|
|
Colors.green,
|
|
Colors.yellow,
|
|
Colors.orange,
|
|
Colors.purple,
|
|
Colors.pink,
|
|
Colors.deepPurple,
|
|
];
|
|
|
|
@override
|
|
void paint(Canvas canvas, Size size) {
|
|
if (size.width == 0) {
|
|
return;
|
|
}
|
|
canvas.drawPaint(Paint()..color = Colors.white);
|
|
for (int i = 0; i < 8; i++) {
|
|
final double x = ((size.width / (i + 1)) + tick) % size.width;
|
|
for (int j = 0; j < data.length; j += 2) {
|
|
data[j] = x;
|
|
data[j + 1] = (size.height / (j + 1)) + 200;
|
|
}
|
|
final Paint paint = Paint()
|
|
..color = kColors[i]
|
|
..strokeWidth = 5
|
|
..strokeCap = StrokeCap.round
|
|
..style = PaintingStyle.stroke;
|
|
canvas.drawRawPoints(PointMode.points, data, paint);
|
|
}
|
|
}
|
|
|
|
@override
|
|
bool shouldRepaint(covariant CustomPainter oldDelegate) {
|
|
return true;
|
|
}
|
|
}
|