![v2-4dbf2281e785a9f9325ece55e736d670_1440w.jpg?source=172ae18b](http://img-03.proxy.5ce.com/view/image?&type=2&guid=15367e57-2a30-eb11-8da9-e4434bdf6706&url=https://pic2.zhimg.com/v2-4dbf2281e785a9f9325ece55e736d670_1440w.jpg?source=172ae18b)
昨天的问题是用了ExpandableListView控件但是不显示问题,今天一检查有很多细小的问题……比如设的私有变量名字写错了,导致有问题的方法给注释了等等……不过这些都修正了还是不能加载出数据。
这里再重新提一下原来的是用在activity中的我给换到fragment里了,把对应的方法所在的生命周期也都改了还是不行。估计是有的语句只能在activity中写吧,以后有机会找一下具体哪些不能用。而且学校教的太肤浅了,今天一看当时的期末复习资料直接笑出声hhh
ExpandableListView的使用【Android】 - 书客创作www.ibooker.cc![v2-dd3140ea387d16c3ce86a385ccfde849_180x120.jpg](http://img-01.proxy.5ce.com/view/image?&type=2&guid=15367e57-2a30-eb11-8da9-e4434bdf6706&url=https://pic2.zhimg.com/v2-dd3140ea387d16c3ce86a385ccfde849_180x120.jpg)
顺便把链接贴上。
之前写到java语句各种碰壁,无奈下去搞页面设计了。现在做的差不多了,之后的页面长啥样也没想好,于是又回来研究了,这次又重新看了listview和adapter以及sql,之前在网上看的教程怎么也实现不了,今天看到期末复习资料突然想到学校书上教的没准可以,一看还真的浅显易懂。刚学的时候还嫌弃这个读起来晦涩难懂,还是自己太菜了啊。不过看教程这件事还是货比三家,大佬的教程不一定适合每个人,有时候看看别人的没准更符合自己的思维。
今天先来写一下listview是如何应用adapter来进行数据适配的,sqlite我自己还没写好,明天再写吧。
这里我们一共需要两个布局文件,一个是大的整体layout1,另一个是在这个整体layout1中要添加的view的layout2,相当于数据在mainactivity中写好适配给layout2的view,然后再显示在layout1中。
下面是整体的layout代码:
<com.example.maxcion_home.jdmall.ui.FlexiScrollView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:scrollbars="none" >
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<ListView
android:id="@+id/listView2"
android:layout_width="match_parent"
android:layout_height="400dp">
</ListView>
</RelativeLayout>
</com.example.maxcion_home.jdmall.ui.FlexiScrollView>
我这里是加了个FlexiScrollView的ui,用来实现页面上下滑动效果的,具体无视掉就好。
下面是view的layout代码:
<?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"
android:orientation="horizontal" >
<!-- 下面两个是用来给 activity_main.xml里的ListView赋值,-->
<ImageView
android:id="@+id/image_id"
android:layout_width="100dp"
android:layout_height="100dp"
/>
<TextView
android:id="@+id/text_category"
android:layout_width="200dp"
android:layout_height="100dp"
/>
</LinearLayout>
这个没什么好说的吧,id名字没那么严谨,凑活看看吧
下面是最麻烦的java文件,因为需要图片资源,所以需要在drawable目录下添加相应的图片资源:
public class Jiagongshipin extends AppCompatActivity {
private TextView mybutton;
private ListView mListView;
private String[] names = {"1","2"};
private int[] icons = {R.drawable.larou,R.drawable.luobosi};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_jiagongshipin);
mListView = (ListView) findViewById(R.id.listView5);
Jiagongshipin.MyBaseAdapter mAdapter = new Jiagongshipin.MyBaseAdapter();
mListView.setAdapter(mAdapter);
}
class MyBaseAdapter extends BaseAdapter {
@Override
public int getCount() {
return names.length;
}
@Override
public Object getItem(int position) {
return names[position];
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = View.inflate(Jiagongshipin.this, R.layout.item, null);
TextView mTextView = view.findViewById(R.id.text_category);
mTextView.setText(names[position]);
ImageView imageView =view.findViewById(R.id.image_id);
imageView.setBackgroundResource(icons[position]);
return view;
}
}
下面来说明一下:
BaseAdapter顾名思义即基本的适配器。它实际就是一个抽象类。通常在使用自定义适配器时需要继承BaseAdapter,该类拥有4个抽象方法,在Android开发中,就是根据这几个抽象方法来对ListView进行数据适配的。以下是这四个方法:
方法名称:public int getCount()
功能描述:得到item条目的总数
方法名称:public int getItem(int position)
功能描述:根据position(位置)得到某个Item的对象
方法名称:public int getItemId(int position)
功能描述:根据position(位置)得到某个Item的Id
方法名称: public View getView(int position, View convertView, ViewGroup parent)
功能描述:得到相应position对应的Item视图,position是当前Item的位置,convertView用于复用旧视图,parent用于加载XML布局
![v2-592cdc23f97be68239eec51620198717_b.jpg](http://img-03.proxy.5ce.com/view/image?&type=2&guid=15367e57-2a30-eb11-8da9-e4434bdf6706&url=https://pic4.zhimg.com/v2-592cdc23f97be68239eec51620198717_b.jpg)
上面那个标题就不要管了,我没发上来而已。