A flexibly configurable, beautifully animated, device-rotatable drop down list widget.
Minimum SDK: 17
First make sure jcenter()
is included as a repository in your project's build.gradle:
allprojects {
repositories {
jcenter()
}
}
And then add the below to your app's build.gradle:
implementation 'com.asksira.android:dropdownview:1.1.1'
implementation 'com.andkulikov:transitionseverywhere:2.1.0'
<com.asksira.dropdownview.DropDownView
android:id="@+id/dropdownview"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:placeholder_text="Please select"
app:dropdownItem_text_gravity="start"
app:dropdownItem_compound_drawable_selected="@drawable/ic_done_black_24dp"
app:filter_bar_background_color="@android:color/holo_orange_dark"
app:filter_text_color="@android:color/white"
app:arrow_drawable="@drawable/expand_arrow"
app:arrow_width="24dp"
app:dropDownItem_text_color_selected="@android:color/holo_orange_dark"
app:divider_color="@android:color/holo_orange_light"
app:dropDownItem_text_size_selected="18sp"
app:bottom_decorator_color="@android:color/holo_orange_dark"
app:bottom_decorator_height="4dp"
app:expansion_style="drawer"
app:last_item_has_divider="false"
app:arrow_align_end="false"
app:arrow_start_margin="8dp"
app:arrow_end_margin="16dp"
app:deselectable="false"/>
IMPORTANT:
The size of DropDownView
includes both the filter bar AND the drop down list, as well as the background dim.
Therefore its size is meant to be extended to the bottom of its parent.
Therefore it should be placed on top of other views, in a RelativeLayout
/ FrameLayout
/ ConstraintLayout
.
Note that the opened drop down list is scrollable, so you don't need to worry even if you have a lot of selectable items.
Attribute Name | Type | Unit | Default | Remarks |
---|---|---|---|---|
filter_height | Dimension | dp | 56dp | |
filter_text_size | Dimension | dp/sp | 18sp | |
filter_text_color | Resource ID | N/A | #212121 | |
filter_bar_background_color | Resource ID | N/A | Transparent | |
arrow_start_margin | Dimension | dp | 8dp | |
arrow_end_margin | Dimension | dp | 0dp | |
arrow_width | Dimension | dp | wrap_content | |
arrow_height | Dimension | dp | match_parent | match_parent means same as filter bar height. |
arrow_drawable | Resource ID | N/A | Default arrow | Default is a black arrow from material design |
arrow_rotate | boolean | N/A | true | The boolean stands for whether to animate. |
divider_height | Dimension | dp | 1dp | |
divider_color | Resource ID | N/A | #BDBDBD | |
dropDownItem_height | Dimension | dp | 48dp | |
dropDownItem_text_size | Dimension | dp/sp | 16sp | |
dropDownItem_text_size_selected | Dimension | dp/sp | 16sp | |
dropDownItem_text_color | Resource ID | N/A | #212121 | |
dropDownItem_text_color_selected | Resource ID | N/A | #212121 | |
dropDownItem_background_color | Resource ID | N/A | #FFFFFF | |
dropDownItem_background_color_selected | Resource ID | N/A | #FFFFFF | |
expand_dim_background | boolean | N/A | true | |
dim_background_color | Resource ID | N/A | #80000000 | |
expand_include_selected_item | boolean | N/A | true | Whether the drop down list includes the already selected item. |
placeholder_text | String | N/A | Empty | |
dropdown_typeface | Resource ID | N/A | Default system font | More information below |
dropdown_animation_duration | int | ms | 300 | |
dropdownItem_text_gravity | enum | N/A | center_horizontal | center_horizontal / start / end |
dropdownItem_compound_drawable_selected | Resource ID | N/A | null | An image that is displayed at the end of the dropdown item. |
top_decorator_height | Dimension | dp | 0 | |
top_decorator_color | Resource ID | N/A | Transparent | |
bottom_decorator_height | Dimension | dp | 0 | |
bottom_decorator_color | Resource ID | N/A | Transparent | |
expansion_style | enum | N/A | drawer | drawer / reveal |
last_item_has_divider | boolean | N/A | true | |
arrow_align_end | boolean | N/A | false | |
deselectable | boolean | N/A | false |
For the typeface (font), you must use the Official font resource published together with support library v26. i.e. the xml should be something like app:dropdown_typeface="@font/my_own_typeface"
You should
- Provide selectable items (
List<String>
) to DropDownView - Set
OnSelectionListener
to DropDownView
public class MainActivity extends AppCompatActivity {
DropDownView dropDownView;
List<String> yourFilterList;
@Override
protected void onCreate(Bundle savedInstanceState) {
//...
dropDownView = findViewById(R.id.dropdownview);
dropDownView.setDropDownListItem(yourFilterList);
dropDownView.setOnSelectionListener(new OnDropDownSelectionListener() {
@Override
public void onItemSelected(DropDownView view, int position) {
//Do something with the selected position
//If position is -1, it means nothing is selected. This should happen only if deselectable is true.
}
});
}
}
If you are using Kotlin, setOnSelectionListener
should be like this:
dropDownView.onSelectionListener = OnDropDownSelectionListener { view, position ->
//...
}
That's it!
dropDownView.expand(boolean animated);
dropDownView.collapse(boolean animated);
dropDownView.toggle(boolean animated);
/**
* Below are views that opens get method to you.
* You can get them and change whatever you like.
*/
dropDownView.getFilterContainer();
dropDownView.getFilterTextView();
dropDownView.getFilterArrow();
dropDownView.getBackgroundDimView();
/**
* Functional methods
*/
dropDownView.getSelectingPosition(); //Return -1 if nothing is selected
dropDownView.setSelectingPosition(int selectingPosition); //Select item programmtically. OnSelectionListener will be triggered as well.
/**
* View configurations
*/
dropDownView.setArrowRotate(boolean yes);
dropDownView.setExpandDimBackground(boolean yes);
dropDownView.setExpandIncludeSelectedItem(boolean yes);
dropDownView.setPlaceholderText(String placeholderText);
dropDownView.setAnimationDuration(int ms);
dropDownView.setDropDownItemTextSizeSelected(float px);
dropDownView.setDropDownBackgroundColorSelected(int colorResourceID);
dropDownView.setDropdownItemGravity(int gravity);
dropDownView.setDropdownItemCompoundDrawable(int drawableResId);
dropDownView.setTopDecoratorColor(int colorResourceID);
dropDownView.setTopDecoratorHeight(float px);
dropDownView.setBottomDecoratorColor(int colorResourceID);
dropDownView.setBottomDecoratorHeight(float px);
dropDownView.setExpansionStyle(DropDownView.REVEAL);
dropDownView.setLastItemHasDivider(false);
dropDownView.setIsDeselectable(true);
- In case you don't want to show an arrow, just set
arrow_margin_start
andarrow_width
both to 0dp.
You can extends DropDownView and override View generateDropDownItem(String itemName, int index)
to provide your implementation. It works as long as you return a View.
But be aware that you need to do the below things when you override:
- Do not call super.generateDropDownItem (Ya of coz)
- Your view should have
LayoutParams
asnew LinearLayout.LayoutParams(MATCH_PARENT, theHeightYouWishToHaveInPixel)
- You should set onClickListener by yourself. To be exact, call
setSelectingPosition(index)
in theOnClickListener
.
- Drop down list must have the same width as filter bar.
- Supports only single selection. (May consider adding multiple selection in the future releases)
- If your have a lot of drop down items and
expansion_style="drawer"
(default), items are not scrollable. Looks like this is a limitation of Android framework itself where aLinearLayout
in aScrollView
withlayout_gravity="bottom"
cannot be scollred. So I suggest you useexpansion_style="reveal"
if you have a lot of drop down items.
v1.1.1
- Removed not-working run-time view configurations
- Fixed setPlaceholderText() not having effect immediately.
v1.1.0
- New feature: Allow aligning filter arrow to the end, and therefore allowing setting an arrow_end_margin.
- New feature: Allow de-selection by clicking on an already selected item, but you need to set
deselectable
totrue
first. - Updated to AndroidX.
v1.0.3
- Exposed some more views.
v1.0.2
- Fixed Issue #3.
v1.0.1
- Converted to Kotlin.
- Solved Issue #2.
- Added Top and Bottom Decorator.
- Allow configuration of drop down items' gravity.
- Allow configuration of selected item's compound drawable.
- Allow configuration of expansion style.
- Allow configuration of last item has divider or not.
- Allow overriding
View generateDropDownItem(String itemName, int index)
to customize drop down items.
v0.9.1
First Release.
Copyright 2018 Sira Lam
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.