Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/usefulness/easylauncher-gradle-plugin

Add a different ribbon to each of your Android app variants using this gradle plugin. Of course, configure it as you will
https://github.com/usefulness/easylauncher-gradle-plugin

android debug flavor icon launcher overlay ribbon

Last synced: 5 days ago
JSON representation

Add a different ribbon to each of your Android app variants using this gradle plugin. Of course, configure it as you will

Awesome Lists containing this project

README

        

# Easylauncher Gradle Plugin for Android

[![build](https://github.com/usefulness/easylauncher-gradle-plugin/actions/workflows/default.yml/badge.svg)](https://github.com/usefulness/easylauncher-gradle-plugin/actions/workflows/default.yml)
 [![ktlint](https://img.shields.io/badge/code%20style-%E2%9D%A4-FF4081.svg)](https://ktlint.github.io/)

[![version](https://img.shields.io/maven-metadata/v/https/plugins.gradle.org/m2/com/project/starter/easylauncher/maven-metadata.xml?label=gradle)](https://plugins.gradle.org/search?term=com.starter)

Modify the launcher icon of each of your app-variants using simple Gradle rules. Add ribbons of any color, overlay your own images, customize it according to your needs!

| Circle | RoundedRectangle | Teardrop |
| --- | --- | --- |
| ![](icons/launcher_circle.png) | ![](icons/launcher_rectangle.png) | ![](icons/launcher_teardrop.png) |

This library heavily relies on the original [Akaita's easylauncher](https://github.com/akaita/easylauncher-gradle-plugin) plugin, but introduces supports for modern build tools and **Vector icons**

## Usage

### Basic usage

```groovy
// in app/build.gradle
plugins {
id "com.starter.easylauncher" version "${{version}}"
}
```
see [Gradle Plugin Portal] for the details

What should I do if I get `Could not resolve all artifacts` error?

In some configurations a dependency resolution error might be thrown with a message:
> Could not find com.android.tools.build:gradle:x.x.x`.

As a solution apply the plugin to the root project using:

```groovy
// in root project's build.gradle
buildscript {
repositories.google()
}
plugins {
id "com.starter.easylauncher" version "${{version}}" apply false
}
```
then apply the plugin in your application module:
```groovy
// in app/build.gradle
plugins {
id "com.starter.easylauncher"
}
```

Alternatively, if using Version Catalog:
```toml
[plugins]
starter-easylauncher = { id = "com.starter.easylauncher", version.ref = "easylauncher" }
```

See [related issue](https://github.com/usefulness/easylauncher-gradle-plugin/issues/80) for more information.

### Advanced usage

By default, the plugin applies green ribbon for all debuggable build variants.
You can customize the filters applied to each type, flavor and variant of your app.

Imagine these are the type and flavors of your app:

```groovy
// in app/build.gradle
android {
buildTypes {
named("debug") {
//Debuggable, will get a default ribbon in the launcher icon
}
named("release") {
//Non-debuggable, will not get any default ribbon
}
register("beta") {
//Debuggable, will get a default ribbon in the launcher icon
debuggable true
}
register('canary') {
//Non-debuggable, will not get any default ribbon
debuggable false
}
}
productFlavors {
register("local") {}
register("qa") {}
register("staging") {}
register("production") {}
}
}
```

You could customize the plugin's behaviour like this:

```groovy
easylauncher {
defaultFlavorNaming = true // Use flavor name for default ribbon, instead of the type name
showWarnings = true // Defines if the plugins should show warnings at configuration time

productFlavors {
register("local") {}
register("qa") {
// Add one more filter to all `qa` variants
filters redRibbonFilter()
}
register("staging") {}
register("production") {}
}

buildTypes {
register("beta") {
// Add two more filters to all `beta` variants
filters = [
customRibbon(ribbonColor: "#0000FF"),
overlayFilter(file("example-custom/launcherOverlay/beta.png"))
]
}
register("canary") {
// Remove ALL filters to `canary` variants
enable = false
}
register("release") {}
}

variants {
register("productionDebug") {
// OVERRIDE all previous filters defined for `productionDebug` variant
filters = orangeRibbonFilter("custom")
}
}
}
```

#### Providing Icon Names
By default, the plugin **automatically** discovers launcher icon and applies provided filters.
Custom icon names, useful i.e. when defining multiple activity aliases, can be provided using `iconNames` property as follows:

```groovy
easylauncher {
iconNames = ["@mipmap/custom_launcher_icon"] // optional, disables automatic launcher icon discovery and will use provided icons only

buildTypes {
register("beta") {
// icon names can also be provided per each configuration (buildType, productFlavor or variant)
iconNames = ["@mipmap/beta_launcher"]
}
}
}
```

## Available filters

## Overlay filter

| Command | Result |
| --- | --- |
| `overlayFilter(file("example-custom/launcherOverlay/beta.png"))` | ![](icons/overlay.png) |

## Ribbon filters

| Filter | Command | Result |
| --- | --- | --- |
| Gray ribbon | `grayRibbonFilter()` | ![](icons/ribbon_grey.png) |
| Green ribbon | `greenRibbonFilter()` | ![](icons/ribbon_green.png) |
| Yellow ribbon | `yellowRibbonFilter()` | ![](icons/ribbon_yellow.png) |
| Orange ribbon | `orangeRibbonFilter()` | ![](icons/ribbon_orange.png) |
| Red ribbon | `redRibbonFilter()` | ![](icons/ribbon_red.png) |
| Blue ribbon | `blueRibbonFilter()` | ![](icons/ribbon_blue.png) |

## Advanced Ribbon filter

| Description | Command | Result |
| --- | --- | --- |
| Custom background color | `customRibbon(ribbonColor: "#6600CC")` | ![](icons/ribbon_custom_background.png) |
| Custom label | `customRibbon(label: "label", ribbonColor: "#DCDCDC")` | ![](icons/ribbon_custom_label.png) |
| Custom text color | `customRibbon(label: "label", ribbonColor: "#DCDCDC", labelColor: "#000000")` | ![](icons/ribbon_custom_textcolor.png) |
| Custom gravity - Top | `customRibbon(label: "custom", position: "top")` | ![](icons/ribbon_custom_top.png) |
| Custom gravity - Bottom | `customRibbon(position: "bottom")` | ![](icons/ribbon_custom_bottom.png) |
| Custom gravity - TopLeft | `customRibbon(position: "topLeft")` | ![](icons/ribbon_custom_topleft.png) |
| Custom gravity - TopRight | `customRibbon(position: "topRight")` | ![](icons/ribbon_custom_topright.png) |
| Custom text size (relative to the icon size) | `customRibbon(position: "bottom", textSizeRatio: 0.2)` | ![](icons/ribbon_custom_textsizeratio.png) |
| Custom font (locally installed) | `customRibbon(position: "top", font: "ComicSansMs")` | ![](icons/ribbon_custom_font.png) |
| Custom font (using font pack) | `customRibbon(position: "top", font: file("fonts/CustomFont.ttf"))` | ![](icons/ribbon_custom_font.png) |

Troubleshooting on "Problem reading font data."

When using docker or a _minimalistic_ environment one might encounter above error message when loading Fonts.
The solution is to make sure font support was installed i.e. by calling:
```
apk add --no-cache freetype fontconfig ttf-dejavu
```

See [related issue](https://github.com/usefulness/easylauncher-gradle-plugin/issues/201) for more information.

## Chrome-like filters

| Filter | Command | Result |
| --- | --- | --- |
| Default | `chromeLike()` | ![](icons/chromelike_default.png) |
| Custom appearance | `chromeLike(label: "Custom", ribbonColor: "#FF00FF", labelColor: "#FFFFFF")` | ![](icons/chromelike_custom.png) |
| Custom font (locally installed) | `chromeLike(label: "Custom", font: "ComicSansMS-Bold")` | ![](icons/chromelike_font.png) |
| Custom gravity - Top (with additional padding)| `chromeLike(label: "Top", gravity: "Top", labelPadding: 10)` | ![](icons/chromelike_top.png) |
| Custom overlay/label alignment| `chromeLike(label: "Tall", overlayHeight: 0.6, textSizeRatio: 0.3)` | ![](icons/chromelike_tall.png) |

## Available options

- `defaultFlavorNaming`: use _flavor_ name in default ribbons, instead of using _buildType_
- `enable`: enable/disable **all** filters for a flavor/type/variant
- `productFlavors`: define filters for flavors (will be **added** to filters defined for types)
- `buildTypes`: define filters for types (will be **added** to filter defined for flavors)
- `variants`: define filters for variants (will **override** any other filters)
- `iconNames`: provides a list of icons which will have the filters applied

## Requirements
Minimal requirements for the plugin are:
- Gradle: **8.2.1**
- Android Gradle Plugin: **8.2.2**
- Java Version: **11**
- minSdkVersion: **26** _(theoretically there should be no lower boundary - it just hasn't been tested)_

## Project Structure

```
easylauncher/ - source code of Gradle plugin
sample/ - root directory of supported Android applications which serve as test projects
```

## Credits
Credits to [Akaita's easylauncher plugin](https://github.com/akaita/easylauncher-gradle-plugin) which this project heavily relies on

[Gradle Plugin Portal]: https://plugins.gradle.org/plugin/com.starter.easylauncher

---

YourKit logo

YourKit supports open source projects with innovative and intelligent tools
for monitoring and profiling Java and .NET applications.
YourKit is the creator of YourKit Java Profiler,
YourKit .NET Profiler,
and YourKit YouMonitor.