A Library for Remote Debugging, Autogenerating Settings/Preference UIs, and Wizard-of-Ozing by odbol
Sick of tweaking one value in your animation and having to wait minutes to compile and see your change? Ever want to hand someone a prototype, and let them try it with various options you can adjust on the fly? Do you get tingles when someone mentions "one-line solution"? Then Tweakr might be right for you!
Tweakr is an Android library that lets you annotate fields and methods in your code, and then automatically generates a UI to change those elements locally or remotely. It can use Firebase and a web-based UI to alter values and change settings in your app on the fly, instantly. It can also autogenerate a Preferences UI screen using SharedPreferences local to the phone.
Literally write one line of code: just annotate the thing you want to change with @Tweak, and it will handle the rest!
- Add Jitpack to your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
- Add the Tweakr dependency to your app module's build.gradle file:
dependencies {
// Required for local SharedPreferences or Firebase
implementation 'com.github.google.tweakr:core:2.2.3'
// Optional: Include this if you want Firebase support.
implementation 'com.github.google.tweakr:firebase:2.2.3'
}
This autogenerates a PreferenceFragment settings UI with all your Tweaks so you can easily change them locally in your app via a settings screen.
- Initialize the Tweakr repo in your Application onCreate():
public class SampleApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
// Enable local Android preference screen for Tweakr.
Tweakr.setRepo(new TweakrPreferencesRepo(this));
}
}
- Annotate a field or method of your class with
@Tweak
. (It must be public).
@Tweak
public float radius = 50;
@Tweak
public void setTextShown(boolean showText) {
- Call
Tweakr.register(this)
in the class's constructor so that it will register all the annotated fields with the Tweakr repo and begin listening for changes. - Expose an Activity like the TweakrPreferencesActivity that will auto-generate a PreferenceScreen UI for your Tweaks.
- You must run the main Activity first before any of the Tweaks will show up in the Preferences UI. After that, they will persist between launches.
This allows you to remote control your Tweaks via a web UI. Requires Firebase.
- Initialize the Tweakr repo with TweakrFirebaseRepo in your Application onCreate():
public class SampleApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
// Uses the default no-auth Firebase Repo.
Tweakr.setRepo(new TweakrFirebaseRepo());
}
}
- Annotate a field or method of your class with
@Tweak
. (It must be public).
@Tweak
public float radius = 50;
@Tweak
public void setTextShown(boolean showText) {
- Call
Tweakr.register(this)
in the class's constructor so that it will register all the annotated fields with the Tweakr repo and begin listening for changes. - Use our free hosted Easyserver to tweak your parameters via a remote web UI (or use your own server).
- You must run the main Activity first before any of the Tweaks will show up in the web UI. After that, they will persist between launches and update the latest values from the server automatically.
- (Optional): you may increase the security of your app by enabling authentication.
- Set up a Firebase project: https://console.firebase.google.com/
- In the Firebase console, add a new Android app using your own package name:
e.g.
com.[your-domain].tweakr.sample
- Follow the instructions to download the "google-services.json" file.
- Copy the "google-services.json" file into your app module directory (e.g. in the sample:
android-sample/app/
). - Add the Firebase dependencies to your gradle file as directed.
- Skip confirming the connection to Firebase. We'll do that later once we update the applicationId in the Android app.
- In the Firebase console, click "Develop->Database", and scroll down to create a new "Real-Time database". (NOT a Cloud Firestore database!)
- Set up Firebase Authentication. The quickest way is to allow full public access:
// These rules give anyone, even people who are not users of your app,
// read and write access to your database
{
"rules": {
".read": true,
".write": true
}
}
Make sure your applicationId matches the one you created in the Firebase console.
Follow these directions to try the sample app:
- Open the
android-sample
project. - Open the
app/build.gradle
file and change theapplicationId
to the package name you used to set up Firebase, e.g.:com.[your-domain].tweakr.sample
- Run the app.
The easiest way to start tweaking values in your app is to use our pre-hosted web UI. If you'd rather set up your own server, skip the next section.
Note: If you are using authentication to increase the security of your app, this method is not recommended.
- Go to https://google.github.io/tweakr/easyserver/ and follow the instructions to allow the Easyserver to access your Firebase. We never store any of your information, but keep in mind to use this you need to open your Firebase to the public so do so at your own risk.
These instructions are for hosting your own web server UI. For quick-n-dirty prototyping situations, use the Easyserver instead (see previous section).
- In the Firebase console, Click "Project Overview" and add a new Web app.
- It will provide you with some Javascript code. Copy only the object which contains your API values (after
var firebaseConfig =
). - Open
web-server/tweakr-server/src/environments/environment.ts
and replace the placeholder values with the object from step 2.
- Download and install the Angular CLI.
- If you haven't already done so, open
web-server/tweakr-server/src/environments/environment.ts
and replace the placeholder values with values you download from the Firebase console. - Open a command line to the
web-server/tweakr-server/
directory. - Run
npm install
- Run
ng serve --open
- Run the sample Android app. The Tweaks should show up in the web UI instantly and you can alter them and see them change in the app in real-time.
Tweakr's API is (hopefully) simple:
- Annotate any field or method of your object with
@Tweak
. - Call
Tweakr.register(yourObject)
on your object. It will look for all the members of that object annotated with@Tweak
and register them with the server. It will automatically unregsister them when the object is garbage collected.
- Most primitives are supported automatically. If you want to tweak custom types, either write a custom ValueType (see
ColorValueType.java
for an example), or create a method that does what you want and then annotate the method. - You may also tweak child members of an object (in case you don't have access to the object's class). See
MainActivity.introText
in the sample app for an example. - You may call
Tweakr.addListener()
to be notified when your object's values have been modified. SeeCircleView.java
in the sample for an example.
See Tweakr's class documentation for full usage info.
The default implementation is insecure and allows anyone to alter values in your Tweakr database. You can secure it by using authentication. The sample includes code demonstrating how to enable email authentication, but you could also use OAuth or other methods if you like.
- Uncomment the indicated line in SampleApplication.java
- Change the
DEFAULT_EMAIL
andDEFAULT_PASSWORD
fields in theTweakrFirebaseRepoEmailAuth.java
file to your own desired values.
- Change the
DEFAULT_EMAIL
andDEFAULT_PASSWORD
constants in theapp.component.ts
file to match the values in the Android app.
- In the Firebase console, click "Develop->Authentication", then set up email authentication with the email and password from the Android app.
- To restrict database access to authenticated users, open "Database->Real-Time Database->Rules".
- Change the Rules to something like:
{
"rules": {
".read": "auth.uid != null",
".write": "auth.uid != null"
}
}
- Note that anyone can sign up using any email / password combo they like. More work is needed to truly lock down your app to outside users.
- Fix buttons to not run on initial register.
- Support explicit min/max value setting in @Tweak annotation.
- Support custom ordering of Tweaks.
- Add ability to save/load custom Tweak settings, like presets, or the ability to export / import Tweak values as a JSON file.
- Support Tweak groups
- Support multiple children in @Tweak annotation
- Support array types
- Support registering additional ValueTypeConverters
- Binary file ValueType for uploading images/audio remotely and displaying in your app
Note: This is not an officially supported Google product.