HistoryOfEverything

Flutter Launch Timeline Demo

  • 所有者: 2d-inc/HistoryOfEverything
  • 平台:
  • 许可证: MIT License
  • 分类:
  • 主题:
  • 喜欢:
    0
      比较:

Github星跟踪图

The History of Everything

The History of Everything is a vertical timeline that allows you to navigate, explore, and compare events from the Big Bang to the birth of the Internet. Events are beautifully illustrated and animated.

The concept for this app was inspired by the Kurzgesagt video, Time: The History & Future of Everything.

The app was built with Flutter by 2Dimensions and it's available on Android and iOS.

Usage

Make sure you have Flutter installed on your local machine. For more instructions on how to install flutter, look here.

git clone https://github.com/2d-inc/HistoryOfEverything.git
cd HistoryOfEverything/app
git submodule init
git submodule update
flutter run

Overview

The app consists of three main views:

  1. Main Menu - /app/lib/main_menu
    This is the initial view for the app when it opens up. It shows a search bar on top, three menu sections for each major time era, and three buttons on the bottom for accessing favorites, sharing a link to the store, and the about page.

  2. Timeline - /app/lib/timeline
    This view is displayed when an item from the menu is selected: the user is presented with a vertical timeline. It can be scrolled up and down, zoomed in and out.
    When an event is in view, a bubble will be shown on screen with a custom animated widget right next to it. By tapping on either, the user can access the ArticlePage.

  3. ArticlePage - /app/lib/article
    The ArticlePage displays the event animation, together with a full description of the event.

Animated Widgets

This relies heavily on the animations built on 2dimensions and they are seamlessly integrated with Flutter by using the Flare and Nima libraries.

One of Flutter's biggest strengths is its flexibility, because it exposes the architecture of its components, which can be built entirely from scratch: it's possible to create custom widgets out of the SDK's most basic elements.

An example can be found in /app/lib/article/timeline_entry_widget.dart
This file contains two classes:

  • TimelineEntryWidget that extends LeafRenderObjectWidget
  • VignetteRenderObject that extends RenderBox

LeafRenderObjectWidget

This class (docs) is a Widget: it can be inserted in any widget tree without any other default component:

Container(
  child: TimelineEntryWidget(
        isActive: true,
        timelineEntry: widget.article,
        interactOffset: _interactOffset
    )
)

This snippet is used in /app/lib/article/article_widget.dart

The LeafRenderObjectWidget is responsible for having a constructor and encapsulating the values that the RenderObject needs.

The following two overrides are also fundamental:

  • createRenderObject()
    Instantiates the actual RenderObject in the Widget Tree;
  • updateRenderObject()
    Any change to the parameters that are passed to the Widget can be reflected also on the UI, if needed. Updating a RenderObject will cause the object to redraw.

RenderObject

As specified in the docs, this is an object in the render tree, and it defines what and how its creator Widget will paint on the screen.

The key override here is paint():
    the current PaintingContext exposes the canvas, and this class can draw, taking full advantage of the exposed API.
The Flare library, granted access to the canvas, draws the animation.
To have the animation reproduce correctly, it's also necessary to call advance(elapsed) on the current FlutterActor each frame. Moreover, the current ActorAnimation requires that the function apply(time) is called on it to display it's correct interpolated values.
This is all made possible by relying on Flutter's SchedulerBinding.scheduleFrameCallback().

This is just a brief overview of how the Flare widgets can be customized for every experience.

License

All the animations in the /assets folder are distributed under the CC-BY license.

All the articles in assets/articles are from Wikipedia, and are thus distributed under the GNU Free Documentation License.

The rest of the repository's code and contents are distributed under the MIT license as specified in LICENSE.

主要指标

概览
名称与所有者2d-inc/HistoryOfEverything
主编程语言Dart
编程语言Java (语言数: 4)
平台
许可证MIT License
所有者活动
创建于2018-09-29 21:03:02
推送于2021-09-22 19:36:20
最后一次提交2019-07-26 15:30:05
发布数0
用户参与
星数6.5k
关注者数140
派生数1k
提交数226
已启用问题?
问题数91
打开的问题数50
拉请求数5
打开的拉请求数5
关闭的拉请求数3
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?