Android编程实现定时发短信功能示例
作者:pku_android 发布时间:2021-12-29 08:24:17
本文实例讲述了Android编程实现定时发短信功能。分享给大家供大家参考,具体如下:
第一,要实现发短信的功能,必须要用到android系统中发短信的权限,即在AndoridManifest.xml中添加如下内容
<uses-permissionandroid:name="android.permission.SEND_SMS"/>
第二,使用AlarmManager来实现一个倒计时的功能,当时间到时发送短 信。AlarmManager有两个相似的用法:
1.在指定时常时候执行某项操作。
2.周期性的执行某项操作。AlarmManager对象需要配合Intent对象使用,可以定时开启一个Activity,发送一个Broadcast,或者开启一个Service。
以下是核心代码片段:
AlarmManager aManager=(AlarmManager)getSystemService(Context.ALARM_SERVICE);
Intent intent=new Intent(this,AlarmReceiver.class);
intent.setAction("AlarmReceiver");
PendingIntent pendingIntent=PendingIntent.getBroadcast(this, 0, intent, 0);
//aManager.set(AlarmManager.RTC, calendar.getTimeInMillis(), pendingIntent);
aManager.setRepeating(AlarmManager.RTC, 0, 60*1000, pendingIntent)
第三,实现时间的设定方式。
1.可以直接使用AlarmManager对象的set方法来设定具体的闹钟时间。
2.可以使用TImePicker的方式来设定时间,这种方式比较灵活。
第四,新建一个AlarmReceiver类,来对闹钟进行响应。
1. 现在AndroidMainfest.xml里添加Receiver的声明
<receiver
android:name=".AlarmReceiver"
android:label="@string/app_name">
<intent-filter>
<action android:name="AlarmReceiver" />
</intent-filter>
</receiver>
在AlarmReceiver.java中实现对时间的获取以及发送短信的功能。发送短信需要用到SmsManager类,利用类 SmsManager 发送信息, smsManager 为 SmsManager 一个默认的实例.
SmsManager smsManager =SmsManager.getDefault();
它的方法如下
smsManager.sendTextMessage(destinationAddress,scAddress, text, sentIntent, deliveryIntent)
其中各个参数的含义如下
destinationAddress: 收件人号码
scAddress: 短信中心服务号码, 这里设置为null
text: 发送内容
sentIntent: 发送短信结果状态信号(是否成功发送),new 一个Intent , 操作系统接收到信号后将广播这个Intent.此过程为异步.
deliveryIntent: 对方接收状态信号(是否已成功接收).
最后附上详细的代码
public class YoulainaozhongActivity extends Activity {
TextView onetextview;
TextView twotextview;
TextView threetextview;
Button onebutton;
Button twobutton;
Dialog dialog = null;
//新建日历对象,用来设置闹钟时间
Calendar calendar = Calendar.getInstance();
private SharedPreferences sharedPreferences;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
calendar.setTimeInMillis(System.currentTimeMillis());
LinearLayout relativeLayout =(LinearLayout) findViewById(R.id.LinearLayout);
relativeLayout.setBackgroundResource(R.drawable.bejing);
onebutton=(Button) findViewById(R.id.onebutton);
onebutton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
dialog();
}
});
twobutton=(Button) findViewById(R.id.twobutton);
twobutton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
finish();
}
});
onetextview=(TextView) findViewById(R.id.onetextview);
twotextview=(TextView) findViewById(R.id.twotextview);
threetextview=(TextView) findViewById(R.id.threetextview);
sharedPreferences=getSharedPreferences("alarm_record", Activity.MODE_PRIVATE);
AlarmManager aManager=(AlarmManager)getSystemService(Context.ALARM_SERVICE);
Intent intent=new Intent(this,AlarmReceiver.class);
intent.setAction("AlarmReceiver");
PendingIntent pendingIntent=PendingIntent.getBroadcast(this, 0, intent, 0);
// aManager.set(AlarmManager.RTC, calendar.getTimeInMillis(), pendingIntent);
aManager.setRepeating(AlarmManager.RTC, 0, 60*1000, pendingIntent);
}
public void dialog(){
View view=getLayoutInflater().inflate(R.layout.shijian, null);//
final TimePicker timePicker=(TimePicker)view.findViewById(R.id.timepicker);
final EditText oneeditext=(EditText)view.findViewById(R.id.oneeditext);
final EditText twoeditext=(EditText)view.findViewById(R.id.twoeditext);
timePicker.setIs24HourView(true);
new AlertDialog.Builder(this)
.setTitle("设置")
.setView(view)
.setPositiveButton("确定", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
String timeStr=String.valueOf(timePicker.getCurrentHour())+":"+String.valueOf(timePicker.getCurrentMinute());
/*calendar.set(Calendar.HOUR_OF_DAY,timePicker.getCurrentHour());
calendar.set(Calendar.MINUTE, 55);*/
onetextview.setText("您设置的时间为: "+timeStr);
twotextview.setText("您设置的号码为: "+oneeditext.getText().toString());
threetextview.setText("您设置的内容为: "+twoeditext.getText().toString());
sharedPreferences.edit().putString(timeStr, timeStr).commit();
sharedPreferences.edit().putString("haoma", oneeditext.getText().toString()).commit();
sharedPreferences.edit().putString("neirong", twoeditext.getText().toString()).commit();
}
}).setNegativeButton("取消", null).show();
}
}
public class AlarmReceiver extends BroadcastReceiver {
/**
* 通过广播进行扫描,是否到达时间后再响起闹铃
* */
@Override
public void onReceive(Context context, Intent intent) {
SharedPreferences sharedPreferences = context.getSharedPreferences(
"alarm_record", Activity.MODE_PRIVATE);
String hour = String.valueOf(Calendar.getInstance().get(
Calendar.HOUR_OF_DAY));
String minute = String.valueOf(Calendar.getInstance().get(
Calendar.MINUTE));
String time = sharedPreferences.getString(hour + ":" + minute, null);// 小时与分,
String haoma = sharedPreferences.getString("haoma", null);
String neirong = sharedPreferences.getString("neirong", null);
if (time != null) {// 判断是否为空,然后通过创建,
// MediaPlayer mediaPlayer = MediaPlayer.create(context, R.raw.a);
Toast.makeText(context, "短信已经发送成功", Toast.LENGTH_LONG).show();
// mediaPlayer.start();// 开始 ;
sendMsg(haoma, neirong);
}
}
private void sendMsg(String number, String message) {
SmsManager smsManager = SmsManager.getDefault();
smsManager.sendTextMessage(number, null, message, null, null);
}
}
希望本文所述对大家Android程序设计有所帮助。
来源:http://blog.csdn.net/pku_android/article/details/7548385


猜你喜欢
- session超时退到登录页面最近发现使用的工程居然没有session超时机制,功能太欠缺了,现在把追加方法分享出来,里面有一些坑,大家自由
- 背景最近在着手公司框架优化及项目实际应用,原先方案是springboot+html前后端分离单独部署,后端人员兼职前端开发,后续产品线业务进
- 数据传输在Android开发过程中,我们常常通过Intent在各个组件之间传递数据。例如在使用startActivity(android.c
- 我们知道,Object类是所有类的父类,因此也被称为根类、祖先。那么,我们就来看一看Object类的最常用的两个方法是如何用的。1.toSt
- //字符串的内存驻留机制 public static v
- 打包与运行在项目开发完成之后,可以直接用IDEA将其打包成JAR包运行,也可以打包成WAR包运行以便在多服务器、多配置环境下运行。双击cle
- 这一节我们先写一个简单点的Demo来测试易宝支付的流程,熟悉这个流程后,再做实际的开发,因为是一个Demo,所以我没有考虑一些设计模式的东西
- 1 概述在平时开发中,往往会遇到这样一种情况,实现一种功能有很多种算法或者策略,我们可以根据不同的算法或者策略来实现这种功能。比如:想要计算
- 前一段时间,在做摄像头拍照上传,摄像头拍的照片为base64编码格式的字符串,需要上传至项目中,则需要使用到将base64编码字符串转换为图
- spring data jpa @query返回map踩坑记录最近用spring data jpa,网上看的一些教程,有的说是返回的Obje
- 在项目中,时常会有异步调用的需求web.xml配置<servlet> <description>spri
- 目录前言asyncawait从以往知识推导创建异步任务创建异步任务并返回Task异步改同步说说 await Task说说 async Tas
- 案例sql脚本DROP DATABASE IF EXISTS `javacode2018`;CREATE DATABASE `javacod
- 最近因为工作的原因用到了西门子PLC,在使用过程中一直在思考上位机和PLC的通讯问题,后来上网查了一下,找到了一个专门针对S7开发的一个.n
- 1.前言对于一个Android开发者来说,每一个页面都继承一个单独的系统Activity,有时候会带来很多不必要的困扰。比如:每一个页面会有
- 上篇博文:Java-多线程的使用equals与==1. ==的使用1.1 概述⭕ 用于基本类型比较值时:只要两个变量的值相等,即为true。
- 模型对象的作用主要是保存数据,可以借助它们将数据带到前端。常用的模型对象有以下几个:ModelAndView(顾名思义,模型和视图,既可以携
- 一、前言在做Java项目开发过程中,涉及到一些数据库服务连接配置、缓存服务器连接配置等,通常情况下我们会将这些不太变动的配置信息存储在以 .
- 一丶先引入上传下载的lib二丶上传的的servletpackage com.test.action;import java.io.File;
- 这里我们通过Apache Commons CLI来完成目标功能,废话不多说直接上代码所需的maven依赖<dependency>