Loading...
Loading...
Optimize the performance of your Flutter app
npx skill4agent add flutter/skills flutter-performancetraceActionTimelineSummarydebugProfileBuildsEnabled--profilebuild()setState()constStringBuffersaveLayer()OpacityClipImageFilterRepaintBoundaryimport 'package:flutter_driver/flutter_driver.dart' as driver;
import 'package:integration_test/integration_test_driver.dart';
Future<void> main() {
return integrationDriver(
responseDataCallback: (data) async {
if (data != null) {
final timeline = driver.Timeline.fromJson(
data['scrolling_timeline'] as Map<String, dynamic>,
);
final summary = driver.TimelineSummary.summarize(timeline);
await summary.writeTimelineToFile(
'scrolling_timeline',
pretty: true,
includeSummary: true,
);
}
},
);
}import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:integration_test/integration_test.dart';
import 'package:your_package/main.dart';
void main() {
final binding = IntegrationTestWidgetsFlutterBinding.ensureInitialized();
testWidgets('Performance profiling test', (tester) async {
await tester.pumpWidget(const MyApp());
final listFinder = find.byType(Scrollable);
final itemFinder = find.byKey(const ValueKey('target_item'));
await binding.traceAction(() async {
await tester.scrollUntilVisible(
itemFinder,
500.0,
scrollable: listFinder,
);
}, reportKey: 'scrolling_timeline');
});
}flutter drive --driver=test_driver/perf_driver.dart --target=integration_test/scrolling_test.dart --profile --no-ddssetStateconstconst+StringBuffer// BAD: Rebuilds entire widget tree
setState(() { _counter++; });
// GOOD: Encapsulated state
class CounterWidget extends StatefulWidget { ... }
// Inside CounterWidget:
setState(() { _counter++; });// GOOD: Efficient string building
final buffer = StringBuffer();
for (int i = 0; i < 1000; i++) {
buffer.write('Item $i');
}
final result = buffer.toString();OpacityOpacityAnimatedOpacityFadeInImageClip.antiAliasWithSaveLayerborderRadius// BAD: Expensive Opacity widget
Opacity(
opacity: 0.5,
child: Container(color: Colors.red),
)
// GOOD: Semitransparent color
Container(color: Colors.red.withOpacity(0.5))ListView.builderGridView.builderShrinkWrap: trueLayoutBuilderOverlayEntryLayoutBuilderOverlayEntrysetState// FIX: Explicit setState for Overlay/Route changes
final newLabel = await Navigator.pushNamed(context, '/bar');
setState(() {
buttonLabel = newLabel;
});main()runApp()import 'package:flutter/widgets.dart';
import 'package:flutter/rendering.dart';
void main() {
debugProfileBuildsEnabled = true;
debugProfileBuildsEnabledUserWidgets = true;
debugProfileLayoutsEnabled = true;
debugProfilePaintsEnabled = true;
runApp(const MyApp());
}--profileoperator ==WidgetconstAnimatedBuilderchildListColumnListView.buildersaveLayer()