Skip to content

comet0704/MaterialSpinner

 
 

Repository files navigation

Material Spinner

API License


DEMO GIF

Usage

Add the spinner to your layout XML:

<com.comet0704.materialspinner.MaterialSpinner
    android:id="@+id/spinner"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>

Add items to the spinner and listen for clicks:

MaterialSpinner spinner = (MaterialSpinner) findViewById(R.id.spinner);
spinner.setItems("Ice Cream Sandwich", "Jelly Bean", "KitKat", "Lollipop", "Marshmallow");
spinner.setOnItemSelectedListener(new MaterialSpinner.OnItemSelectedListener<String>() {

  @Override public void onItemSelected(MaterialSpinner view, int position, long id, String item) {
    Snackbar.make(view, "Clicked " + item, Snackbar.LENGTH_LONG).show();
  }
});

//
// setItemsWithIcon()
//
private static final MaterialSpinner.ItemWithIcon[] LEVELS = {
      new MaterialSpinner.ItemWithIcon("Advanced", R.drawable.ic_level_advanced),
      new MaterialSpinner.ItemWithIcon("Intermediate", R.drawable.ic_level_intermediate),
};
MaterialSpinner spinerWithIcons = (MaterialSpinner) findViewById(R.id.spinnerWithIcon);
spinerWithIcons.setItemsWithIcon(LEVELS);
spinerWithIcons.setOnItemWithIconSelectedListener(new MaterialSpinner.OnItemSelectedListener<MaterialSpinner.ItemWithIcon>() {

  @Override public void onItemSelected(MaterialSpinner view, int position, long id, MaterialSpinner.ItemWithIcon item) {
    Snackbar.make(view, "Clicked " + item.text, Snackbar.LENGTH_LONG).show();
  }
});

You can add attributes to customize the view. Available attributes:

name type info
ms_arrow_tint color sets the color on the drop-down arrow
ms_hide_arrow boolean set to true to hide the arrow drawable
ms_background_color color set the background color for the spinner and drop-down
ms_background_selector integer set the background resource for the dropdown items
ms_text_color color set the text color
ms_dropdown_max_height dimension set the max height of the drop-down
ms_dropdown_height dimension set the height of the drop-down
ms_padding_top dimension set the top padding of the drop-down
ms_padding_left dimension set the left padding of the drop-down
ms_padding_bottom dimension set the bottom padding of the drop-down
ms_padding_right dimension set the right padding of the drop-down
ms_popup_padding_top dimension set the top padding of the drop-down items
ms_popup_padding_left dimension set the left padding of the drop-down items
ms_popup_padding_bottom dimension set the bottom padding of the drop-down items
ms_popup_padding_right dimension set the right padding of the drop-down items
ms_drwable_start dimension set the drawable start when using setItemsWithIcon()

Download

Download via Gradle:

allprojects {
		repositories {
			...
			maven { url 'https://jitpack.io' }
		}
}
dependencies {
        implementation 'com.github.comet0704:MaterialSpinner:1.0.0'
}

or Maven:

<repositories>
		<repository>
		    <id>jitpack.io</id>
		    <url>https://jitpack.io</url>
		</repository>
</repositories>
<dependency>
	    <groupId>com.github.comet0704</groupId>
	    <artifactId>MaterialSpinner</artifactId>
	    <version>Tag</version>
</dependency>

Acknowledgements

Nice Spinner by Angelo Marchesin

License

Copyright (C) 2016 Jared Rummler

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.

About

A spinner view for Android

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Languages

  • Java 100.0%