FastLayout

Additional

Language
Java
Version
v0.0.2-alpha37 (Jun 12, 2016)
Created
May 9, 2016
Updated
Jan 24, 2019 (Retired)
Owner
Fabian Terhorst (FabianTerhorst)
Contributors
Mike Penz (mikepenz)
Fabian Terhorst (FabianTerhorst)
Ivan Feliciano (ivanfeli)
3
Activity
Badge
Generate
Download
Source code

FastLayout

Generates a Java Object for your xml layout to reduce inflate time to zero

This projects methodcount is very low, because everything happens on compile time.

Add the dependencies

main build.gradle

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        ...
  classpath 'io.fabianterhorst:fastlayout-gradle-plugin:0.0.2-alpha37'
  ...
 }
}

app build.gradle

...
apply plugin: 'fastlayout'
...

First create your layout java class

This is needed to filter the layouts you want to compile

//this is compiling all layouts in layout folder
@Layouts(all = true, exclude = {R.layout.sample_item})
//there you can specify the layouts
//@Layouts(layouts = {"activity_main", "fragment_one"})
//@Layouts(ids = {R.layout.activity_main, R.layout.fragment_one})
//this is needed when you want to use the class fields
//@Layouts
public class AppLayouts {
}

Now use the layout inside your Activity for example

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //when you donĀ“t wanna use the cache you can also just initiate the object
        //setContentView(new ActivityMainLayout(this));
        //The cache is reusing the object to improve the performance
        ActivityMainLayout layout = LayoutCache.getInstance().getLayout(context, LayoutCache.Activity_Main_Layout);
        setContentView(layout);
    }
}

Limitations

Specify a id for every view, otherwise the id is generated and can change.