╔════════════════════════════════════════════════════════╗
║ Linear Layout (Center) ║
║ ╔══════════════════════════════════════════════╗ ║
║ ║ ImageView ╔══════════════╗ ║ ║
║ ║ ║ ║ (Center) ║ ║
║ ║ ║ Actual image ║ ║ ║
║ ║ ║ ║ ║ ║
║ ║ ║ (Center) ║ ║ ║
║ ║ ║ ║ ║ ║
║ ║ ╚══════════════╝ ║ ║
║ ╚══════════════════════════════════════════════╝ ║
║ ║
╚════════════════════════════════════════════════════════╝
我想这样做:
╔════════════════════════════════════════════════════════╗
║ Linear Layout (Center) ║
║ ╔══════════════════════════════════════════════╗ ║
║ ║ ImageView ║ ║ ║ ║
║ ║ ║ ║ (Center) ║ ║
║ ║ ║ Actual image ║ ║ ║
║ ║ ║ ║ ║ ║
║ ║ ║ (Top) ║ ║ ║
║ ║ ║ ║ ║ ║
║ ║ ╚══════════════╝ ║ ║
║ ╚══════════════════════════════════════════════╝ ║
║ ║
╚════════════════════════════════════════════════════════╝
请注意:imageview具有带线性布局的重心 我希望imageview中的图像具有重力顶部,我尝试设置重力:顶部,但没有任何变化。帮帮我
编辑:这是我的xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="fill_parent"
android:layout_height="fill_parent" android:background="@color/all_white">
<LinearLayout android:id="@+id/title_bar" style="@style/TitleBar">
<TextView android:layout_width="wrap_content"
android:id="@+id/tv_printweb"
android:singleLine="true"
android:ellipsize="end"
style="@style/ScreenTitleText" />
</LinearLayout>
<RelativeLayout android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_below="@+id/tv_web_filename"
android:layout_above="@+id/tv_web_page_num"
android:layout_weight="1"
android:background="@color/background">
<LinearLayout android:id="@+id/ln_web_pre"
android:layout_width="30dp"
android:layout_height="fill_parent"
android:layout_alignParentLeft="true"
android:gravity="center">
<Button android:id="@+id/btn_web_pre"
android:layout_width="40dp"
android:layout_height="120dp"
android:background="@drawable/bt_left"
/>
</LinearLayout>
<LinearLayout android:id="@+id/ln_web_zoomview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@color/all_white"
android:orientation="vertical"
android:gravity="center"
android:layout_centerInParent="true">
<ImageView android:id="@+id/web_zoomview"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@color/all_white"
android:layout_gravity="top"
/>
</LinearLayout>
<LinearLayout android:id="@+id/llCircle"
android:layout_height="fill_parent"
android:layout_width="fill_parent"
android:layout_marginRight="40dp"
android:layout_marginLeft="40dp"
android:layout_marginBottom="25dp"
android:layout_marginTop="25dp">
</LinearLayout>
<LinearLayout android:id="@+id/ln_web_next"
android:layout_width="30dp"
android:layout_height="fill_parent"
android:layout_alignParentRight="true"
android:gravity="center">
<Button android:id="@+id/btn_web_next"
android:layout_width="40dp"
android:layout_height="120dp"
android:background="@drawable/bt_right_1"
/>
</LinearLayout>
<RelativeLayout android:id="@+id/pagebar_web_top"
android:layout_width="fill_parent"
android:layout_height="30dp"
android:layout_alignParentTop="true"
android:gravity="center_vertical"
android:paddingLeft="10dip"
android:paddingRight="10dip">
<TextView android:id="@+id/tv_web_page_size"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:gravity="center"
android:text="Paper Size"
android:textColor="@color/all_black"
android:textStyle="bold"
android:background="@drawable/paper_border" />
</RelativeLayout>
<RelativeLayout android:id="@+id/web_pagebar"
android:layout_width="fill_parent"
android:layout_height="50dp"
android:layout_alignParentBottom="true"
android:gravity="left"
android:paddingLeft="10dip"
android:paddingRight="10dip">
<TextView android:id="@+id/tv_page_num"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:gravity="center"
android:text="1/1"
android:textColor="@color/all_black"
android:textStyle="bold"
android:background="@drawable/paper_border" />
<Button android:id="@+id/btn_web_orientation"
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_alignParentRight="true"
android:background="@drawable/rotate_l" />
</RelativeLayout>
</RelativeLayout>
<LinearLayout android:gravity="right|center_horizontal"
android:id="@+id/toolbar"
style="@style/FunctionBar">
<Button android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/btn_web_print"
style="@style/FunctionButton"
android:text="@string/str_print" />
</LinearLayout>
</LinearLayout>
答案 0 :(得分:84)
将XML中的scaleType
设置为fitStart
:
<ImageView
android:id="@+id/ivMap"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scaleType="fitStart" >
</ImageView>
答案 1 :(得分:6)
请查看Terel的回答,这被认为是正确答案。
根据布局中的其他内容,解决方案可能是使用另一个布局(即FrameLayout
而不是ImageView
代替ImageView
,并且具有android:layout_gravity="top"
代替实际图片,使用{{1}}。
答案 2 :(得分:5)
您可以使用ImageView.ScaleType.MATRIX
并使用ImageView.setImageMatrix()
设置图像矩阵。可以使用Matrix
方法获取Matrix.setRectToRect()
。
答案 3 :(得分:3)
您是否尝试过使用属性 android:gravity =“top” 我看到你的ImageView使用的是android:layout_gravity,也许你可以尝试使用另一个。 据我所知,“ android:layout_gravity ”属性用于设置其父级元素的重力,而“ android:gravity ”属性用于设置元素内容的重力。 (如果我错了,有人会纠正我!= P呵呵!)
答案 4 :(得分:2)
使用RelativeLayout
会不会更容易?使用android:layout_alignParentTop="true"
和android:layout_centerHorizontal="true"
,您可以达到预期的效果。