这个主要学习是关于listview的学习。
怎样去自定义adapter,以及使用。自己创建文件,还有就是为listview的每一个子控件添加点击事件。
在整个过程中收获到的知识点如下:
一、对于数据库查找方面的知识点:
ORDER BY从句后跟要排序的列。ORDER BY 从句出现在SELECT语句的最后。
排序有升序和降序之分,ASC表示升序排序,DESC表示降序排序。如果不指明排序顺序,默认的排序顺序为升序ASC。如果要降序,必须书写DESC关键字
对于一些网上的例子:这样更容易理解:
悄悄的成长い 2020/2/6 9:18:52
1.升序排序
【训练1】 查询雇员姓名和工资,并按工资从小到大排序。
输入并执行查询:
Sql代码
SELECT ename, sal FROM emp ORDER BY sal;
悄悄的成长い 2020/2/6 9:19:03
注意:若省略ASC和DESC,则默认为ASC,即升序排序。
2.降序排序
【训练2】 查询雇员姓名和雇佣日期,并按雇佣日期排序,后雇佣的先显示。
输入并执行查询:
Sql代码
SELECT ename,hiredate FROM emp ORDER BY hiredate DESC;
悄悄的成长い 2020/2/6 9:19:17
注意: DESC表示降序排序,不能省略。
3.多列排序
可以按多列进行排序,先按第一列,然后按第二列、第三列......。
【训练3】 查询雇员信息,先按部门从小到大排序,再按雇佣时间的先后排序。
输入并执行查询:
Sql代码
SELECT ename,deptno,hiredate FROM emp ORDER BY deptno,hiredate;
悄悄的成长い 2020/2/6 9:20:04
说明:该排序是先按部门升序排序,部门相同的情况下,再按雇佣时间升序排序。
4.在排序中使用别名
如果要对计算列排序,可以为计算列指定别名,然后按别名排序。
【训练4】 按工资和工作月份的乘积排序。
输入并执行查询:
Sql代码
SELECT empno, ename, sal*Months_between(sysdate,hiredate) AS total FROM emp
ORDER BY total;
但是自己实际应用时候的写法是“mingzi asc”这两个是写在一个括号里面,中间用空格分开。
二、关于一个类继承一个接口的时候的操作:
Serializable是Java提供的序列化接口,是一个空接口,为对象提供标准的序列化与反序列化操作。使用Serializable实现序列化过程相当简单,只需要在类声明的时候指定一个标识,便可以自动的实现默认的序列化过程。
private static final long serialVersionUID = 1L;
上面已经说明让对象实现序列化,只需要让当前类实现Serializable接口,并且声明一个serialVersionUID就可以了,非常的简单方便。实际上serialVersionUID都不是必须的,没有它同样可以正常的实现序列化操作。
User类就是一个实现了Serialzable的类,它是可以被序列化和反序列化的。
public class User implements Serializable {
private static final long serialVersionUID = 1L;
private String userId;
private String userName;
}
通过Serializable实现对象的序列化过程非常的简单,无需任何操作,系统就为我们自动实现了。如何进行对象的序列化与反序列化操作也是非常的简单,只需要通过ObjectOutputStream,ObjectInputStream进行操作就可以了。
//序列化过程
public void toSerial() {
try {
User user = new User("id", "user");
ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("user.txt"));
objectOutputStream.writeObject(user);
objectOutputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
//反序列化过程
public void fromSerial(){
try {
ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("user.txt"));
User user = (User) objectInputStream.readObject();
objectInputStream.close();
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
三、关于cuosor的相关知识点
Cursor 是每行的集合。使用 moveToFirst() 定位第一行。你必须知道每一列的名称。你必须知道每一列的数据类型。Cursor 是一个随机的数据源。所有的数据都是通过下标取得。
关于 Cursor 的重要方法:
·close()——关闭游标,释放资源
·copyStringToBuffer(int columnIndex, CharArrayBuffer buffer)——在缓冲区中检索请求的列的文本,将将其存储
·getColumnCount()——返回所有列的总数
·getColumnIndex(String columnName)——返回指定列的名称,如果不存在返回-1
·getColumnIndexOrThrow(String columnName)——从零开始返回指定列名称,如果不存在将抛出IllegalArgumentException 异常。
·getColumnName(int columnIndex)——从给定的索引返回列名
·getColumnNames()——返回一个字符串数组的列名
·getCount()——返回Cursor 中的行数
·moveToFirst()——移动光标到第一行
·moveToLast()——移动光标到最后一行
·moveToNext()——移动光标到下一行
·moveToPosition(int position)——移动光标到一个绝对的位置
·moveToPrevious()——移动光标到上一行
下面是自己研究使用listview的具体实验代码:
MessageAdapter.java
package com.example.thetrueappwen; import android.content.Context; import android.graphics.Color; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ListView; import android.widget.TextView; import java.util.List; public class MessageAdapter extends BaseAdapter { private List<Message> mlist; private Context mContext; private LayoutInflater mlayoutInflater; public MessageAdapter(Context context, List<Message> list){ mContext=context; mlist=list; mlayoutInflater= LayoutInflater.from(context); } @Override public int getCount() {//返回一共有多少条记录 return mlist.size(); } @Override public Object getItem(int position) {//返回当前的item对象 return mlist.get(position); } @Override public long getItemId(int position) {//返回当前item的id return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if(convertView==null) { viewHolder=new ViewHolder(); convertView=mlayoutInflater.inflate(R.layout.list_viewlayout,null); viewHolder.kindtxt=convertView.findViewById(R.id.kindtxt); viewHolder.datatxt=convertView.findViewById(R.id.datatxt); viewHolder.jinetxt=convertView.findViewById(R.id.jinetxt); // viewHolder.eventtxt=convertView.findViewById(R.id.eventtxt); // viewHolder.choicetxt=convertView.findViewById(R.id.choicetxt); // viewHolder.timetxt=convertView.findViewById(R.id.timetxt); convertView.setTag(viewHolder); }else{ viewHolder=(ViewHolder) convertView.getTag(); } Message message=mlist.get(position); viewHolder.kindtxt.setText(message.userkind); viewHolder.datatxt.setText(message.userdata); viewHolder.jinetxt.setText(message.usermoney); viewHolder=new ViewHolder(); viewHolder.listwen=convertView.findViewById(R.id.list_view); if(message.userchoice.equals("收入")) { convertView.setBackgroundColor(Color.parseColor("#008577"));//背景色 } else { convertView.setBackgroundColor(Color.parseColor("#D81B60"));//背景色 } // viewHolder.eventtxt.setText(message.userevent); // viewHolder.timetxt.setText(message.usertime); // viewHolder.choicetxt.setText(message.userchoice); return convertView; } private static class ViewHolder{//该类中包括item文件(activity_news_list_view)中所有需要显示内容的组件 public TextView kindtxt; public TextView datatxt; public TextView jinetxt; public ListView listwen; // public TextView eventtxt; //public TextView choicetxt; // public TextView timetxt; } }
FrdFragment.java
package com.example.thetrueappwen; import android.content.Context; import android.content.Intent; import android.database.Cursor; import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.ListView; import android.widget.Toast; import androidx.annotation.Nullable; import androidx.fragment.app.Fragment; import java.util.ArrayList; import java.util.List; public class FrdFragment extends Fragment{ private DBOpenMessage dbOpenMessage; private String username; private ListView listview; private List<Message> alllistmessage = new ArrayList<Message>(); @Nullable @Override public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.tab2, container, false); dbOpenMessage=new DBOpenMessage(getActivity(),"db_wen2",null,1); listview=(ListView)view.findViewById(R.id.list_view); getMessage1(username); final MessageAdapter adapter = new MessageAdapter(getActivity(), alllistmessage); listview.setAdapter(null); listview.setAdapter(adapter); listview.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView parent, View view, int position, long id) { // Intent intent=new Intent(getActivity(),AllMessage.class); // intent.putExtra("username",username2); //startActivity(intent); Message message = (Message) parent.getItemAtPosition(position); Intent intent = new Intent(); intent.setClass(getActivity(), AllMessage.class); Bundle bundle = new Bundle(); bundle.putSerializable("message", message); intent.putExtras(bundle); startActivity(intent); } }); return view; } //碎片和活动建立关联的时候调用 @Override public void onAttach(Context context) { super.onAttach(context); username = ((AllWord) context).getTitles(); } /* private void xianshixinxi() { Cursor cursor1=dbOpenMessage.getReadableDatabase().query("db_wen2",null,"username=?",new String[]{username},null,null,null); ArrayList<Map<String,String>> resultlist=new ArrayList<Map<String,String >>(); }*/ private void getMessage1(String username) { Cursor cursor=dbOpenMessage.getAllCostData(username); if(cursor!=null){ while(cursor.moveToNext()){ Message message2=new Message(); message2.userkind=cursor.getString(cursor.getColumnIndex("userkind")); message2.usermoney=cursor.getString(cursor.getColumnIndex("usermoney")); message2.userdata=cursor.getString(cursor.getColumnIndex("userdata")); message2.userevent=cursor.getString(cursor.getColumnIndex("userevent")); message2.userchoice=cursor.getString(cursor.getColumnIndex("userchoice")); message2.usertime=cursor.getString(cursor.getColumnIndex("usertime")); alllistmessage.add(message2); } } } }
AllMessage.java
package com.example.thetrueappwen;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.widget.EditText;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
public class AllMessage extends AppCompatActivity
{
private Context context;
private Intent intent;
private String username,usermoney,userkind ,userdata,usertime,userevent,userchoice;
private Message message;
private DBOpenMessage dbOpenMessage;
private EditText jine5,neirong5;
private TextView data5,time5,choice5,kind5;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.all_message);
context=this;
intent=getIntent();
username=intent.getStringExtra("username");//经检验已经成功
jine5=(EditText)findViewById(R.id.jine5);
neirong5=(EditText)findViewById(R.id.neirong5);
data5=(TextView)findViewById(R.id.data5);
time5=(TextView)findViewById(R.id.time5);
choice5=(TextView)findViewById(R.id.choice5);
kind5=(TextView)findViewById(R.id.kind5);
dbOpenMessage=new DBOpenMessage(AllMessage.this,"db_wen2",null,1);
Intent intent = this.getIntent();
message=(Message)intent.getSerializableExtra("message");
usermoney=message.getUsermoney();
jine5.setText(usermoney);
userevent=message.getUserevent();
neirong5.setText(userevent);
userdata=message.getUserdata();
data5.setText(userdata);
usertime=message.getUsertime();
time5.setText(usertime);
userchoice=message.getUserchoice();
choice5.setText(userchoice);
userkind=message.getUserkind();
kind5.setText(userkind);
}
@Override
public void onDestroy()
{
super.onDestroy();
if(dbOpenMessage!=null)
dbOpenMessage.close();
}
}
还有就是四个布局文件:
tab2.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout 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" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/qianhui" tools:context=".FrdFragment"> <TextView android:id="@+id/wenwen" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="40dp" android:text="粉红色表示支出项目" android:layout_marginTop="10dp" android:textSize="15dp" android:textColor="@color/colorAccent"/> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@+id/wenwen" android:layout_marginRight="40dp" android:layout_marginLeft="50dp" android:layout_marginTop="10dp" android:text="绿色表示收入项目"list android:textSize="15dp" android:textColor="@color/colorPrimary"/> <ListView android:layout_below="@+id/wenwen" android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/list_view"/> </RelativeLayout>
list_viewlayout.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:focusable="false" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/kindtxt" android:layout_width="90dp" android:layout_height="80dp" android:layout_marginLeft="10dp" android:layout_alignParentLeft="true" android:gravity="center" android:singleLine="true" android:textSize="35sp" android:text="userkindtext" android:focusable="false" android:ellipsize="marquee" /> <TextView android:id="@+id/datatxt" android:layout_width="150dp" android:layout_height="80dp" android:layout_toRightOf="@+id/kindtxt" android:layout_marginLeft="15dp" android:textSize="20sp" android:gravity="center" android:ellipsize="marquee" android:focusable="false" android:text="userdatatext"/> <TextView android:id="@+id/jinetxt" android:layout_width="120dp" android:layout_height="80dp" android:text="userjinetxt" android:textSize="30sp" android:layout_marginRight="10dp" android:layout_alignParentRight="true" android:singleLine="true" android:ellipsize="marquee" android:marqueeRepeatLimit="marquee_forever" android:focusable="false" android:gravity="center"/> </RelativeLayout>
allword.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <include layout="@layout/top"/> <androidx.viewpager.widget.ViewPager android:id="@+id/id_viewpager" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"> </androidx.viewpager.widget.ViewPager> <include layout="@layout/bottom"/> </LinearLayout>
all_message.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".AllMessage"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:text="对应的具体情况" android:textSize="30dp" android:gravity="center_horizontal" android:padding="5dp" android:background="@color/baise" android:layout_marginBottom="10dp" /> <LinearLayout android:id="@+id/ming" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="对应的金额:" android:padding="8dp" android:background="@color/qianhuang" android:layout_marginRight="5dp" android:textSize="18sp" /> <EditText android:id="@+id/jine5" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="请输入收入的金额" android:inputType="number" android:lines="2" android:padding="8dp" android:background="@color/baise" android:layout_marginBottom="10dp" /> </LinearLayout> <EditText android:id="@+id/neirong5" android:layout_width="match_parent" android:layout_height="wrap_content" android:hint="请输入收入的相关内容" android:lines="8" android:padding="8dp" android:background="@color/baise" android:layout_marginBottom="10dp" android:inputType="textMultiLine" android:gravity="top" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="选择日期:" android:padding="8dp" android:background="@color/baise" android:textSize="18sp" /> <TextView android:id="@+id/data5" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="8dp" android:background="@color/qianhuang" android:textSize="18sp" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:orientation="horizontal"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="选择时间:" android:padding="8dp" android:background="@color/baise" android:textSize="18sp" /> <TextView android:id="@+id/time5" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@color/qianhuang" android:padding="8dp" android:layout_marginBottom="10dp" android:textSize="18sp" /> </LinearLayout> <TextView android:id="@+id/age" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="账单类别" android:background="@color/chengse" android:layout_gravity="center_horizontal" android:layout_marginBottom="10dp" android:layout_marginTop="15dp" android:textSize="25sp" /> <TextView android:id="@+id/choice5" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@color/qianhuang" android:padding="8dp" android:layout_gravity="center_horizontal" android:text="收出" android:layout_marginBottom="10dp" android:textSize="18sp" /> <TextView android:id="@+id/kind5" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@color/qianhuang" android:padding="8dp" android:layout_gravity="center_horizontal" android:text="类型" android:layout_marginBottom="10dp" android:textSize="18sp" /> </LinearLayout>
具体的是研究过如下:
当点击其中一个账单的时候: