实际效果:
1.首先进行布局文件的编写,布局前台页面
2.布置两个按钮,一个是填写页面的跳转,一个是查询页面的跳转。进行按钮事件的添加,onclick,重载父类方法,进行页面的跳转。利用intent开启活动activity。
填写页面:输入框(姓名,体温),时间利用android自带的系统函数获取设备的时间
地点获取:采用高德地图SDK
在application标签中声明service组件,每个app拥有自己单独的定位service。
Java
<service android:name="com.amap.api.location.APSService"></service>
Java
<!--用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission>
<!--用于访问GPS定位-->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
<!--用于获取运营商信息,用于支持提供运营商信息相关的接口-->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<!--用于访问wifi网络信息,wifi信息会用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
<!--用于获取wifi的获取权限,wifi信息会用来进行网络定位-->
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
<!--用于访问网络,网络定位需要上网-->
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<!--用于读取手机当前的状态-->
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<!--用于写入缓存数据到扩展存储卡-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<!--用于申请调用A-GPS模块-->
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS"></uses-permission>
在application标签中加入:
Java
<meta-data android:name="com.amap.api.v2.apikey" android:value="key">//开发者申请的key
</meta-data>
在主线程中声明AMapLocationClient类对象,需要传Context类型的参数。推荐用getApplicationContext()方法获取全进程有效的context。
Java
//声明AMapLocationClient类对象
public AMapLocationClient mLocationClient = null;
//声明定位回调监听器
public AMapLocationListener mLocationListener = new AMapLocationListener();
//初始化定位
mLocationClient = new AMapLocationClient(getApplicationContext());
//设置定位回调监听
mLocationClient.setLocationListener(mLocationListener);
AMapLocationClientOption对象用来设置发起定位的模式和相关参数。
Java
//声明AMapLocationClientOption对象
public AMapLocationClientOption mLocationOption = null;
//初始化AMapLocationClientOption对象
mLocationOption = new AMapLocationClientOption();
Java
//给定位客户端对象设置定位参数
mLocationClient.setLocationOption(mLocationOption);
//启动定位
mLocationClient.startLocation();
根据回调函数mylisener设置textview部件,设置参数得到地址。
将所有的数据保存到android的数据库中
第一步: 创建一个类继承 SQLiteOpenHelper 并实现父类的构造
第二步 重写onCreate 方法 和onUpgrade 方法
第三步 在Activity中 创建MySQLOpenHelper对象( 至此并没有创建数据库)
第四部 调用 MySQLOpenHelper的getReadableDatabase或getWriteableDatabase方法获取SQLiteDataBase对象
当调用getReadableDatabase或getWriteableDatabase方法 第一次创建数据库的时候会执行这个方法
作用: 在这个方法中做创建表 和初始化数据的操作
当调用getReadableDatabase或getWriteableDatabase方法时 如果数据库版本号变大 则会调用这个方法
作用: 在这个方法中做数据库或表结构修改的操作 比如给表添加字段 或给数据库增加新的表
public void insert(View v) {
SQLiteDatabase db = openHelper.getReadableDatabase();
db.execSQL("insert into info(name,phone) values('赵四','13888888888')");
db.execSQL("insert into info(name,phone) values('王五','13888888888')");
db.close();
}
public void update(View v) {
SQLiteDatabase db = openHelper.getReadableDatabase();
db.execSQL("update info set phone = '12345678' where name='赵四' ");
db.close();
}
public void delete(View v) {
SQLiteDatabase db = openHelper.getReadableDatabase();
db.execSQL("delete from info where name = '赵四'");
db.close();
}
public void query(View v) {
SQLiteDatabase db = openHelper.getReadableDatabase();
Cursor cursor = db.rawQuery("select * from info where name = ? ; ", new String[]{"王五"});
while(cursor.moveToNext()){
for (int i = 0; i < cursor.getColumnCount(); i++) {
String result = cursor.getString(i);
Log.d("MainActivity", result+"");
}
}
db.close();
}
进行数据库的操作存入数据
将查到的数据利用listview展示,用listview的子方法onclicklistview点击查看详细信息。
在获取地址时,调用外部的api,导入SDK遇到较多问题。
最开始用的是百度地图SDK,根据开发文档,编写好相关的方法,在测试时出现了版本不适的问题。Android百度地图定位API onReceiveLocation没有调用,无法进行定位。于是换了
最新的版本,又出现了问题,百度地图的jar包中有文件编译版本高于我的jdk版本,无法解析相关的class问价,编译不能通过。问题一直未解决。于是换高德地图,成功根据相关文档获取的位置信息。
AndroidManifest
<!-- 用于进行网络定位 -->
<uses-permission android:name="android.permission.ACCESS\_COARSE\_LOCATION" >
</uses-permission>
<!-- 用于访问GPS定位 -->
<uses-permission android:name="android.permission.ACCESS\_FINE\_LOCATION" >
</uses-permission>
<!-- 获取运营商信息,用于支持提供运营商信息相关的接口 -->
<uses-permission android:name="android.permission.ACCESS\_NETWORK\_STATE" >
</uses-permission>
<!-- 用于访问wifi网络信息,wifi信息会用于进行网络定位 -->
<uses-permission android:name="android.permission.ACCESS\_WIFI\_STATE" >
</uses-permission>
<!-- 这个权限用于获取wifi的获取权限,wifi信息会用来进行网络定位 -->
<uses-permission android:name="android.permission.CHANGE\_WIFI\_STATE" >
</uses-permission>
<!-- 用于访问网络,网络定位需要上网 -->
<uses-permission android:name="android.permission.INTERNET" >
</uses-permission>
<!-- 用于读取手机当前的状态 -->
<uses-permission android:name="android.permission.READ\_PHONE\_STATE" >
</uses-permission>
<!-- 写入扩展存储,向扩展卡写入数据,用于写入缓存定位数据 -->
<uses-permission android:name="android.permission.WRITE\_EXTERNAL\_STORAGE" >
</uses-permission>
<!-- 用于申请调用A-GPS模块 -->
<uses-permission android:name="android.permission.ACCESS\_LOCATION\_EXTRA\_COMMANDS" >
</uses-permission>
<!-- 用于申请获取蓝牙信息进行室内定位 -->
<uses-permission android:name="android.permission.BLUETOOTH" >
</uses-permission>
<uses-permission android:name="android.permission.BLUETOOTH\_ADMIN" >
</uses-permission>
<uses-sdk
android:minSdkVersion="17"
android:targetSdkVersion="29" />
<application
android:allowBackup="true"
android:icon="@drawable/preferences\_desktop\_icons\_72px\_572043\_easyicon"
android:label="@string/app\_name"
android:requestLegacyExternalStorage="true"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app\_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".InActivity"
android:label="@string/title\_activity\_in" >
</activity>
<activity
android:name=".OutActivity"
android:label="@string/title\_activity\_out" >
</activity>
<service android:name="com.amap.api.location.APSService" >
</service>
<meta-data
android:name="com.amap.api.v2.apikey"
android:value="cda85f6569f758ce27c1e616ecbb390c" />
<activity
android:name=".SmallitemActivity"
android:label="@string/title\_activity\_smallitem" >
</activity>
</application>
mainactivity
package com.study.temperature;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button bt_in = (Button)findViewById(R.id.bt_in);
//数据填写跳转
//绑定监听事件
bt_in.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
//点击跳转
Intent intent =new Intent(MainActivity.this,InActivity.class);
//启动填写页面
startActivity(intent);
}
});
//数据查询------------------------------------------------------------------------------------------
Button bt_out = (Button)findViewById(R.id.bt_out);
bt_out.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
//点击跳转
Intent intent =new Intent(MainActivity.this,OutActivity.class);
//启动填写页面
startActivity(intent);
}
});
}
}
main_xml
<TextView
android:id="@+id/tx\_outline"
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:layout\_above="@+id/bt\_in"
android:layout\_centerHorizontal="true"
android:layout\_marginBottom="62dp"
android:text="体温填报查看SYSTEM"
android:textColor="#771133"
android:textSize="25sp" />
<Button
android:id="@+id/bt\_in"
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:layout\_above="@+id/bt\_out"
android:layout\_centerHorizontal="true"
android:layout\_marginBottom="20dp"
android:text="填写信息" />
<Button
android:id="@+id/bt\_out"
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:layout\_alignLeft="@+id/bt\_in"
android:layout\_centerVertical="true"
android:text="查询信息" />
inactivity
package com.study.temperature;
import android.app.Activity;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
import java.util.Calendar;
import com.amap.api.location.AMapLocation;
import com.amap.api.location.AMapLocationClient;
import com.amap.api.location.AMapLocationClientOption;
import com.amap.api.location.AMapLocationClientOption.AMapLocationMode;
import com.amap.api.location.AMapLocationListener;
public class InActivity extends Activity {
//地址
private Button bt_start;
private TextView tv_locat;
private MyopenHelper helper;
private EditText et\_name;
private EditText et\_temon;
private EditText et\_temunder;
private TextView tv\_time;
private AMapLocationClient mLocationClient = null;
private AMapLocationListener mLocationListener = null;
/\*\*
\* 接受百度地图定位的回调类,该类是派生于百度地图的一个地图定位的监听类,用于定位后信息的返回。
\*/
/\*\*
\* 自定义的定位回调接口监听器,该接口是自定义的一个接口,用于在使用该对象时,把定位信息进行回调;
\*/
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\_in);
bt\_start = (Button)findViewById(R.id.bt\_start);
tv\_locat = (TextView)findViewById(R.id.tv\_locat);
bt\_start.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
if(bt\_start.getText().equals("开始定位")) {
bt\_start.setText("stop");
//声明AMapLocationClient类对象
//初始化定位
mLocationClient = new AMapLocationClient(getApplicationContext());
mLocationListener = new AMapLocationListener(){
@Override
public void onLocationChanged(AMapLocation location) {
if (location != null) {
if (location.getErrorCode() == 0) {
//解析定位结果
String province = location.getProvince(); //获取省份
String city = location.getCity(); //获取城市
String district = location.getDistrict(); //获取区县
String street = location.getStreet(); //获取街道信息
StringBuilder myPosition=new StringBuilder();
myPosition.append("纬度:").append(location.getLatitude()).append("\\n");
myPosition.append("经度:").append(location.getLongitude()).append("\\n");
myPosition.append("省份:").append(province).append("\\n");
myPosition.append("城市:").append(city).append("\\n");
myPosition.append("区:").append(district).append("\\n");
myPosition.append("街道:").append(street).append("\\n");
myPosition.append("门牌号:").append(location.getStreetNum());//街道门牌号信息
tv\_locat.setText(myPosition);
}
}
}
};
//设置定位回调监听
mLocationClient.setLocationListener(mLocationListener);
//异步获取定位结果
initLocation();
//启动定位
mLocationClient.startLocation();
}else if(bt\_start.getText().equals("stop")) {
bt\_start.setText("开始定位");
close();
}
}
});
//------------------------
et_name = (EditText)findViewById(R.id.et_name);
et_temon = (EditText)findViewById(R.id.et_temon);
et_temunder = (EditText)findViewById(R.id.et_temunder);
Calendar calendar = Calendar.getInstance();
//年
int year = calendar.get(Calendar.YEAR);
//月
int month = calendar.get(Calendar.MONTH)+1;
//日
int day = calendar.get(Calendar.DAY\_OF\_MONTH);
//获取系统时间
//小时
int hour = calendar.get(Calendar.HOUR\_OF\_DAY);
//分钟
int minute = calendar.get(Calendar.MINUTE);
//秒
int second = calendar.get(Calendar.SECOND);
tv\_time = findViewById(R.id.tv\_time);
tv\_time.setText(year+"年"+month+"月"+day+"日"+hour+":"+minute+":"+second);
helper = new MyopenHelper(this,1);
Button bt\_tijiao = (Button)findViewById(R.id.bt\_tijiao);
bt\_tijiao.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
//打开数据库
SQLiteDatabase readableDatabase = helper.getReadableDatabase();
//获取edittext数据
String text = et\_name.getText().toString().trim();
String text2 = et\_temon.getText().toString().trim();
String text3 = et\_temunder.getText().toString().trim();
String text4 = tv\_time.getText().toString().trim();
String text5 = tv\_locat.getText().toString().trim();
if (TextUtils.isEmpty(text)||TextUtils.isEmpty(text2)||TextUtils.isEmpty(text3)) {
Toast.makeText(InActivity.this, "输入不能为空", Toast.LENGTH\_SHORT).show();
}else {
String sql = "insert into info (name,temon,temunder,time,locat) values('"+text+"','"+text2+"','"+text3+"','"+text4+"','"+text5+"')";
readableDatabase.execSQL(sql);
readableDatabase.close();
Toast.makeText(InActivity.this, "提交成功!", Toast.LENGTH\_SHORT).show();
Intent intent =new Intent(InActivity.this,MainActivity.class);
finish();//结束当前活动
startActivity(intent);
}
}
});
}
private void initLocation() {
AMapLocationClientOption option = new AMapLocationClientOption();
option.setGpsFirst(true); // 打开gps;
//可选,是否需要地址信息,默认为不需要,即参数为false
//设置定位模式为AMapLocationMode.Hight\_Accuracy,高精度模式。
option.setLocationMode(AMapLocationMode.Hight\_Accuracy); //可选,设置是否需要最新版本的地址信息。默认需要,即参数为true
mLocationClient.setLocationOption(option);
//mLocationClient为第二步初始化过的LocationClient对象
//需将配置好的LocationClientOption对象,通过setLocOption方法传递给LocationClient对象使用
//更多LocationClientOption的配置,请参照类参考中LocationClientOption类的详细说明
}
private void close() {
mLocationClient.stopLocation();
mLocationClient.unRegisterLocationListener(mLocationListener);
mLocationClient.onDestroy();
}
}
in_xml
<LinearLayout
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:orientation="horizontal" >
<TextView
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:text="姓名:" />
<EditText
android:id="@+id/et\_name"
android:layout\_width="match\_parent"
android:layout\_height="wrap\_content"
android:ems="10"
android:hint="请输入" />
</LinearLayout>
<LinearLayout
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:orientation="horizontal" >
<TextView
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:text="上午体温:" />
<EditText
android:id="@+id/et\_temon"
android:layout\_width="match\_parent"
android:layout\_height="wrap\_content"
android:ems="10"
android:hint="请输入" />
</LinearLayout>
<LinearLayout
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:orientation="horizontal" >
<TextView
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:text="下午体温:" />
<EditText
android:id="@+id/et\_temunder"
android:layout\_width="match\_parent"
android:layout\_height="wrap\_content"
android:ems="10"
android:hint="请输入" />
</LinearLayout>
<TextView
android:id="@+id/tv\_time"
android:layout\_width="match\_parent"
android:layout\_height="wrap\_content"
android:text="时间" />
<Button
android:id="@+id/bt\_start"
android:layout\_width="match\_parent"
android:layout\_height="wrap\_content"
android:text="开始定位" />
<TextView
android:id="@+id/tv\_locat"
android:layout\_width="match\_parent"
android:layout\_height="wrap\_content"
android:text="地址"/>
<Button
android:id="@+id/bt\_tijiao"
android:layout\_width="wrap\_content"
android:layout\_height="wrap\_content"
android:layout\_marginLeft="210dp"
android:onClick="insert"
android:text="提交" />
outactivity
package com.study.temperature;
import java.util.ArrayList;
import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
public class OutActivity extends Activity {
private ListView lv\_list;
private ArrayList<Person> persons = new ArrayList<Person>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\_out);
lv\_list = (ListView)findViewById(R.id.lv\_list);
MyopenHelper helper = new MyopenHelper(this,1);
SQLiteDatabase readableDatabase = helper.getReadableDatabase();
String sql = "select \* from info";
Cursor curor = readableDatabase.rawQuery(sql , null);
//遍历查询到的结果
int count=0;
while(curor.moveToNext()){
//创建person对象
Person person = new Person();
//根据列名 name 获取数据库中对应的值
String name = curor.getString(curor.getColumnIndex("name"));
//根据列名 phone 获取数据库中对应的值
String temon = curor.getString(curor.getColumnIndex("temon"));
String temunder = curor.getString(curor.getColumnIndex("temunder"));
String time = curor.getString(4);
String locat = curor.getString(5);
//设置相应数据
person.setName(name);
person.setTemon(temon);
person.setTemunder(temunder);
person.setTime(time);
person.setLocat(locat);
//把数据添加到集合
persons.add(person);
count++;
}
//list显示
//把数据适配器和listview绑定
lv\_list.setAdapter(new MyAdapter());
//关闭游标
curor.close();
helper.close();
if(count!=0) {
Toast.makeText(this, "查询成功", Toast.LENGTH\_SHORT).show();
}else {
Toast.makeText(this, "查询失败", Toast.LENGTH\_SHORT).show();
}
lv\_list.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
//点击跳转
Intent intent =new Intent(OutActivity.this,SmallitemActivity.class);
//启动填写页面
Person tem =persons.get(position);
intent.putExtra("name",tem.getName());
intent.putExtra("info", tem.getTime()+"\\n"+tem.getLocat());
startActivity(intent);
}
});
}
private class MyAdapter extends BaseAdapter{
//返回要展示的数据集合的条目数
@Override
public int getCount() {
return persons.size();
}
//通过adapter传进来的posion(listview中条目的position)
//把它对应的数据集合中的对象返回来
@Override
public Object getItem(int position) {
return persons.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
//①把布局文件转换为View对象 需要判断convertView是否为空
View view= null;
if(convertView == null){
//创建view对象
view = View.inflate(OutActivity.this, R.layout.item, null);
}else{
//复用旧的convertView
view = convertView;
}
//②找到要修改的控件的对象 注意要调用view.findViewById
TextView tv\_name = (TextView)view.findViewById(R.id.tv\_name);
TextView tv\_tem = (TextView)view.findViewById(R.id.tv\_tem);
//③ 设置数据
//3.1通过position 到数据集合中把要显示的数据找到
Person person = persons.get(position);
//3.2把要显示的内容展示到对应的View对象上
tv\_name.setText(person.getName());
tv\_tem.setText("上午:"+person.getTemon()+"下午:"+person.getTemunder());
return view;
}
}
}
out_xml
<ListView
android:id="@+id/lv\_list"
android:layout\_width="match\_parent"
android:layout\_height="match\_parent"
android:fastScrollEnabled="true" />
只帖了主要的,完整见GitHub,欢迎提出不足之处。
手机扫一扫
移动阅读更方便
你可能感兴趣的文章