rotatable_overlay 0.0.11 copy "rotatable_overlay: ^0.0.11" to clipboard
rotatable_overlay: ^0.0.11 copied to clipboard

A flutter widget that makes its child rotatable by dragging around its center.

RotatableOverlay #

A flutter widget that makes its child rotatable by dragging around its center.

Usage #

RotatableOverlay(
    child: Container(
        height: 50,
        width: 50,
        color: Colors.green,
    ),
)
copied to clipboard

Parameters #

Parameter Description
child Child widget that will be rotatable
initialRotation Sets the initial rotation of the child
snaps A list of angles to which the rotation snaps
snapDelta Determines how close the rotation has to be to a snap angle in order to snap
shouldSnapOnEnd If true the rotation will animate to the nearest snap angle when stopped dragging
snapDuration Determines how long the animation will take if shouldSnapOnEnd is true
shouldUseRelativeSnapDuration Whether the duration of the snap animation is constant or it should be calculated based on the relative angle it has to rotate
snapCurve Determines the animation curve to the nearest snap angle
onSnap Callback that is called when the rotation snaps
onAngleChanged Callback that is called when the angle of the rotation changes
onAngleChangedPanEnd Callback that is called when the pan gesture ends
onSnapAnimationEnd Callback that is called when animation to the nearest snap angle is finished
applyInertia Whether to add inertia to the movement when stopped dragging
frictionCoefficient The friction coefficient to apply to inertia
limitDragToBounds Wether to limit drag to widget bounds (increase robustness of rotation sign determination)

Example #

rotatable_overlay_example

class App extends StatelessWidget {
  const App({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: Scaffold(
        body: SafeArea(
          child: Center(
            child: RotatableOverlay(
              snaps: [
                Angle.degrees(0),
                Angle.degrees(90),
                Angle.degrees(180),
                Angle.degrees(270),
              ],
              snapDelta: Angle.degrees(5),
              shouldSnapOnEnd: true,
              shouldUseRelativeSnapDuration: true,
              child: Stack(
                alignment: Alignment.center,
                children: [
                  Container(
                    height: 150,
                    width: 150,
                    color: Colors.green,
                  ),
                  const Positioned(
                    top: 0,
                    child: Text('N', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
                  ),
                  const Positioned(
                    right: 0,
                    child: Text('E', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
                  ),
                  const Positioned(
                    left: 0,
                    child: Text('W', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
                  ),
                  const Positioned(
                    bottom: 0,
                    child: Text('S', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
                  ),
                ],
              ),
            ),
          ),
        ),
      ),
    );
  }
}
copied to clipboard

Using inertia:

class App extends StatelessWidget {
  const App({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: Scaffold(
        body: SafeArea(
          child: Center(
            child: RotatableOverlay(
              applyInertia: true,
              child: Stack(
                alignment: Alignment.center,
                children: [
                  Container(
                    height: 150,
                    width: 150,
                    color: Colors.green,
                  ),
                  const Positioned(
                    top: 0,
                    child: Text('N', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
                  ),
                  const Positioned(
                    right: 0,
                    child: Text('E', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
                  ),
                  const Positioned(
                    left: 0,
                    child: Text('W', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
                  ),
                  const Positioned(
                    bottom: 0,
                    child: Text('S', style: TextStyle(fontSize: 18, fontWeight: FontWeight.bold)),
                  ),
                ],
              ),
            ),
          ),
        ),
      ),
    );
  }
}
copied to clipboard

Bugs & Features #

If you find any bugs or have ideas for new features, feel free to open an issue! 👋

3
likes
160
points
61
downloads

Publisher

verified publisherdaniel-riffert.com

Weekly Downloads

2024.09.19 - 2025.04.03

A flutter widget that makes its child rotatable by dragging around its center.

Repository (GitHub)

Documentation

API reference

License

BSD-3-Clause (license)

Dependencies

angle_utils, flutter

More

Packages that depend on rotatable_overlay