如何将imageView放在工具栏的最左侧?

时间:2016-03-27 11:39:56

标签: android xml android-layout

我正在尝试将我的ImageView内容放在工具栏的最左侧。我怎么能这样做?我试过以下代码: 这是我的工具栏:

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimary"
android:elevation="4dp"
>

<ImageView
    android:layout_width="50dp"
    android:layout_height="50dp"
    android:text="Departure"
    android:src="@drawable/abc"
    android:scaleType="fitCenter"
    android:layout_gravity="left"
    android:id="@+id/toolbar_image"
    />
    </android.support.v7.widget.Toolbar>

这是我的activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:tools="http://schemas.android.com/tools"
android:orientation="vertical"
tools:context=".MainActivity">

<include
    android:id="@+id/tool_bar"
    layout="@layout/toolbar"

    ></include>

<ListView
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:id="@+id/listview">

</ListView>
</LinearLayout>

这是我的menu.xml

<menu
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context=".MainActivity">

<item
    android:id="@+id/action_settings"
    android:orderInCategory="100"
    android:title="refresh"
    app:showAsAction="never" />
<item
    android:id="@+id/action_search"
    android:orderInCategory="200"
    android:title="Search"
    app:showAsAction="ifRoom"
    ></item>
<item
    android:id="@+id/action_user"
    android:orderInCategory="300"
    android:title="User"

    app:showAsAction="ifRoom"></item>

</menu>

我的输出就像是这个图像位于我的应用名称的右侧 enter image description here

这是我的manifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="################">

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

</manifest>

3 个答案:

答案 0 :(得分:2)

使用此:

   <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="right"
            android:layout_marginRight="@dimen/activity_horizontal_margin"/>

必须有效。

答案 1 :(得分:0)

我相信你正在使用ToolBar.setTitle()来设置应用名称,所以先删除它..

现在像这样更改工具栏xml ..

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimary"
android:elevation="4dp"
> 

    <ImageView
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:text="Departure"
        android:src="@drawable/back2"
        android:scaleType="fitCenter"
        android:layout_gravity="left"
        android:id="@+id/toolbar_image"
        />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLargePopupMenu"
        android:text="your_title"
        android:textColor="#000000"
        android:gravity="center_horizontal"
        android:textStyle="bold"
        android:id="@+id/page_title"
        />
</android.support.v7.widget.Toolbar>

执行此操作时,您将在工具栏中手动设置标题,并使用textview,图像将自动显示在工具栏的大部分左侧

这不是一种有效的方法,但它可以解决......

答案 2 :(得分:0)

这对我有用:

    public class MainActivity extends AppCompatActivity {

    private Toolbar toolbar;           

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        toolbar = (Toolbar) findViewById(R.id.tool_bar);
        setSupportActionBar(toolbar);
        getSupportActionBar().setDisplayShowTitleEnabled(false);/* Just put this line after setting your Action Bar*/
}