Files
flame/examples/lib/stories/widgets/sprite_widget_example.dart
Erick a5338d0c20 feat: Adding paint attribute to SpriteWidget and SpriteAnimationWidget (#3298)
Adds a `Paint` attribute to the `SpriteWidget` and
`SpriteAnimationWidget` for an improved API.

---------

Co-authored-by: Lukas Klingsbo <me@lukas.fyi>
2024-09-12 12:19:54 +00:00

31 lines
901 B
Dart

import 'dart:math';
import 'package:dashbook/dashbook.dart';
import 'package:examples/stories/widgets/paints.dart';
import 'package:flame/widgets.dart';
import 'package:flutter/material.dart';
final anchorOptions = Anchor.values.map((e) => e.name).toList();
Widget spriteWidgetBuilder(DashbookContext ctx) {
return Container(
width: ctx.numberProperty('container width', 400),
height: ctx.numberProperty('container height', 200),
decoration: BoxDecoration(border: Border.all(color: Colors.amber)),
child: SpriteWidget.asset(
path: 'shield.png',
angle: pi / 180 * ctx.numberProperty('angle (deg)', 0),
anchor: Anchor.valueOf(
ctx.listProperty('anchor', 'center', anchorOptions),
),
paint: paintList[paintChoices.indexOf(
ctx.listProperty(
'paint',
'none',
paintChoices,
),
)],
),
);
}