在Android项目的开发中,经常会遇到一些布局,可能需要在ScrollView中嵌套ListView或、GridView来实现,当然我们都知道ScroView中嵌套ListView、GridView的坑,之前的文章 ScrollView中嵌套ListView和GridView冲突问题的解决
也给出了解决方案,但是在使用的过程总又遇到了一个新的问题,就是如果在ScrollView中嵌套ListView/GridView,并且在ListView/GridView之上还有其它的布局,这个时后进入该页面时,一开始显示的位置并不是页面的最顶端,而是中间的部分,更明确的说显示的位置是从ListView/GridView部分开始。
下面给出实例:
布局文件如下:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="20dp">
<ScrollView
android:layout_width="match_parent"
android:layout_height="wrap_content">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:gravity="center_horizontal"
>
<ImageView
android:layout_width="100dp"
android:layout_height="100dp"
android:scaleType="centerCrop"
android:src="@mipmap/ic_launcher" />
<ImageView
android:layout_width="100dp"
android:layout_height="100dp"
android:scaleType="centerCrop"
android:src="@mipmap/ic_launcher" />
<ImageView
android:layout_width="100dp"
android:layout_height="100dp"
android:scaleType="centerCrop"
android:src="@mipmap/ic_launcher" />
<com.nadao.scrollviewtest.MyListView
android:id="@+id/listview_activity_main"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
</ScrollView>
</RelativeLayout>
这里的MyListView即是为了解决ScrollView中嵌套ListView冲突而自定义的一个ListView
public class MyListView extends ListView{
public MyListView(Context context,AttributeSet attrs){
super(context,attrs);
}
public void onMeasure(int widthMeasureSpec,int heightMeasureSpec){
int expandSpec=MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE>>2,MeasureSpec.AT_MOST);
super.onMeasure(widthMeasureSpec,expandSpec);
}
}
MainActivity的代码如下:
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ArrayAdapter;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
MyListView mMyListView;
ArrayAdapter<String> mAdapter;
List<String> mDataList = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initData();
initView();
mAdapter = new ArrayAdapter<String>(this, R.layout.item_list, R.id.tv_item_list, mDataList);
mMyListView.setAdapter(mAdapter);
}
public void initView() {
mMyListView = (MyListView) findViewById(R.id.listview_activity_main);
}
public void initData() {
for (int i = 0; i < 30; i++) {
mDataList.add("item" + i);
}
}
}
运行的效果:
通过运行的效果可以看出,进入页面一开始显示的位置并不是最顶端的位置,而是中间的位置。但是正常的应该显示的是最顶端的位置。
这里给出解决方法:
在ScrollView的父布局中添加如下属性:
android:focusable="true"
android:focusableInTouchMode="true"
即如下所示:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="20dp"
android:focusable="true"
android:focusableInTouchMode="true"
>
<ScrollView
android:layout_width="match_parent"
android:layout_height="wrap_content">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:gravity="center_horizontal"
>
<ImageView
android:layout_width="100dp"
android:layout_height="100dp"
android:scaleType="centerCrop"
android:src="@mipmap/ic_launcher" />
<ImageView
android:layout_width="100dp"
android:layout_height="100dp"
android:scaleType="centerCrop"
android:src="@mipmap/ic_launcher" />
<ImageView
android:layout_width="100dp"
android:layout_height="100dp"
android:scaleType="centerCrop"
android:src="@mipmap/ic_launcher" />
<com.nadao.scrollviewtest.MyListView
android:id="@+id/listview_activity_main"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</LinearLayout>
</ScrollView>
</RelativeLayout>
运行效果如下:
此时进入页面一开始显示的位置是页面的最顶部,问题得到解决。