Skip to content

Latest commit

 

History

History
131 lines (103 loc) · 4.01 KB

README.md

File metadata and controls

131 lines (103 loc) · 4.01 KB

MaterialSettings

MaterialSettings - small library to create settings activity

Android app on Google Play

Add to project

Repo:

repositories {
	maven {
		url "https://jitpack.io"
	}
}

Dependences:

dependencies {
	compile 'com.github.kenumir:MaterialSettings:v.1.2.2'
}

###Simple code:

public class Settings1Activity extends MaterialSettings {
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		addItem(new HeaderItem(this).setTitle("Sample title 1"));
		addItem(new CheckboxItem(this, "key1").setTitle("Checkbox item 1").setSubtitle("Subtitle text 1").setOnCheckedChangeListener(new CheckboxItem.OnCheckedChangeListener() {
			@Override
			public void onCheckedChange(CheckboxItem cbi, boolean isChecked) {
				Toast.makeText(Settings1Activity.this, "CHECKED: " + isChecked, Toast.LENGTH_SHORT).show();
			}
		}));
	}
	@Override
    public StorageInterface initStorageInterface() {
    	return new PreferencesStorageInterface(this);
    }
}

Important

If in your app has layout named "activity_material_settings.xml" will occur error "NoSuchFieldError: No static field" - issue #2

Style attrs

  • msToolbarTheme
  • msToolbarThemePopup
  • msColorPrimary - primary color
  • msColorPrimaryDark - color of status bar (api 21+)
  • msColorAccent - accent color
  • msWindowBg - default window bg color
  • msColorHeader - headers text color (usually same as msColorAccent)
  • msColorTextTitle - item title color
  • msColorTextSubTitle - subtitle text color
  • msDivider - divider drawable
  • msItem - whole item color
  • msTextStyle - reference to text title style (TextView)
  • msSubTextStyle - reference to text sub title style (TextView)
  • msHeaderStyle - reference to text title style (TextView)

Same style

<style name="MaterialSettings.Red" parent="MaterialSettingsTheme">
<item name="msColorPrimary">@color/redPrimary</item>
    <item name="msColorPrimaryDark">@color/redPrimaryDark</item>
    <item name="msColorAccent">@color/redAccent</item>
    <item name="msColorHeader">@color/redAccent</item>
</style>

StorageInterface

Easiest way to save/load settings

  • PreferencesStorageInterface - in shared preferences
  • SimpleStorageInterface - in memory
  • or write own interface to save data (sqlite, content provider or to file)

Interface:

    public abstract class StorageInterface {
        public StorageInterface() {}

        public abstract void save(String key, Boolean value);
        public abstract boolean load(String key, Boolean defaultValue);

        public abstract void save(String key, String value);
        public abstract String load(String key, String defaultValue);

        public abstract void save(String key, Integer value);
        public abstract Integer load(String key, Integer defaultValue);

        public abstract void save(String key, Float value);
        public abstract Float load(String key, Float defaultValue);

        public abstract void save(String key, Long value);
        public abstract Long load(String key, Long defaultValue);

        public abstract Map<String, ?> getAll();
    }

Extend and write own methods.

Screens

Default Rec Dark

###License

Copyright 2013-2015 Michał Szwarc

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.