如何在Android中集中活动的操作栏标题?
我已经在这个特定主题上看到了很多关于SO的问题。每个答案都回到"使用自定义视图"并拥有自己的工具栏。
我找到了一个无需创建自定义视图的解决方案。
答案 0 :(得分:5)
在Activity
:
private void centerTitle() {
ArrayList<View> textViews = new ArrayList<>();
getWindow().getDecorView().findViewsWithText(textViews, getTitle(), View.FIND_VIEWS_WITH_TEXT);
if(textViews.size() > 0) {
AppCompatTextView appCompatTextView = null;
if(textViews.size() == 1) {
appCompatTextView = (AppCompatTextView) textViews.get(0);
} else {
for(View v : textViews) {
if(v.getParent() instanceof Toolbar) {
appCompatTextView = (AppCompatTextView) v;
break;
}
}
}
if(appCompatTextView != null) {
ViewGroup.LayoutParams params = appCompatTextView.getLayoutParams();
params.width = ViewGroup.LayoutParams.MATCH_PARENT;
appCompatTextView.setLayoutParams(params);
appCompatTextView.setTextAlignment(View.TEXT_ALIGNMENT_CENTER);
}
}
}
然后,只需在onCreate()
:
centerTitle();
那就是!!!“
答案 1 :(得分:0)
在Kotlin中,您可以执行以下操作:
private fun centerTitle() {
val textViews = ArrayList<View>()
window.decorView.findViewsWithText(textViews, title, View.FIND_VIEWS_WITH_TEXT)
if (textViews.size > 0) {
var appCompatTextView: AppCompatTextView? = null
if (textViews.size == 1)
appCompatTextView = textViews[0] as AppCompatTextView
else {
for (v in textViews) {
if (v.parent is Toolbar) {
appCompatTextView = v as AppCompatTextView
break
}
}
}
if (appCompatTextView != null) {
val params = appCompatTextView.layoutParams
params.width = ViewGroup.LayoutParams.MATCH_PARENT
appCompatTextView.layoutParams = params
appCompatTextView.textAlignment = View.TEXT_ALIGNMENT_CENTER
}
}
}
然后在您的centerTitle()
中呼叫onCreate()
答案 2 :(得分:0)
您可以使用此解决方案。但这并不会忽略工具栏中的其他元素。
fun setToolbarTextAlignment(textAlignment: Int) {
for (i in 0..toolbarView.childCount) {
(toolbarView.getChildAt(i) as? TextView)?.let {
it.layoutParams.width = ViewGroup.LayoutParams.MATCH_PARENT
it.textAlignment = textAlignment
}
}
}
答案 3 :(得分:-1)
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:popupTheme="@style/AppTheme.PopupOverlay" >
<TextView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:text="haiii"/>
</android.support.v7.widget.Toolbar>