[Android Library] Object Spinner

[Android Library] Object Spinner

Android Library : Object Spinner

Github: https://github.com/ry4nkim/ObjectSpinner

API LICENSE Download

ObjectSpinner is an Android spinner library for object selection and supports searching.



Download Download

Download the latest AAR or grab via Gradle:

implementation 'kr.ry4nkim:objectspinner:1.0.1'

or Maven:

<dependency>
  <groupId>kr.ry4nkim</groupId>
  <artifactId>objectspinner</artifactId>
  <version>1.0.1</version>
  <type>pom</type>
</dependency>

Usage

Add the ObjectSpinner to your layout XML:

<kr.ry4nkim.objectspinner.ObjectSpinner
    android:id="@+id/spinner"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>

Implement ObjectSpinner.Delegate on your object to override the getSpinnerDelegate() method to return the spinner’s delegate:

public class YourObject implements ObjectSpinner.Delegate {
  private String mCode;
  private String mName;
  ...

  @Override
  public String getSpinnerDelegate() {
    return mName;
  }
  ...
}

Add item list to the spinner and listen for select:

ObjectSpinner<YourObject> mObjectSpinner = findViewById(R.id.spinner);

List<YourObject> itemList = new ArrayList<>();

itemList.add(new YourObject("obj0001", "Object 1"));
itemList.add(new YourObject("obj0002", "Object 2"));
itemList.add(new YourObject("obj0003", "Object 3"));

mObjectSpinner.setItemList(itemList);

mObjectSpinner.setOnItemSelectedListener((view, position, item) -> {
  Snackbar.make(view, "Selected Object : " + item, Snackbar.LENGTH_SHORT).show();
});

mObjectSpinner.setOnNothingSelectedListener(view -> {
  Log.i(TAG, "onNothingSelected");
});

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

name type info
os_padding dimension set the padding of the spinner
os_padding_left dimension set the left padding of the spinner
os_padding_top dimension set the top padding of the spinner
os_padding_right dimension set the right padding of the spinner
os_padding_bottom dimension set the bottom padding of the spinner
os_text_size dimension set the text size of the spinner
os_text_color color set the text color of the spinner
os_background_color color set the background color of the spinner
os_hint string set the hint of the spinner
os_hint_color color set the hint color of the spinner
os_arrow_color color set the arrow color of the spinner
os_shadow boolean set to false to hide the shadow of the spinner
os_list_max_height dimension set the max height of the spinner list
os_list_empty_text string set the empty list text of the spinner list
os_item_padding dimension set the padding of the spinner item
os_item_padding_left dimension set the left padding of the spinner item
os_item_padding_top dimension set the top padding of the spinner item
os_item_padding_right dimension set the right padding of the spinner item
os_item_padding_bottom dimension set the bottom padding of the spinner item
os_item_text_size dimension set the text size of the spinner item
os_item_text_color color set the text color of the spinner item
os_item_background_color color set the background color of the spinner item
os_selected_item_text_size dimension set the padding of the spinner selected item
os_selected_item_text_color color set the padding of the spinner selected item
os_selected_item_background_color color set the padding of the spinner selected item
os_search_text_color color set the search text color of the spinner
os_search_icon_color color set the search icon color of the spinner
os_search_background_color color set the search background color of the spinner
os_searchable boolean set to false to hide the search of the spinner

Acknowledgements

Material Spinner by Jared Rummler

License

Copyright (C) 2019 ry4nkim

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.
ry4nkim

ry4nkim

사용자 친화적인 UI/UX를 지향하는 개발자,
김진우입니다.

comments powered by Disqus
rss facebook twitter github youtube mail spotify lastfm instagram linkedin google google-plus pinterest medium vimeo stackoverflow reddit quora quora