litho

A declarative framework for building efficient UIs on Android.

  • Owner: facebook/litho
  • Platform:
  • License:: Apache License 2.0
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

Litho CircleCI Bintray Join the chat at https://gitter.im/facebook/litho

Litho is a declarative framework for building efficient UIs on Android.

  • Declarative: Litho uses a declarative API to define UI components. You simply describe the layout for your UI based on a set of immutable inputs and the framework takes care of the rest.
  • Asynchronous layout: Litho can measure and layout your UI ahead of time without blocking the UI thread.
  • View flattening: Litho uses Yoga for layout and automatically reduces the number of ViewGroups that your UI contains.
  • Fine-grained recycling: Any component such as a text or image can be recycled and reused anywhere in the UI.

To get started, check out these links:

Installation

Litho can be integrated either in Gradle or Buck projects. Read our Getting Started guide for installation instructions.

Quick start

1. Initialize SoLoader in your Application class.

public class SampleApplication extends Application {
  @Override
  public void onCreate() {
    super.onCreate();
    SoLoader.init(this, false);
  }
}

2. Create and display a component in your Activity

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    final ComponentContext c = new ComponentContext(this);

    final Component component = Text.create(c)
        .text("Hello World")
        .textSizeDip(50)
        .build();

    setContentView(LithoView.create(c, component));
}

Run sample

You can find more examples in our sample app.

To build and run (on an attached device/emulator) the sample app, execute

$ buck fetch sample
$ buck install -r sample

or, if you prefer Gradle,

$ ./gradlew :sample:installDebug

Contributing

Before contributing to Litho, please first read the Code of
Conduct
that we expect
project participants to adhere to.

For pull requests, please see our CONTRIBUTING guide.

See our issues page for ideas on how to contribute or to let us know of any problems.

Please also read our Coding Style and Code of Conduct before you contribute.

Getting Help

  • Post on StackOverflow
    using the #litho tag.
  • Chat with us on Gitter.
  • Join our Facebook Group to
    stay up-to-date with announcements.
  • Please open GitHub issues only if you suspect a bug in the framework or have a
    feature request and not for general questions.

License

Litho is licensed under the Apache 2.0 License.

Main metrics

Overview
Name With Ownerfacebook/litho
Primary LanguageKotlin
Program languageJava (Language Count: 10)
Platform
License:Apache License 2.0
所有者活动
Created At2017-01-27 03:59:11
Pushed At2025-05-05 18:25:29
Last Commit At2025-05-05 11:13:57
Release Count363
Last Release Namev2025.05.05 (Posted on 2025-05-05 00:03:16)
First Release Namev0.1.0 (Posted on )
用户参与
Stargazers Count7.7k
Watchers Count182
Fork Count762
Commits Count19.1k
Has Issues Enabled
Issues Count394
Issue Open Count56
Pull Requests Count51
Pull Requests Open Count44
Pull Requests Close Count496
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private