Monday, 5 August 2019

A Flutter library for gradually painting SVG path objects on canvas

drawing_animation

A Flutter library for gradually painting SVG path objects on canvas (drawing line animation).
FROM STATIC SVG ASSETSSEE MORE EXAMPLES IN THE SHOWCASING APP.

Dynamically created from Path objects which are animated over time
more coming soon
...
The rendering library exposes a central widget called AnimatedDrawing which allows to render SVG paths (via AnimatedDrawing.svg) or Flutter Path objects (via AnimatedDrawing.paths) in a drawing like fashion.

Getting Started - AnimatedDrawing.svg

To get started with the drawing_animation package you need a valid Svg file.
Currently only simple path elements without transforms are supported (see Supported SVG specifications)
  1. Add dependency in your pubspec.yaml
dependencies:
  drawing_animation: ^0.1.1

YAML
  1. Add the SVG asset
assets:
  - assets/my_drawing.svg
YAML
  1. Use the widget
    An AnimatedDrawing widget can be initiated in two ways:
    1. Simplified - without animation controller (See Example_01)
      By default every animation repeats infinitely. For running an animation only once you can use a callback to set run to false after the first animation cycle completed (see field onFinish).
      AnimatedDrawing.svg(
        "assets/my_drawing.svg",
        run: this.run,
        duration: new Duration(seconds: 3),
        onFinish: () => setState(() {
          this.run  = false;
        }),
      )
      
      Dart
    2. Standard - with animation controller (See Example_02)
      The simplified version will be sufficient in most of the use cases. If you wish to controll the animation furthermore or you want to syncronize it with other existing animations, you might consider using an custom animation controller:
      AnimatedDrawing.svg(
        "assets/test.svg",
        controller: this.controller,
      )
      
      Dart
  2. Check out examples in the examples folder. It seems that antialising for the Paint/Canvas is switched off when using debug mode. For pretty results use flutter run --release.

Getting Started - AnimatedDrawing.paths (still experimental)

By providing Path objects directly to the widget, elements can be changed dynamically, even during the animation. The internal data structure is rebuild every time the state changes, therefore the animation performance might suffer if the amount of elements in paths is very high (see Limitations). More examples will be provided soon (for now see Example_01 and Example_04).
AnimatedDrawing.paths(
    [
    ///Path objects
    ],
    paints:[
    ///Paint objects (optional), specifies a [Paint] object for each [Path] element in `paths`.
    ],
    run: this.run,
    duration: new Duration(seconds: 3),
    onFinish: () => setState(() {
      this.run  = false;
    }),
  )
Dart
Current limitations:
As stated, for every state change of the widget, the internal data structure for the path objects is rebuilt. When the amount of provided path objects is high and a custom animationOrder is defined (which triggers a sorting operation over the data structure) it can result in lags. This becomes especially apparent when the state is rebuild at 60fps by another animation (e.g. rotating the path objects at every frame). Any suggestions on how to elegantly solve this are very welcome :-)

Option list

Here is increasingly growing list with all available parameters and their visual effect.
FIELDTYPE
 ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ 
EXAMPLE
 ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ ‍ 
lineAnimation 

Specifies in which way the path elements are drawn to the canvas. When allAtOnce selected all path segments are drawn simultaneously. oneByOne paints every path segment one after another.
LineAnimation.oneByOne
LineAnimation.allAtOnce
animationOrder 

Denotes the order in which the path elements are drawn to canvas when lineAnimation is set to LineAnimation.oneByOne. When no animationOrderis specified it defaults to the same order specified in the Svg asset or path array (PathOrder.original).
PathOrders.original
PathOrders.bottomToTop
PathOrders.decreasingLength
PathOrders.increasingLength
PathOrders.leftToRight
PathOrders.rightToLeft
PathOrders.topToBottom
animationCurve 

Easing curves are used to adjust the rate of change of an animation over time, allowing them to speed up and slow down, rather than moving at a constant rate. See Flutter docs.
Curves.linear
Curves.elasticOut
Curves.bounceInOut
Curves.decelerate
Other
onFinish 

Callback when one animation cycle is finished. By default every animation repeats infinitely.
onPaint 

Callback when a complete path is painted to the canvas. Returns with the relative index and the Path element itself.
range 

Start and stop a animation from a certain moment in time by defining a AnimationRangeobject.
scaleToViewport 

Path objects are scaled to the available viewport while maintaining the aspect ratio. Defaults to true.

Supported SVG specifications

  • Only path elements (<path d="M3m1....">) are supported for now. I'm currently considering to add flutter_svg as dependency for more complete SVG parsing.
  • Attributes
    • stroke, only Hex-Color without alpha for now
    • stroke-width
    • style, but only the both fields above
  • No transforms are supported, yet.

How can I use my own SVG files?

A lot of tools can convert existing SVG files to the supported format.
For example with Inkscape:
  1. Select all objects and ungroup till there is no group left (Ctrl+U)
  2. Convert selection to paths: Path>>Object to Path and hit save
  3. Afterwards remove transforms with svgo or the webversion svgomg.
  4. Now it should work, if not feel free to write an issue!

Examples:

  • Example_01: Set up simplfied AnimatedDrawing with AnimatedDrawing.svg and AnimatedDrawing.paths
  • Example_02: Set up AnimatedDrawing with an custom animation controller
  • Example_03: Small artistic showcasing app with vectorizied drawings of old book scans provided by the British Library
  • Example_04: Show how to create Gifs with high resolution using the debug field.

Todo

  • Better test coverage
  • Improve SVG parsing capabilities
    • Circles, rect etc.
    • Better color parsing incl. alpha for hex code and RGB(A)
    • Subsitute SVG parsing logic with an mature parsering library as flutter_svg
  • Provide a way to overwrite color/brush etc. for AnimatedDrawing.svg - maybe also over paints object?
  • Define a [PathOrder] which maintains each Path and only sorts them relative to each other
  • Improve performance AnimatedDrawing.paths, for every rebuild all provided paths have to be parsed again. Is there a way to check Path-Objects for equality like Keys for widget? Idea: implementing a proxy for Path which creates a unique hash when command evoked
  • Showcase: write "drawing_animation" in different ways + 3 cirlcles + color it and one gif and put it at the top
  • Showcase: Create fractals with L-Systems
  • AnimatedDrawing.paths:
    • Provide some kind of fixed boundingBox since Paths and the overall bounding box can dynamically change (e.g. rotating circle pulses in size)
    • Also custom viewport

GitHub

A Flutter library for gradually painting SVG path objects on canvas (drawing line animation). — Read More
Latest commit to the master branch on 7-21-2019
Download as zip

A sample app to showcase classified app using flutter

A complete music player built with flutter

music player built with flutter


Musicfy

A complete music player built with flutter.

Getting Started

This project is a starting point for a Flutter application.
A few resources to get you started if this is your first Flutter project:
  • Lab: Write your first Flutter app
  • Cookbook: Useful Flutter samples
For help getting started with Flutter, view our online documentation, which offers tutorials, samples, guidance on mobile development, and a full API reference.
Plugins used
  1. provider: ^2.0.1+1
  2. flute_music_player: ^0.0.6
  3. rxdart: ^0.22.0
  4. sliding_up_panel: ^0.3.4
  5. permission_handler: 2.1.2
  6. shared_preferences: ^0.5.3+1
  7. url_launcher: ^5.1.0
music player built with flutter

music player built with flutter

music player built with flutter


music player built with flutter


music player built with flutter

GitHub

— Read More
Latest commit to the undefined branch on unknown
Download as zip

Flutter representation of a Social App Concept i found in Uplabs


Flutter Social App Concept

Flutter representation of a Social App Concept i found on Uplabs.

Requirements

  • Any Operating System (ie. MacOS X, Linux, Windows)
  • Any IDE with Flutter SDK installed (ie. IntelliJ, Android Studio, VSCode etc)
  • A little knowledge of Dart and Flutter
  • A brain to think













Toggle theme

To toggle the theme, change the isDark variable in main.dart.
true for dark and false for light.

GitHub

Flutter representation of a Social App Concept. — Read More
Latest commit to the master branch on 7-17-2019
Download as zip

Material Style Date Picker with Bikram Sambat(Nepali) Calendar Support

Material Style Date Picker with Bikram Sambat


Nepali Date Picker

Material and Cupertino Style Date Picker with Bikram Sambat(Nepali) Calendar Support. Supports Android, iOS and Fuchsia. Available in Nepali and English Languages.
Material Style Date Picker with Bikram Sambat
Nepali Date Picker returns data in NepaliDateTime type, which is
included in nepali_utils
package.

Salient Features

  • Material DatePicker
  • Cupertino DatePicker
  • Adaptive DatePicker
  • Supports from 2000 B.S. to 2099 B.S.

Usage

Material Style Date Picker

import 'package:nepali_date_picker/nepali_date_picker.dart' as picker;

NepaliDateTime _selectedDateTime = await picker.showMaterialDatePicker(
    context: context,
    initialDate: NepaliDateTime.now(),
    firstDate: NepaliDateTime(2000),
    lastDate: NepaliDateTime(2090),
    language: _language,
    initialDatePickerMode: DatePickerMode.day,
);

print(_selectedDateTime); // 2076-02-16T00:00:00
Dart

Cupertino Style Date Picker

picker.showCupertinoDatePicker(
    context: context,
    initialDate: NepaliDateTime.now(),
    firstDate: NepaliDateTime(2000),
    lastDate: NepaliDateTime(2090),
    language: _language,
    dateOrder: _dateOrder,
    onDateChanged: (newDate) {
        print(_selectedDateTime);
    },
);
Dart

Adaptive Date Picker

Shows DatePicker based on Platform.
i.e. Cupertino DatePicker will be shown on iOS while Material on Android and Fuchsia.
NepaliDateTime _selectedDateTime = await picker.showAdaptiveDatePicker(
    context: context,
    initialDate: NepaliDateTime.now(),
    firstDate: NepaliDateTime(2000),
    lastDate: NepaliDateTime(2090),
    language: _language,
    dateOrder: _dateOrder, // for iOS only
    initialDatePickerMode: DatePickerMode.day, // for platform except iOS
);
Dart

Screenshots

Material Design (Portrait)
Material Style Date Picker with Bikram Sambat


Material Design (Landscape)

Material Style Date Picker with Bikram Sambat

Cupertino Design


GitHub

Material Style Date Picker with Bikram Sambat(Nepali) Calendar Support. Supports both Android and ios. — Read More
Latest commit to the master branch on 8-3-2019
Download as zip