成语展示

新建一个db包,在其下新建一个DBOpenHelper类

package happyidiom.bztc.edu.com.happyidiom.db;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.os.Environment;
import android.util.Log;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

import happyidiom.bztc.edu.com.happyidiom.R;

/**
 * Created by Administrator on 2017/5/4.
 */

public class DBOpenHelper {
    private final int BUFFER_SIZE = 400000;
    public static final String DB_NAME = "idioms.db";
    public static final String PACKAGE_NAME = "happyidiom.bztc.edu.com.happyidiom";
    public static final String DB_PATH = "/data"
            + Environment.getDataDirectory().getAbsolutePath() +"/"
            + PACKAGE_NAME+ "/databases";

    private Context context;
    public DBOpenHelper(Context context) {
        this.context = context;
    }
    public SQLiteDatabase openDatabase() {
        try {
            File myDataPath = new File(DB_PATH);
            if (!myDataPath.exists()){
                myDataPath.mkdirs();
            }
            String dbfile=myDataPath+"/"+DB_NAME;
            if (!(new File(dbfile).exists())) {
                InputStream is = context.getResources().openRawResource(
                        R.raw.idioms);
                FileOutputStream fos =new FileOutputStream(dbfile);
                byte[] buffer = new byte[BUFFER_SIZE];
                int count = 0;
                while ((count = is.read(buffer)) > 0) {
                    fos.write(buffer, 0, count);
                }
                fos.close();
                is.close();
            }
            SQLiteDatabase db = SQLiteDatabase.openOrCreateDatabase(dbfile,
                    null);
            return db;
        } catch (FileNotFoundException e) {
           Log.e("Database", "File not found");
            e.printStackTrace();
        } catch (IOException e) {
            Log.e("Database", "IO exception");
            e.printStackTrace();
        }
        return null;
    }
}

搭建AndroidManifest.xml文件

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="happyidiom.bztc.edu.com.happyidiom">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".activity.StudyAnimalActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <uses-library android:name="android.test.runner"/>
    </application>
    <instrumentation
        android:name="android.test.InstrumentationTestRunner"
        android:targetPackage="cn.edu.bztc.happyidom"></instrumentation>

</manifest>

新建一个test包,在其下新建DBOpenHelperTest继承AndroidTestCase

package happyidiom.bztc.edu.com.happyidiom.test;

import android.test.AndroidTestCase;

import happyidiom.bztc.edu.com.happyidiom.db.DBOpenHelper;

/**
 * Created by Administrator on 2017/5/4.
 */

public class DBOpenHelperTest extends AndroidTestCase {
    public void testDBCopy(){
        DBOpenHelper dbOpenHelper=new DBOpenHelper(getContext());
        dbOpenHelper.openDatabase();
    }

}

新建一个entity包,在entity包下新建一个Animal类

package happyidiom.bztc.edu.com.happyidiom.entity;

/**
 * Created by Administrator on 2017/5/4.
 */

public class Animal {
    private int id;
    private String name;
    private String pronounce;
    private String explain;
    private String antonym;
    private String homoionym;
    private String derivation;
    private String examples;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPronounce() {
        return pronounce;
    }
    public void setPronounce(String pronounce) {
        this.pronounce = pronounce;
    }
    public String getExplain() {
        return explain;
    }
    public void setExplain(String explain) {
        this.explain = explain;
    }
    public String getAntonym() {
        return antonym;
    }
    public void setAntonym(String antonym) {
        this.antonym = antonym;
    }
    public String getHomoionym() {
        return homoionym;
    }
    public void setHomoionym(String homoionym) {
        this.homoionym = homoionym;
    }
    public String getDerivation() {
        return derivation;
    }
    public void setDerivation(String derivation) {
        this.derivation = derivation;
    }
    public String getExamples() {
        return examples;
    }
    public void setExamples(String examples) {
        this.examples = examples;
    }

}

在entity包下再创建一个AnimalDao类

package happyidiom.bztc.edu.com.happyidiom.entity;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

import java.util.ArrayList;
import java.util.List;

import happyidiom.bztc.edu.com.happyidiom.db.DBOpenHelper;

/**
 * Created by Administrator on 2017/5/5.
 */

public class AnimalDao {
    private static AnimalDao animalDao;
    private SQLiteDatabase db;

    private AnimalDao(Context context) {
        DBOpenHelper dbHelper = new DBOpenHelper(context);
        db=dbHelper.openDatabase();
    }

    public synchronized static AnimalDao getInstance(Context context) {
        if (animalDao == null) {
            animalDao= new AnimalDao(context);
        }
        return animalDao;
    }

    public List<Animal> getAllAnimals() {
        List<Animal> list = new ArrayList<>();
        Cursor cursor=db.query("animal",null,null,null,null,null,null);
        if (cursor.moveToFirst()) {
            do {
                Animal animal=new Animal();
                animal.setId(cursor.getInt(cursor.getColumnIndex("_id")));
                animal.setName(cursor.getString(cursor
                        .getColumnIndex("name")));
                animal.setPronounce(cursor.getString(cursor
                        .getColumnIndex("pronounce")));
                animal.setAntonym(cursor.getString(cursor
                        .getColumnIndex("antonym")));
                animal.setHomoionym(cursor.getString(cursor
                        .getColumnIndex("homoionym")));
                animal.setDerivation(cursor.getString
                        (cursor.getColumnIndex("derivation")));
                animal.setExamples(cursor.getString
                        (cursor.getColumnIndex("examples")));
                list.add(animal);
            } while (cursor.moveToNext());
        }
        return list;
    }

}

编写单元测试类AnimalDaoTest 继承 AndroidTestCase

package happyidiom.bztc.edu.com.happyidiom.test;

import android.test.AndroidTestCase;

import java.util.List;

import happyidiom.bztc.edu.com.happyidiom.entity.Animal;
import happyidiom.bztc.edu.com.happyidiom.entity.AnimalDao;

/**
 * Created by Administrator on 2017/5/5.
 */

public class AnimalDaoTest extends AndroidTestCase{
    public void testGetAllAnimals(){
        AnimalDao animalDao=  AnimalDao.getInstance(getContext());
        List<Animal> animals=animalDao.getAllAnimals();
        System.out.println(animals.size());
        for(Animal animal:animals){
            System.out.println(animal.getName());
        }
    }

}

在layout下新建activity_animal.xml文件,主要添加了一个ListView控件

<?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:background="@drawable/bg_animal"
    android:orientation="vertical">

    <ListView
        android:id="@+id/lvAnimalList"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layoutAnimation="@anim/anim_layout_listview"
        android:listSelector="#00000000"
        />
</LinearLayout>

在layout目录下新建animal_item.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="10dp">


    <TextView
        android:text="助人为乐"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/tvName"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:gravity="center"
        android:textAppearance="?android:attr/textAppearanceLarge" />
    <ImageButton
        android:id="@+id/btnSave"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@null"
        android:layout_alignParentRight="true"
        android:layout_alignTop="@+id/tvName"
        android:src="@drawable/btnsave"
        />
</RelativeLayout>

在res目录下新建anim目录,在下面创建anim_listview.xml文件

<?xml version="1.0" encoding="utf-8"?>
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="1000"
    android:fromAlpha="0.0"
    android:toAlpha="1.0">

</alpha>

创建anim_layout_listview.xml文件

<?xml version="1.0" encoding="utf-8"?>
<layoutAnimation xmlns:android="http://schemas.android.com/apk/res/android"
    android:animation="@anim/anim_listview"
    android:animationOrder="random"
    android:delay="0.2">

</layoutAnimation>

创建adapter包,在其下创建一个AnimalAdapter类

package happyidiom.bztc.edu.com.happyidiom.adapter;

import android.content.Context;
import android.support.annotation.NonNull;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageButton;
import android.widget.TextView;

import java.util.List;

import happyidiom.bztc.edu.com.happyidiom.R;
import happyidiom.bztc.edu.com.happyidiom.entity.Animal;

/**
 * Created by Administrator on 2017/5/4.
 */

public class AnimalAdapter extends ArrayAdapter<Animal> {
    private int resourceId;
    public AnimalAdapter(Context context, int resource, List<Animal> objects) {
        super(context, resource, objects);
        resourceId=resource;
    }

    @NonNull
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        Animal animal = getItem(position);
        View view;
        ViewHolder viewHolder;
        if (convertView == null) {
            view = LayoutInflater.from(getContext()).inflate(resourceId, null);
            viewHolder = new ViewHolder();
            viewHolder.tvName= (TextView) view
                    .findViewById(R.id.tvName);
            viewHolder.btnSave=(ImageButton) view
                    .findViewById(R.id.btnSave);
            view.setTag(viewHolder);
        } else {
            view = convertView;
            viewHolder = (ViewHolder) view.getTag();
        }
        viewHolder.tvName.setText(animal.getName());
        viewHolder.btnSave.setFocusable(false);
        viewHolder.btnSave.setFocusableInTouchMode(false);
        return view;
    }
    class ViewHolder {
        TextView tvName;
        ImageButton btnSave;

    }
}

在activity包下新建StudyAnimalActivity继承自Activity

package happyidiom.bztc.edu.com.happyidiom.activity;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;

import java.util.List;

import happyidiom.bztc.edu.com.happyidiom.R;
import happyidiom.bztc.edu.com.happyidiom.adapter.AnimalAdapter;
import happyidiom.bztc.edu.com.happyidiom.entity.Animal;
import happyidiom.bztc.edu.com.happyidiom.entity.AnimalDao;
import happyidiom.bztc.edu.com.happyidiom.unil.DialogUtil;

/**
 * Created by Administrator on 2017/5/5.
 */

public class StudyAnimalActivity extends Activity {
    private List<Animal> animalList;
    private AnimalDao animalDao;
    private ListView lvAnimalList;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_animal);
        initAnimals();
        lvAnimalList = (ListView) findViewById(R.id.lvAnimalList);
        AnimalAdapter animalAdapter = new AnimalAdapter(this,
                R.layout.animal_item, animalList);
        lvAnimalList.setAdapter(animalAdapter);
        lvAnimalList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> adapterView, View view, int position, long id) {
                Animal animal = animalList.get(position);
                String result = animal.getName() + "\n" + animal.getPronounce() + "\n【解释】:" + animal.getExplain() + "\n【近义词】:" + animal.getHomoionym() + "\n【反义词】:" + animal.getAntonym() + "\n【来源】:" + animal.getDerivation() + "\n【示例】:" + animal.getExamples();
                DialogUtil.showDialog(result, StudyAnimalActivity.this);




            }
        });
    }


    private void initAnimals() {
        animalDao = AnimalDao.getInstance(this);
       animalList=animalDao.getAllAnimals();
    }
}

在layout下新建布局文件dialog_info.xml

<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/bg_ling"
        android:orientation="vertical" >
        <TextView
            android:id="@+id/tvIdiomInfo"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="Medium Text"
            android:textAppearance="?android:attr/textAppearanceMedium" />
    </LinearLayout>


</ScrollView>

在util包下新建DialogUtil类

package happyidiom.bztc.edu.com.happyidiom.unil;

import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.TextView;

import happyidiom.bztc.edu.com.happyidiom.R;

/**
 * Created by Administrator on 2017/5/5.
 */

public class DialogUtil {
    public static void showDialog(String result,Context context) {
        AlertDialog.Builder builder = new AlertDialog.Builder(context);
       LayoutInflater layoutInflater = LayoutInflater.from(context);
       View view = layoutInflater.inflate(R.layout.dialog_info, null);
        builder.setView(view);
       TextView tvIdiomInfo = (TextView) view.findViewById(R.id.tvIdiomInfo);
        tvIdiomInfo.setText(result);
        builder.setPositiveButton("确定", new DialogInterface.OnClickListener(){
            @Override
            public void onClick(DialogInterface dialog, int which) {
                dialog.dismiss();
            }
        });
        builder.create().show();
    }


}

实验结果
这里写图片描述

这里写图片描述
实验过程遇到的问题

 Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.database.Cursor android.database.sqlite.SQLiteDatabase.query(java.lang.String, java.lang.String[], java.lang.String, java.lang.String[], java.lang.String, java.lang.String, java.lang.String)' on a null object reference
                      at happyidiom.bztc.edu.com.happyidiom.entity.AnimalDao.getAllAnimals(AnimalDao.java:34)
                      at happyidiom.bztc.edu.com.happyidiom.activity.StudyAnimalActivity.initAnimals(StudyAnimalActivity.java:52)
                      at happyidiom.bztc.edu.com.happyidiom.activity.StudyAnimalActivity.onCreate(StudyAnimalActivity.java:30)
                      at android.app.Activity.performCreate(Activity.java:6664)
                      at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118)
                      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2599)
                      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707)?
                      at android.app.ActivityThread.-wrap12(ActivityThread.java)?
                      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460)?
                      at android.os.Handler.dispatchMessage(Handler.java:102)?
                      at android.os.Looper.loop(Looper.java:154)?
                      at android.app.ActivityThread.main(ActivityThread.java:6077)?
                      at java.lang.reflect.Method.invoke(Native Method)?
                      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)?
                      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)?

出现问题的原因:DBOpenHelper中的包名路径与实际建立的包名的路径不同,所以调试不成功

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值