开源软件名称(OpenSource Name):Ferfalk/SimpleSearchView开源软件地址(OpenSource Url):https://github.com/Ferfalk/SimpleSearchView开源编程语言(OpenSource Language):Kotlin 95.7%开源软件介绍(OpenSource Introduction):SimpleSearchViewA simple SearchView for Android based on Material Design
DownloadAdd the JitPack repository to the build.gradle file: allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
} Add the Gradle dependency: implementation 'com.github.Ferfalk:SimpleSearchView:0.2.0' UsageAdd SimpleSearchView to your AppBarLayout: <android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimary"
android:theme="@style/AppTheme.AppBarOverlay">
<FrameLayout
android:id="@+id/toolbar_container"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:popupTheme="@style/AppTheme.PopupOverlay"
app:subtitle="@string/app_subtitle"
app:title="Example" />
<com.ferfalk.simplesearchview.SimpleSearchView
android:id="@+id/searchView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/colorPrimary" />
</FrameLayout>
</android.support.design.widget.AppBarLayout> Setup with an MenuItem or Open manually Setup the listener: simpleSearchView.setOnQueryTextListener(new SimpleSearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
Log.d("SimpleSearchView", "Submit:" + query);
return false;
}
@Override
public boolean onQueryTextChange(String newText) {
Log.d("SimpleSearchView", "Text changed:" + newText);
return false;
}
@Override
public boolean onQueryTextCleared() {
Log.d("SimpleSearchView", "Text cleared");
return false;
}
}); OptionsMenuItemOpen when the MenuItem is clicked <item
android:id="@+id/action_search"
android:icon="@drawable/ic_search_black_24dp"
android:title="@string/search_hint"
app:iconTint="@android:color/white"
app:showAsAction="ifRoom" /> Setup the MenuItem : @Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.main_menu, menu);
MenuItem item = menu.findItem(R.id.action_search);
searchView.setMenuItem(item);
return true;
} TabLayoutHides the TabLayout when the SimpleSearchView opens <android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimary"
android:theme="@style/AppTheme.AppBarOverlay">
<FrameLayout
android:id="@+id/toolbar_container"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:popupTheme="@style/AppTheme.PopupOverlay"
app:subtitle="@string/app_subtitle"
app:title="Example" />
<com.ferfalk.simplesearchview.SimpleSearchView
android:id="@+id/searchView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/colorPrimary" />
</FrameLayout>
<android.support.design.widget.TabLayout
android:id="@+id/tabLayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabGravity="fill"
app:tabMode="fixed">
<android.support.design.widget.TabItem
android:id="@+id/tabItem1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/tab_text_1" />
<android.support.design.widget.TabItem
android:id="@+id/tabItem2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/tab_text_2" />
<android.support.design.widget.TabItem
android:id="@+id/tabItem3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/tab_text_3" />
</android.support.design.widget.TabLayout>
</android.support.design.widget.AppBarLayout> Setup the TabLayout: simpleSearchView.setTabLayout(findViewById(R.id.tabLayout)); Open and close manuallysimpleSearchView.showSearch();
simpleSearchView.closeSearch(); OnBackPressedCloses the SimpleSearchView automatically @Override
public void onBackPressed() {
if (searchView.onBackPressed()) {
return;
}
super.onBackPressed();
} Voice search
or simpleSearchView.enableVoiceSearch(true); Handle the result: @Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (searchView.onActivityResult(requestCode, resultCode, data)) {
return;
}
super.onActivityResult(requestCode, resultCode, data);
} StyleBar style (default):
Card style:
Open and close listenersimpleSearchView.setOnSearchViewListener(new SimpleSearchView.SearchViewListener() {
@Override
public void onSearchViewShown() {
Log.d("SimpleSearchView", "onSearchViewShown");
}
@Override
public void onSearchViewClosed() {
Log.d("SimpleSearchView", "onSearchViewClosed");
}
@Override
public void onSearchViewShownAnimation() {
Log.d("SimpleSearchView", "onSearchViewShownAnimation");
}
@Override
public void onSearchViewClosedAnimation() {
Log.d("SimpleSearchView", "onSearchViewClosedAnimation");
}
}); Changing the reveal animation starting point// Adding padding to the animation because of the hidden menu item
Point revealCenter = simpleSearchView.getRevealAnimationCenter();
revealCenter.x -= DimensUtils.convertDpToPx(EXTRA_REVEAL_CENTER_PADDING, this); Attributes<style name="SimpleSearchViewStyle">
<!-- Change search style -->
<item name="type">card</item>
<!-- Change search hint -->
<item name="android:hint">Sample</item>
<!-- Change search inputType -->
<item name="android:inputType">text</item>
<!-- Change search textColor -->
<item name="android:textColor">@color/sample</item>
<!-- Search bar/card background -->
<item name="searchBackground">@drawable/sample</item>
<!-- Change icons -->
<item name="searchBackIcon">@drawable/sample</item>
<item name="searchClearIcon">@drawable/sample</item>
<item name="searchVoiceIcon">@drawable/sample</item>
<!-- Change icons tint -->
<item name="backIconTint">1</item>
<item name="iconsTint">1</item>
<!-- Change icons alpha -->
<item name="backIconAlpha">0.8</item>
<item name="iconsAlpha">0.8</item>
<!-- Change search input colors -->
<item name="cursorColor">@color/sample</item>
<item name="hintColor">@color/sample</item>
<!-- Enable voice search -->
<item name="voiceSearch">true</item>
<!-- Set voice search prompt -->
<item name="voiceSearchPrompt">Sample</item>
</style> License
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论