移动开发作业3:resolver调用provider对表格进行数据添加

目录

目录

作业要求

本作业实现

一、请求方app:MyResolver 

(一)activity_main.xml文件配置

文件作用

控件配置

界面展示

(二)MainActivity.java文件配置

文件作用

代码如下

(三)AndroidManifest.xml文件配置

二、提供方app:MyContentProvider

(一)MyDAO.java文件配置

文件作用

代码如下

(二)MyDBhelper.java文件配置

文件作用

代码如下

(三)MyContentProvider.java文件配置

文件作用

代码如下

(四)MainActivity.java文件配置

代码如下

(五)activity_main.xml文件配置

(六)AndroidManifest.xml文件配置

代码如下

三、建立请求方与提供方联系

(一)请求方MainActivity.java文件代码补充

(二)请求方AndroidManifest.xml文件代码补充

四、运行结果

五、源码地


作业要求

1、contentprovider是安卓四大组件之一,请使用其方法类进行数据获取;

2、请自建一个provider,然后在另一个app中使用resolver调用这个provider。

3、本次作业请启用新项目,理论上需要两个APP进行实验。

本作业实现

本次作业将实现请求方MyResolver调用提供方MyContentProvider对表格进行数据添加

一、请求方app:MyResolver 

(一)activity_main.xml文件配置

文件作用

该文件显示MyResolver app界面,并提醒用户接收添加数据的操作;

控件配置

在palette中选择TextView和Button控件,将其拖入ConstraintLayout下,并在Code中修改相应代码(代码如下)

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="这是resolver"
        android:textSize="35sp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button"
        android:layout_width="157dp"
        android:layout_height="74dp"
        android:text="接收"
        android:textSize="35dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.498"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/textView"
        app:layout_constraintVertical_bias="0.224" />

</androidx.constraintlayout.widget.ConstraintLayout>

界面展示

 

(二)MainActivity.java文件配置

文件作用

说明Myresolver提出的要求,在本次作业中该app提出的要求是在person表格中添加一条“name=dyt,age=18”的数据

代码如下

import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

    private Button button;
    private ContentResolver resolver;
    //private static final String AUTHORITY='dyt.Provider1';
    //private static final Uri NOTIFY_URI=Uri.parse("content://"+AUTHORITY+"/person");


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        button=findViewById(R.id.button);

        ContentResolver resolver=getContentResolver();
        ContentValues values=new ContentValues();
        values.put("name","dyt");
        values.put("age",18);

        Integer.parseInt("18");

    }
}

(三)AndroidManifest.xml文件配置

暂时保持默认生成的代码即可

二、提供方app:MyContentProvider

(一)MyDAO.java文件配置

文件作用

数据处理层,写在数据库上的增填操作,该作业中创建了“dytDB”数据库;

代码如下

package com.example.mycontentprovider;

import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.net.Uri;
import android.util.Log;
//数据处理层,写一套在数据库上的增删改查
public class MyDAO {
    private SQLiteDatabase database;
    private SQLiteOpenHelper myopenhelper;
    private Context context;

    private Uri uri=Uri.parse("content://dyt.provider1");  //.../person/10  指的是person表第10行

    public MyDAO(Context context){
        this.context=context;
        myopenhelper=new MyDBhelper(context,"dytDB",null,1);
        database=myopenhelper.getReadableDatabase();

        database.execSQL("drop table if exists person");
        database.execSQL("create table person(id integer primary key autoincrement,"+" name varchar, age integer)");
    }

    public Uri addvalue(Uri uri,ContentValues values){
        long rowID=database.insert("person",null,values);

        if(rowID == -1){
            Log.d("DAO","数据插入失败");
            return  null;
        }
        else {
            Uri insertUri= ContentUris.withAppendedId(uri,rowID);
            Log.d("dyt","ContentUris:"+insertUri.toString());
            context.getContentResolver().notifyChange(insertUri,null);
            return insertUri;
        }
    }
}

(二)MyDBhelper.java文件配置

文件作用

在数据库中建表,在该作业中创建person表

代码如下

package com.example.mycontentprovider;

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

import androidx.annotation.Nullable;
//解决sqlite数据库创建问题,修改函数参数->看解释(直接将super()中要修改的参数双击改成如下参数对应的实际数据)
//name->数据库名字
//factory->游标工厂(暂时设为null)
public class MyDBhelper extends SQLiteOpenHelper {
    public MyDBhelper(@Nullable Context context, @Nullable String name, @Nullable SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }

    @Override
    public void onCreate(SQLiteDatabase sqLiteDatabase) {
        //在onCreat中创建表结构
        // 数据库中所有的操作都在这里写
            sqLiteDatabase.execSQL("create table person(id integer primary key autoincrement " +
                                    ",name varchar(20) ," +
                                    "age integer)");  //execSQL  最简单粗暴的语句   可以执行标准的SQL语句
        //写到这里发现MyDBhelper还是灰色->未被使用->databaseactivity中操作
    }

    @Override
    public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {

    }
}

(三)MyContentProvider.java文件配置

文件作用

实例化DAO类,实现增添数据操作

代码如下

package com.example.mycontentprovider;

import android.content.ContentProvider;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.net.Uri;

public class MyContentProvider extends ContentProvider {
    private MyDAO myDAO;
    public MyContentProvider() {

    }

//获得类型
    @Override
    public String getType(Uri uri) {
        // TODO: Implement this to handle requests for the MIME type of the data
        // at the given URI.
        throw new UnsupportedOperationException("Not yet implemented");
    }
//增  返回类型uri
    @Override
    public Uri insert(Uri uri, ContentValues values) {
        // TODO: Implement this to handle requests to insert a new row.
        return myDAO.addvalue(uri,values);
    }
//创建
    @Override
    public boolean onCreate() {
        // TODO: Implement this to initialize your content provider on startup.
        Context context=getContext();
        myDAO=new MyDAO(context);
        return true;
    }

}

(四)MainActivity.java文件配置

代码如下

package com.example.mycontentprovider;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        MyDAO myDAO=new MyDAO(this);
    }
}

(五)activity_main.xml文件配置

暂时保持默认生成的文件即可

(六)AndroidManifest.xml文件配置

代码如下

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

    <application
        android:allowBackup="true"
        android:dataExtractionRules="@xml/data_extraction_rules"
        android:fullBackupContent="@xml/backup_rules"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/Theme.MycontentProvider"
        tools:targetApi="31">
        <provider
            android:authorities="dyt.provider1"
            android:name=".MyContentProvider"
            android:enabled="true"
            android:exported="true"></provider>
        <activity
            android:name=".MainActivity"
            android:exported="true">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

三、建立请求方与提供方联系

(一)请求方MainActivity.java文件代码补充

建立URI,完善按钮的点击效果,故在onCreate()函数中添加如下代码:

//建立Uri
Uri uri=Uri.parse("content://dyt.provider1/person");

//完善button点击效果
button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                resolver.insert(uri,values);
            }
        });

(二)请求方AndroidManifest.xml文件代码补充

注意!!!!!一定要添加下列语句!!!!

<queries>
        <package android:name="com.example.mycontentprovider"></package>
    </queries>

四、运行结果

step1.将MyResolver和MyContentProvider两个app同时启动;

step2.在resolver页面点击“接收”按钮;

step3.在MyContentProvider中查看App Inspection下的dytDB数据库中的person表,如图:

 该作业运行视频如下:

移动开发作业3的结果

五、源码地址

由于不久前电脑故障重装了系统,导致很多C盘软件丢失,后续下载GIT配置时反复出现不同问题,作业提交又有时限,故我直接将源码打包放在百度云中,永久有效可提取:

百度云链接:https://pan.baidu.com/s/1fUSDHfbwXoIFU-ELb-SAYQ?pwd=n0w0

提取码:n0w0

猜你喜欢

转载自blog.csdn.net/qq_57739064/article/details/128002545
今日推荐