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

2023-10-14 03:50

本文主要是介绍移动开发作业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"><TextViewandroid: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" /><Buttonandroid: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");@Overrideprotected 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);}@Overridepublic void onCreate(SQLiteDatabase sqLiteDatabase) {//在onCreat中创建表结构// 数据库中所有的操作都在这里写sqLiteDatabase.execSQL("create table person(id integer primary key autoincrement " +",name varchar(20) ," +"age integer)");  //execSQL  最简单粗暴的语句   可以执行标准的SQL语句//写到这里发现MyDBhelper还是灰色->未被使用->databaseactivity中操作}@Overridepublic 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() {}//获得类型@Overridepublic 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@Overridepublic Uri insert(Uri uri, ContentValues values) {// TODO: Implement this to handle requests to insert a new row.return myDAO.addvalue(uri,values);}
//创建@Overridepublic 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 {@Overrideprotected 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"><applicationandroid: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"><providerandroid:authorities="dyt.provider1"android:name=".MyContentProvider"android:enabled="true"android:exported="true"></provider><activityandroid: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() {@Overridepublic 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

这篇关于移动开发作业3:resolver调用provider对表格进行数据添加的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/207952

相关文章

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

C#提取PDF表单数据的实现流程

《C#提取PDF表单数据的实现流程》PDF表单是一种常见的数据收集工具,广泛应用于调查问卷、业务合同等场景,凭借出色的跨平台兼容性和标准化特点,PDF表单在各行各业中得到了广泛应用,本文将探讨如何使用... 目录引言使用工具C# 提取多个PDF表单域的数据C# 提取特定PDF表单域的数据引言PDF表单是一

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处