一个列表展示

main

package com.example.zhoukao_01_mn;

import android.app.AlertDialog;

import android.app.Dialog;

import android.content.ContentResolver;

import android.content.ContentValues;

import android.content.Context;

import android.content.DialogInterface;

import android.database.Cursor;

import android.net.ConnectivityManager;

import android.net.NetworkInfo;

import android.net.Uri;

import android.os.AsyncTask;

import android.os.Bundle;

import android.support.v7.app.AppCompatActivity;

import android.util.Log;

import android.view.View;

import android.widget.AdapterView;

import android.widget.ListView;

import android.widget.Toast;

import com.example.zhoukao_01_mn.adapter.MyAdapter;

import com.example.zhoukao_01_mn.bean.MyData;

import com.google.gson.Gson;

import java.io.BufferedReader;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.net.HttpURLConnection;

import java.net.MalformedURLException;

import java.net.URL;

import java.util.ArrayList;

import java.util.Collections;

import java.util.List;

public class MainActivityextends AppCompatActivity {

private ListViewlv;

private StringmUrl="https://suggest.taobao.com/sug?code=utf-8&q=%E6%89%8B%E6%9C%BA";

private MyAdaptermyAdapter;

private ContentResolverresolver;

private Uriuri = Uri.parse("content://com.example.zhoukao_01_mn.provider.provider.MyContentprovider/user");

private List>mList =new ArrayList<>();

@Override

    protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initView();

resolver = getContentResolver();

myAdapter =new MyAdapter(MainActivity.this,mList);

lv.setAdapter(myAdapter);

if(isNetworkConnected(MainActivity.this)){

Cursor cursor =resolver.query(uri,null,null,null,null);

if(cursor.getCount()==0){

new MyToack().execute(mUrl);

}else{

Toast.makeText(MainActivity.this,"有网,已经请求过数据并且保存到了数据库",Toast.LENGTH_SHORT).show();

Cursor query =resolver.query(uri,null,null,null,null);

while (query.moveToNext()){

String string = query.getString(query.getColumnIndex("string"));

mList.add(Collections.singletonList(string));

}

myAdapter.setmList(mList);

}

}else{

Toast.makeText(MainActivity.this,"没有联网,从数据库请求数据",Toast.LENGTH_SHORT).show();

Cursor cursorw =resolver.query(uri,null,null,null,null);

if(cursorw.getCount()==0){

Toast.makeText(MainActivity.this,"数据库没有数据",Toast.LENGTH_SHORT).show();

}else {

while (cursorw.moveToNext()) {

String string = cursorw.getString(cursorw.getColumnIndex("string"));

mList.add(Collections.singletonList(string));

}

//                Log.d("zzz",mList.toString());

                myAdapter.setmList(mList);

}

}

lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {

@Override

            public void onItemClick(AdapterView parent, View view,final int position,long id) {

AlertDialog.Builder builder =new AlertDialog.Builder(MainActivity.this);

builder.setTitle("确认删除吗?");

builder.setNegativeButton("取消",new DialogInterface.OnClickListener() {

@Override

                    public void onClick(DialogInterface dialog,int which) {

}

});

builder.setPositiveButton("确认",new DialogInterface.OnClickListener() {

@Override

                    public void onClick(DialogInterface dialog,int which) {

//                        Toast.makeText(MainActivity.this,mList.get(position).toString()+"",Toast.LENGTH_SHORT).show();

                        resolver.delete(uri,"string=?",new String[]{mList.get(position).toString()});

Toast.makeText(MainActivity.this,"删除成功!",Toast.LENGTH_SHORT).show();

mList.remove(position);

myAdapter.notifyDataSetChanged();

}

});

builder.show();

}

});

}

public boolean isNetworkConnected(Context context) {

if (context !=null) {

ConnectivityManager mConnectivityManager = (ConnectivityManager) context

.getSystemService(Context.CONNECTIVITY_SERVICE);

NetworkInfo mNetworkInfo = mConnectivityManager.getActiveNetworkInfo();

if (mNetworkInfo !=null) {

return mNetworkInfo.isAvailable();

}

}

return false;

}

private void initView() {

lv = (ListView) findViewById(R.id.lv);

}

class MyToackextends AsyncTask>>{

@Override

        protected List> doInBackground(String... strings) {

try {

URL url =new URL(strings[0]);

HttpURLConnection connection = (HttpURLConnection) url.openConnection();

if(connection.getResponseCode()==200){

InputStream stream = connection.getInputStream();

Gson gson =new Gson();

MyData myData = gson.fromJson(new BufferedReader(new InputStreamReader(stream)), MyData.class);

mList=myData.getResult();

for(int i=0;i

ContentValues values =new ContentValues();

Log.d("zzz",mList.get(i).toString());

values.put("string",mList.get(i).toString());

resolver.insert(uri,values);

}

return mList;

}

}catch (Exception e) {

e.printStackTrace();

}

return null;

}

@Override

        protected void onPostExecute(List> lists) {

super.onPostExecute(lists);

myAdapter.setmList(lists);

}

}

}

内容提供者

package com.example.zhoukao_01_mn.provider;

import android.content.ContentProvider;

import android.content.ContentValues;

import android.content.Context;

import android.content.UriMatcher;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import android.net.Uri;

import com.example.zhoukao_01_mn.Helper.MyHelper;

import com.example.zhoukao_01_mn.MainActivity;

public class MyContentproviderextends ContentProvider {

private  SQLiteDatabasedb;

private static UriMatcherum =new UriMatcher(UriMatcher.NO_MATCH);

static {

um.addURI(".provider.provider.MyContentprovider","user",100);

}

@Override

    public boolean onCreate() {

MyHelper helper =new MyHelper(getContext());

db = helper.getWritableDatabase();

return false;

}

@Override

    public Cursor query( Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {

Cursor cursor =db.query("user",null,null,null,null,null,null);

return cursor;

}

@Override

    public String getType( Uri uri) {

return null;

}

@Override

    public Uri insert(Uri uri,  ContentValues values) {

db.insert("user",null,values);

return null;

}

@Override

    public int delete( Uri uri,  String selection, String[] selectionArgs) {

int i =db.delete("user", selection, selectionArgs);

return i;

}

@Override

    public int update( Uri uri,  ContentValues values,  String selection,String[] selectionArgs) {

return 0;

}

}


helper

package com.example.zhoukao_01_mn.Helper;

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteOpenHelper;

public class MyHelperextends SQLiteOpenHelper {

public MyHelper(Context context) {

super(context,"show",null,1);

}

@Override

    public void onCreate(SQLiteDatabase db) {

String sql ="create table if not exists user(string text)";

db.execSQL(sql);

}

@Override

    public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion) {

}

}

adapter

package com.example.zhoukao_01_mn.adapter;

import android.content.Context;

import android.util.Log;

import android.view.View;

import android.view.ViewGroup;

import android.widget.BaseAdapter;

import android.widget.TextView;

import com.example.zhoukao_01_mn.R;

import java.util.List;

public class MyAdapterextends BaseAdapter {

private Contextcontext;

private List>mList;

public MyAdapter(Context context, List> mList) {

this.context = context;

this.mList = mList;

}

public void setmList(List> mList){

this.mList=mList;

notifyDataSetChanged();

}

@Override

    public int getCount() {

return mList.size();

}

@Override

    public Object getItem(int position) {

return null;

}

@Override

    public long getItemId(int position) {

return 0;

}

@Override

    public View getView(int position, View convertView, ViewGroup parent) {

ViewHolder holder;

if(convertView ==null){

convertView=View.inflate(context, R.layout.list_item,null);

holder =new ViewHolder();

holder.tv=convertView.findViewById(R.id.tv);

convertView.setTag(holder);

}else{

holder = (ViewHolder) convertView.getTag();

}

holder.tv.setText(mList.get(position).toString());

return convertView;

}

class ViewHolder{

TextViewtv;

}

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容