记录ToolBar的定制:
SettingsIntelligence搜索模块:
要求:
1.搜索框右上角弹框在下方显示
2.修改menu的背景色
3.修改searchView与返回键之间的间距
2024.10.24更新
4.修改menu菜单textview的颜色
2025.0819更新
5.
定义style:
<style name="OverflowMenuStyle" parent="Widget.AppCompat.Light.PopupMenu.Overflow">
<item name="android:overlapAnchor">false</item> <!--设置menu在...的下方-->
<item name="android:popupBackground">@drawable/actionbar_menu_bg</item><!--设置menu的背景-->
<!--<item name="android:dropDownHorizontalOffset">-12dp</item>-->
</style>
在当前Activity也就是SearchActivity的配置文件中设置主题:
<activity
android:name=".search.SearchActivity"
android:exported="true"
android:theme="@style/Theme.Settings.NoActionBar"
android:windowSoftInputMode="adjustResize">
<intent-filter priority="-1">
<action android:name="com.android.settings.action.SETTINGS_SEARCH" />
<action android:name="android.settings.APP_SEARCH_SETTINGS" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
定义主题:
<style name="Theme.Settings.NoActionBar">
<item name="android:windowActionBar">false</item>
<item name="android:windowNoTitle">true</item>
<item name="android:windowSoftInputMode">adjustPan</item>
<item name="android:actionOverflowMenuStyle">@style/OverflowMenuStyle</item>
</style>
添加如下属性:
<item name="android:actionOverflowMenuStyle">@style/OverflowMenuStyle</item>
3.修改searchView与返回键之间的间距,在代码中实现:
mSearchView = toolbar.findViewById(R.id.search_view);
//消除searchview与返回键之间的间距
//查看系统组件SearchView的布局文件search_view,该文件在frame/base/core/res/res/layout中定义的,即可知道该容器设置了左右边距各为8dp,拿到该容器动态把它的margin设置为0
LinearLayout ll = mSearchView.findViewById(android.R.id.search_edit_frame);
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,ViewGroup.LayoutParams.MATCH_PARENT);
params.setMargins(0,0,0,0);
ll.setLayoutParams(params);
附系统资源search_view的xml布局:
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/an

最低0.47元/天 解锁文章
203

被折叠的 条评论
为什么被折叠?



