布局中上面一个子布局,中间一个listview,下面一个edittext,解决edittext点击后输入法遮盖布局的问题

最近再做一个聊天界面的时候,遇到一个问题,就是点击edittext后,输入法会把整个布局给顶上去,查了好多资料蛋都没法解决问题,最终经过询问同事才解决了这个问题,下面我就说一下解决方法。

第一步:

在res文件夹下面新建一个文件夹anim,然后在哪anim下面新建四个动画文件。分别如下:

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

    <translate
        android:duration="200"
        android:fromXDelta="100%p"
        android:toXDelta="0" />

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

    <translate
        android:duration="200"
        android:fromXDelta="0"
        android:toXDelta="-100%p" />

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

    <translate
        android:duration="200"
        android:fromXDelta="-100%p"
        android:toXDelta="0" />

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

    <translate
        android:duration="200"
        android:fromXDelta="0"
        android:toXDelta="100%p" />

</set>
第二步:在values下面的styles中新建一个styles,如下:

<style name="horizontal_slide" parent="android:style/Theme.Holo.Light.NoActionBar">
    <item name="android:windowAnimationStyle">@style/AnimFade2</item>
</style>
<style name="AnimFade2" parent="@android:style/Animation.Activity">
    <item name="android:activityOpenEnterAnimation">@anim/slide_in_from_right</item>
    <item name="android:activityOpenExitAnimation">@anim/slide_out_to_left</item>
    <item name="android:activityCloseExitAnimation">@anim/slide_out_to_right</item>
    <item name="android:activityCloseEnterAnimation">@anim/slide_in_from_left</item>
</style>
第三步:在清单文件中对应的activity中进行设置,如下:

<activity
    android:name=".activity.Add_MessageActivity"
    android:launchMode="singleTop"
    android:screenOrientation="portrait"
    android:theme="@style/horizontal_slide"
    android:windowSoftInputMode="adjustResize"/>
经过上面四步以后就大功告成了,这个问题纠结了我好几天,解决了后感觉很好。



### 回答1: 当使用ListView时,可以定义一个布局文件作为每个列表项的外观。以下是一个简单的例: 首先,创建一个名为 `list_item.xml` 的新布局文件,它将包含一个ImageView和两个TextView。布局如下: ```xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="10dp"> <ImageView android:id="@+id/item_icon" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/ic_launcher"/> <LinearLayout android:orientation="vertical" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" android:layout_marginStart="10dp"> <TextView android:id="@+id/item_title" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Item Title"/> <TextView android:id="@+id/item_description" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Item Description"/> </LinearLayout> </LinearLayout> ``` 在这个布局文件,我们定义了一个水平方向的LinearLayout,它包含一个ImageView和一个竖直方向的LinearLayout。竖直方向的LinearLayout包含两个TextView,分别用于显示标题和描述。我们还将LinearLayout的权重设置为1,这将使标题和描述填满空白区域。 接下来,将该布局文件用作ListView的每个列表项的布局。在ListView的适配器,可以通过以下方式使用该布局文件: ```java public class MyAdapter extends BaseAdapter { private List<Item> mItems; private Context mContext; public MyAdapter(Context context, List<Item> items) { mContext = context; mItems = items; } @Override public int getCount() { return mItems.size(); } @Override public Object getItem(int position) { return mItems.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = convertView; if (view == null) { LayoutInflater inflater = LayoutInflater.from(mContext); view = inflater.inflate(R.layout.list_item, parent, false); } Item item = mItems.get(position); ImageView icon = (ImageView) view.findViewById(R.id.item_icon); icon.setImageResource(item.getIcon()); TextView title = (TextView) view.findViewById(R.id.item_title); title.setText(item.getTitle()); TextView description = (TextView) view.findViewById(R.id.item_description); description.setText(item.getDescription()); return view; } } ``` 在适配器的getView()方法,我们获取要在该位置显示Item对象,然后使用该对象的数据填充视图的ImageView和TextView。如果convertView为空,则使用LayoutInflater将列表项的布局文件转换为View对象。最后,返回填充数据的视图。 ### 回答2: 当然,我可以给您提供一个Android ListView布局。 首先,在您的布局文件,您需要添加一个ListView组件。例如,您可以在XML文件添加以下代码: ```xml <ListView android:id="@+id/listview" android:layout_width="match_parent" android:layout_height="match_parent"/> ``` 接下来,在您的Activity或Fragment,您需要引用这个ListView,并为其设置适配器,以便显示数据。以下是一个简单的例: ```java ListView listView = findViewById(R.id.listview); ArrayList<String> dataList = new ArrayList<>(); // 假设您有一个String数组作为数据源 String[] data = {"Apple", "Banana", "Cherry", "Durian", "Elderberry"}; // 将数据源添加到ArrayList Collections.addAll(dataList, data); // 创建适配器,并将数据源传递给它 ArrayAdapter<String> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, dataList); // 将适配器设置给ListView listView.setAdapter(adapter); ``` 以上例,我们使用了Android提供的简单列表项布局(android.R.layout.simple_list_item_1)作为ListView的每个项的布局。 最后,在您的Activity或Fragment,您可以为ListView设置一个点击事件监听器,以响应用户对列表项的点击。例如,您可以使用以下代码: ```java listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { // 在这里处理用户点击列表项的逻辑 Toast.makeText(MainActivity.this, "You clicked " + dataList.get(position), Toast.LENGTH_SHORT).show(); } }); ``` 这个例展示了如何创建一个简单的Android ListView布局,并为其设置适配器和点击事件监听器。您可以根据自己的需求,对ListView进行更多的自定义和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值