Day15日作业 内容提供/解析者

本文详细介绍了一个使用ContentProvider和ContentResolver的完整项目案例。项目包括两个应用:一个用于存储数据到ContentProvider,另一个用于从ContentProvider检索数据并展示。文章深入讲解了如何通过ContentResolver插入、查询、更新和删除数据,以及如何在不同应用间共享数据。

第一个项目

mainActivity
package com.example.day10_provider_homework;

import android.content.ContentResolver;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;
import android.os.AsyncTask;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;

import com.example.day10_provider_homework.Task.HttpUtils;
import com.example.day10_provider_homework.Task.JavaBean;
import com.google.gson.Gson;

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

public class MainActivity extends AppCompatActivity {

    private ContentResolver contentResolver;
    private String path = "http://www.qubaobei.com/ios/cf/dish_list.php?stage_id=1&limit=20&page=1";
    static List<JavaBean.DataBean> totalList = new ArrayList<>();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        new myTask().execute(path);

    }

    public void getJson(View view) {

       // Toast.makeText(this, ""+totalList.toString(), Toast.LENGTH_SHORT).show();
        contentResolver = getContentResolver();


        Toast.makeText(this, totalList.size()+"", Toast.LENGTH_SHORT).show();
        for (int i = 0; i < totalList.size(); i++) {
            ContentValues contentValues = new ContentValues();
            contentValues.put("picid",totalList.get(i).getNum());
            contentValues.put("picurl",totalList.get(i).getPic());
            contentValues.put("title",totalList.get(i).getTitle());
            contentResolver.insert(Uri.parse("content://com.pan.sql"),contentValues);
        }

    }

    public void select(View view) {

        Cursor cursor = contentResolver.query(Uri.parse("content://com.pan.sql"), null, null, null, null, null);

        if(cursor != null){
            while(cursor.moveToNext()){
                String picurl = cursor.getString(cursor.getColumnIndex("picurl"));
                int picid = cursor.getInt(cursor.getColumnIndex("picid"));

                Toast.makeText(this, picid+"-"+picurl, Toast.LENGTH_SHORT).show();
            }

        }

    }


    //异步
    static class myTask extends AsyncTask<String ,Void, List<JavaBean.DataBean>>{


        @Override
        protected List<JavaBean.DataBean> doInBackground(String... strings) {

            String json = HttpUtils.LoadJson(strings[0]);
            if (json != null) {
                JavaBean javaBean = new Gson().fromJson(json, JavaBean.class);
                return javaBean.getData();
            }
            return null;
        }

        @Override
        protected void onPostExecute(List<JavaBean.DataBean> dataBeans) {

            if(dataBeans != null && dataBeans.size() > 0){
                totalList.addAll(dataBeans);
            }
        }
    }

}

SqlHelper 工具类
package com.example.day10_provider_homework.sql;

import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.support.annotation.Nullable;

import com.example.day10_provider_homework.Task.JavaBean;
import com.example.day10_provider_homework.Task.MyAsyncTask;

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

public class MySqlHelper extends SQLiteOpenHelper {

    private List<JavaBean.DataBean> totalList = new ArrayList<>();

    public MySqlHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        String sql = "create table user(picid integer primary key,picurl varchar(20),title varchar(20))";
        db.execSQL(sql);


    }

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

    }
}

ContentProvider 提供者
package com.example.day10_provider_homework.Provider;

import android.content.ContentProvider;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;

import com.example.day10_provider_homework.Task.JavaBean;
import com.example.day10_provider_homework.Task.MyAsyncTask;
import com.example.day10_provider_homework.sql.MySqlHelper;

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

public class MyContentProvider extends ContentProvider {

    private SQLiteDatabase db;

    public MyContentProvider() {
    }

    @Override
    public int delete(Uri uri, String selection, String[] selectionArgs) {
        return db.delete("user",selection,selectionArgs);
    }

    @Override
    public String getType(Uri uri) {

        return null;
    }

    @Override
    public Uri insert(Uri uri, ContentValues values) {
        db.insert("user",null,values);
        return uri;
    }

    @Override
    public boolean onCreate() {


        MySqlHelper test = new MySqlHelper(getContext(), "test.db", null, 1);
        db = test.getReadableDatabase();

        if(db != null){
            return true;
        }
        return false;
    }

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

        return db.query("user",projection,selection,selectionArgs,null,null,sortOrder);
    }

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

        return db.update("user",values,selection,selectionArgs);
    }
}

第二个项目/解析者

mainActivity
package com.example.app2;

import android.content.ContentResolver;
import android.database.Cursor;
import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.ListView;
import android.widget.Toast;

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

public class MainActivity extends AppCompatActivity {

    private ContentResolver contentResolver;
    private Uri uri;
    private List<JavaBean> list = new ArrayList<>();
    private ListView listView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        contentResolver = getContentResolver();
        uri = Uri.parse("content://com.pan.sql");
        listView = findViewById(R.id.list_view);
    }

    public void click(View view) {

        Cursor c = contentResolver.query(uri, null, null, null, null);

        if(c != null){
            while(c.moveToNext()){
                String picurl = c.getString(c.getColumnIndex("picurl"));
                int picid = c.getInt(c.getColumnIndex("picid"));
                String title = c.getString(c.getColumnIndex("title"));
                JavaBean javaBean = new JavaBean();
                javaBean.setNum(picid);
                javaBean.setTitle(title);
                javaBean.setPic(picurl);

                list.add(javaBean);
            }
            c.close();

            Toast.makeText(this, ""+list.toString(), Toast.LENGTH_SHORT).show();
        }
        MyAdapter adapter = new MyAdapter(list,this);
        listView.setAdapter(adapter);
    }
}

适配器Adapter
package com.example.app2;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import com.bumptech.glide.Glide;

import java.util.List;

public class MyAdapter extends BaseAdapter {

    private List<JavaBean> totalList;
    private Context context;
    private LayoutInflater layoutInflater;

    public MyAdapter(List<JavaBean> totalList, Context context) {
        this.totalList = totalList;
        this.context = context;
        layoutInflater = LayoutInflater.from(context);
    }

    @Override
    public int getCount() {
        return totalList.size();
    }

    @Override
    public Object getItem(int position) {
        return totalList.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder holder = null;

        if(convertView == null){
            holder = new ViewHolder();
            convertView = layoutInflater.inflate(R.layout.layout_list_item,null);

            holder.textView_title = convertView.findViewById(R.id.text_title);
            holder.textView_num = convertView.findViewById(R.id.text_num);
            holder.imageView_pic = convertView.findViewById(R.id.image_pic);

            convertView.setTag(holder);
        }else{
            holder = (ViewHolder) convertView.getTag();
        }

        holder.textView_num.setText(String.valueOf(totalList.get(position).getNum()));
        holder.textView_title.setText(totalList.get(position).getTitle());
        Glide.with(context).load(totalList.get(position).getPic()).into(holder.imageView_pic);
        return convertView;
    }

    static class ViewHolder{
        TextView textView_title;
        TextView textView_num;
        ImageView imageView_pic;
    }

}

MATLAB主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性内容概要:本文主要介绍了一种在MATLAB环境下实现的主动噪声和振动控制算法,该算法针对较大的次级路径变化具有较强的鲁棒性。文中详细阐述了算法的设计原理与实现方法,重点解决了传统控制系统中因次级路径动态变化导致性能下降的问题。通过引入自适应机制和鲁棒控制策略,提升了系统在复杂环境下的稳定性和控制精度,适用于需要高精度噪声与振动抑制的实际工程场景。此外,文档还列举了多个MATLAB仿真实例及相关科研技术服务内容,涵盖信号处理、智能优化、机器学习等多个交叉领域。; 适合人群:具备一定MATLAB编程基础和控制系统理论知识的科研人员及工程技术人员,尤其适合从事噪声与振动控制、信号处理、自动化等相关领域的研究生和工程师。; 使用场景及目标:①应用于汽车、航空航天、精密仪器等对噪声和振动敏感的工业领域;②用于提升现有主动控制系统对参数变化的适应能力;③为相关科研项目提供算法验证与仿真平台支持; 阅读建议:建议读者结合提供的MATLAB代码进行仿真实验,深入理解算法在不同次级路径条件下的响应特性,并可通过调整控制参数进一步探究其鲁棒性边界。同时可参考文档中列出的相关技术案例拓展应用场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值