Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/flutter-studio/rebound

A Flutter library that models spring dynamics and adds real world physics to your app.
https://github.com/flutter-studio/rebound

animation flutter rebound spring

Last synced: about 22 hours ago
JSON representation

A Flutter library that models spring dynamics and adds real world physics to your app.

Awesome Lists containing this project

README

        

English | [简体中文](./README_zh-CN.md)

# Flutter Rebound

[![pub package](https://img.shields.io/pub/v/flutter_rebound.svg)](https://pub.dartlang.org/packages/flutter_rebound)

A Flutter library that models spring dynamics and adds real world physics to your app. inspired by Facebook [Rebound](https://github.com/facebook/rebound)


图片名称


## Usage
To use this plugin, add `flutter_rebound` as a [dependency in your pubspec.yaml file](https://flutter.io/platform-plugins/).

## Example

``` dart
// Import package
import 'package:flutter_rebound/flutter_rebound.dart';
import 'package:flutter/material.dart';
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);

final String title;

@override
_MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State with TickerProviderStateMixin {
SpringSystem system;
Spring spring;
double _scale = 1;

@override
void initState() {
super.initState();
system = SpringSystem(vsync: this);
spring = system.createSpring(40, 3);
spring.addUpdateListener((spring) {
double value = spring.currentValue;
_scale = 1 - value * 0.5;
setState(() {});
});
spring.endValue = 1;
}

@override
void dispose() {
system.dispose();
super.dispose();
}

@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: Center(
child: Transform.scale(
scale: _scale,
child: Container(
width: 200,
height: 200,
color: Colors.red,
),
),
),
);
}
}
```