发送短信功能界面

/**
* 发送短信Demo
*
* @description:
* @author ldm
* @date 2016-4-22 上午9:07:53
*/
public class SmsActivity extends Activity implements OnClickListener {
public static final String SMS_RECIPIENT_EXTRA = "com.ldm.study.SMS_RECIPIENT";
public static final String ACTION_SMS_SENT = "com.ldm.study.SMS_SENT_ACTION";
private Button sms_send_message;
private EditText sms_recipient;
private EditText sms_content;
private CheckBox sms_enable_receiver;
private TextView sms_status; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.send_sms_layout);
initViews();
initListeners();
registerSmsReceiver(); } /**
* 注冊短信监听广播
*
* @description:
* @author ldm
* @date 2016-4-22 上午9:23:23
*/
private void registerSmsReceiver() {
registerReceiver(new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
String message = null;
boolean error = true;
switch (getResultCode()) {
case Activity.RESULT_OK:
message = "发送成功!";
error = false;
break;
case SmsManager.RESULT_ERROR_GENERIC_FAILURE:
message = "发送失败";
break;
case SmsManager.RESULT_ERROR_NO_SERVICE:
message = "发送失败";
break;
case SmsManager.RESULT_ERROR_NULL_PDU:
message = "发送失败";
break;
case SmsManager.RESULT_ERROR_RADIO_OFF:
message = "发送失败";
break;
} sms_recipient.setEnabled(true);
sms_content.setEnabled(true);
sms_content.setText(""); sms_status.setText(message);
sms_status.setTextColor(error ? Color.RED : Color.GREEN);
}
}, new IntentFilter(ACTION_SMS_SENT));
} /**
* 监听事件
*
* @description:
* @author ldm
* @date 2016-4-22 上午9:24:20
*/
private void initListeners() {
sms_send_message.setOnClickListener(this);
// 应用Package管理器
final PackageManager pm = this.getPackageManager();
// 获取到应用中指定的组件
final ComponentName componentName = new ComponentName("com.ldm.study",
"com.ldm.study.receiver.SmsMessageReceiver");
// 依据组件是否可用的状态来推断sms_enable_receiver的选中状态
sms_enable_receiver
.setChecked(pm.getComponentEnabledSetting(componentName) == PackageManager.COMPONENT_ENABLED_STATE_ENABLED);
// 监听sms_enable_receiver设置广播组件是否可用
sms_enable_receiver
.setOnCheckedChangeListener(new OnCheckedChangeListener() {
public void onCheckedChanged(CompoundButton buttonView,
boolean isChecked) {
// 组件状态设置
pm.setComponentEnabledSetting(
componentName,
isChecked ? PackageManager.COMPONENT_ENABLED_STATE_ENABLED
: PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
PackageManager.DONT_KILL_APP);
}
}); } private void initViews() {
sms_recipient = (EditText) (findViewById(R.id.sms_recipient));
sms_content = ((EditText) findViewById(R.id.sms_content));
// 是否打开短信广播接收开关
sms_enable_receiver = (CheckBox) findViewById(R.id.sms_enable_receiver);
sms_send_message = (Button) findViewById(R.id.sms_send_message);
sms_status = (TextView) findViewById(R.id.sms_status);
if (getIntent().hasExtra(SMS_RECIPIENT_EXTRA)) {
sms_recipient.setText(getIntent().getExtras().getString(
SMS_RECIPIENT_EXTRA));
sms_content.requestFocus();
}
} @Override
public void onClick(View v) {
if (v.getId() == R.id.sms_send_message) {
sendSms();
}
} /**
* 发送短信
*
* @description:
* @author ldm
* @date 2016-4-22 上午9:30:38
*/
private void sendSms() { if (TextUtils.isEmpty(sms_recipient.getText())) {
Toast.makeText(SmsActivity.this, "请输入短信接收者", Toast.LENGTH_SHORT)
.show();
return;
} if (TextUtils.isEmpty(sms_content.getText())) {
Toast.makeText(SmsActivity.this, "请输入短信内容", Toast.LENGTH_SHORT)
.show();
return;
} sms_recipient.setEnabled(false);
sms_content.setEnabled(false); SmsManager sms = SmsManager.getDefault(); List<String> messages = sms.divideMessage(sms_recipient.getText()
.toString()); String recipient = sms_content.getText().toString();
for (String message : messages) {
// 发送短信
sms.sendTextMessage(recipient, null, message, PendingIntent
.getBroadcast(SmsActivity.this, 0, new Intent(
ACTION_SMS_SENT), 0), null);
} }
}

收到短信后处理界面:

/**
* 接收短信语音播报
*
* @description:
* @author ldm
* @date 2016-4-22 上午9:34:21
*/
public class SmsReceivedActivity extends Activity implements OnInitListener { private static final int DIALOG_SHOW_MESSAGE = 1; public static final String SMS_FROM_ADDRESS_EXTRA = "com.ldm.study.SMS_FROM_ADDRESS";
public static final String SMS_FROM_DISPLAY_NAME_EXTRA = "com.ldm.study.SMS_FROM_DISPLAY_NAME";
public static final String SMS_MESSAGE_EXTRA = "com.ldm.study.SMS_MESSAGE"; private TextToSpeech mTts; private String mFromDisplayName;
private String mFromAddress;
private String mMessage;
private String mFullBodyString; @SuppressWarnings("deprecation")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 短信来电号码
mFromAddress = getIntent().getExtras()
.getString(SMS_FROM_ADDRESS_EXTRA);
// 来电人称呼
mFromDisplayName = getIntent().getExtras().getString(
SMS_FROM_DISPLAY_NAME_EXTRA);
mMessage = getIntent().getExtras().getString(SMS_MESSAGE_EXTRA);
// 短信内容
mFullBodyString = String.format(getString(R.string.sms_format),
mFromDisplayName, mMessage); showDialog(DIALOG_SHOW_MESSAGE);
//初始化TTS
mTts = new TextToSpeech(this, this);
} /**
* 初始化TTS服务
*/
@SuppressWarnings("deprecation")
public void onInit(int status) {
if (status == TextToSpeech.SUCCESS) {// 成功状态
// 设置语言,TTS引擎支持 English、 French 、 German 、 Italian 和 Spanish 这5大语言
int result = mTts.setLanguage(Locale.ENGLISH);
if (result == TextToSpeech.LANG_MISSING_DATA
|| result == TextToSpeech.LANG_NOT_SUPPORTED) {
Toast.makeText(this, "TTS不可用", Toast.LENGTH_LONG).show();
} else {
mTts.speak(mFullBodyString, TextToSpeech.QUEUE_ADD, null);
// mTts.speak(mFullBodyString, TextToSpeech.QUEUE_ADD, null,
// "");
}
} else {
Toast.makeText(this, "TTS初始化失败", Toast.LENGTH_LONG).show();
}
} @Override
protected Dialog onCreateDialog(int id) {
switch (id) {
case DIALOG_SHOW_MESSAGE:
return new AlertDialog.Builder(this)
.setIcon(android.R.drawable.ic_dialog_email)
.setTitle("Message Received")
.setMessage(mFullBodyString)
.setPositiveButton("回复",
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int whichButton) {
// 回复短信则跳转到发送短信界面。把接收人信息带过去
Intent i = new Intent();
i.setClass(SmsReceivedActivity.this,
SmsActivity.class);
i.putExtra(SmsActivity.SMS_RECIPIENT_EXTRA,
mFromAddress);
startActivity(i); dialog.dismiss();
finish();
}
})
.setNegativeButton("取消",
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int whichButton) {
dialog.dismiss();
finish();
}
}).create();
}
return null;
}
}

短信广播

/**
* 短信来信监听广播
*
* @description:
* @author ldm
* @date 2016-4-22 上午10:07:49
*/
public class MyMsmReceiver extends BroadcastReceiver { @Override
public void onReceive(Context context, Intent intent) {
Bundle extras = intent.getExtras();
if (extras == null)
return;
// 收到的短信内容
Object[] pdus = (Object[]) extras.get("pdus"); for (int i = 0; i < pdus.length; i++) {
SmsMessage message = SmsMessage.createFromPdu((byte[]) pdus[i]);
String fromAddress = message.getOriginatingAddress();
String fromDisplayName = fromAddress; Uri uri;
String[] projection; uri = Uri.withAppendedPath(
ContactsContract.PhoneLookup.CONTENT_FILTER_URI,
Uri.encode(fromAddress));
projection = new String[] { ContactsContract.PhoneLookup.DISPLAY_NAME }; // 查询短信的发件人
Cursor cursor = context.getContentResolver().query(uri, projection,
null, null, null);
if (cursor != null) {
if (cursor.moveToFirst())
fromDisplayName = cursor.getString(0); cursor.close();
}
// 跳转到短信接收界面
Intent di = new Intent();
di.setClass(context, SmsReceivedActivity.class);
di.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK
| Intent.FLAG_ACTIVITY_SINGLE_TOP);
di.putExtra(SmsReceivedActivity.SMS_FROM_ADDRESS_EXTRA, fromAddress);
di.putExtra(SmsReceivedActivity.SMS_FROM_DISPLAY_NAME_EXTRA,
fromDisplayName);
di.putExtra(SmsReceivedActivity.SMS_MESSAGE_EXTRA, message
.getMessageBody().toString());
context.startActivity(di);
}
}
}

DEMO下载地址:http://download.csdn.net/detail/true100/9498881

Android短信收到,语音播报的更多相关文章

  1. Android短信监听实现,及Android4.4之后短信机制变更

    前阵子公司有一个项目,简单的监听短信应用,功能只有如下两个: 1.监听短信并获取短信内容上传服务器: 2.从服务器获取短信内容,发送出去    按照传统的思路,监听短信我们有两种方式:第一种是使用广播 ...

  2. 【mob】Android短信验证+源码

    在很多的应用当中,都涉及到了短信验证的功能,比如在注册或者找回密码的时候,那么我们如何通过第三方的平台来完成这个功能呢? 本面博文就实现短信验证,来做一个小的栗子. 第一步-下载开发包 第二步-将SD ...

  3. Android 短信的还原

    上篇文章讲到<Android 短信的备份>,本文主要实现Android 短信的还原,即是将一条 布局文件: <RelativeLayout xmlns:android="h ...

  4. Android短信发送器(2)

    在上一篇的<Android短信发送器>当中.发送功能并不完好.当发送内容超过限定字数时,短信就会发送失败,此时就须要推断内容是否超过限制,假设不超过限制.就直接发送,反之.则对其进行处理再 ...

  5. Android 短信验证码控件

    Android 短信验证码控件,便于项目中使用统一样式,统一提示改动.个人觉得挺好用的 <span style="font-size:18px;">public cla ...

  6. Android 短信监听及用途分析

    监听系统短信这个只能作为一个技术点来研究下,读者可能在工作中可能不会哦涉及到,一般的应用软件也不会有这个需求 但是作为程序员呢,多了解一下也是好的. Android 监听系统短信有什么用? 1.对系统 ...

  7. Android短信监听软件

    本案例是在android手机中运行,是一个没有界面的短信监听软件.主要是用BroadcastReceiver来接受短信广播,当接收到短信后就跳转到service中来转发短信.哈哈,不是用来干坏事的.这 ...

  8. Android短信彩信收发流程(应用层)

    下图为ComposeMessageActivity中confirmSendMessageIfNeeded部分的信息发送流程.主要以接收者有效性的确认为主,然后转向sendMessage方法进行发送. ...

  9. android短信发送器源代码

    Activity类: import java.util.List;import android.app.Activity;import android.app.PendingIntent;import ...

随机推荐

  1. 使用 IntraWeb (8) - 系统模板

    我们可以自定义系统错误模板, 编辑 IWError.html 放到模板文件夹后, 它将替换默认的模板. {在主页面, 这是要模拟一个系统错误} procedure TIWForm1.IWButton1 ...

  2. MongoDB+MongoVUE安装及入门

    前言及概念 据说nodejs和mongoDB是一对好基友,于是就忍不住去学习了解了一下MongoDB相关的一些东西, 那么,MongoDB是什么?这里的五件事是每个开放人员应该知道的: MongoDB ...

  3. CGI-- FASTCGI

    http://blog.csdn.net/sweatott/article/details/54913151 CGI:是 Web Server 与 Web Application 之间数据交换的一种协 ...

  4. 1300多万条数据30G论坛大数据优化实战经验小结

    最近由于某大型网站社区论坛运行效率比较低用户反馈论坛有些卡需要对系统进行优化,论坛性能影响了公司的形象还有网站的流量,当然这也会影响到公司的收入,而且后期还需要长期维护网站的社区论坛服务. 1:并发访 ...

  5. Universal-Image-Loader解析(二)——DisplayImageOptions的详细配置与简单的图片加载

    在使用这个框架的时候,我们必须要配置一个DisplayImageOptions对象来作为ImageLoader.getInstance().displayImage()中的参数,所以很有必要讲解这个对 ...

  6. 7z文件格式及其源码linux/windows编译

    7z文件格式及其源码的分析(二) 一. 准备工作: 1. 源码下载: 可以从官方中文主页下载:http://sparanoid.com/lab/7z/. 为了方便, 这里直接给出下载链接: http: ...

  7. [转]mysqldump备份还原和mysqldump导入导出语句大全详解

    FROM : http://www.cnblogs.com/zeroone/archive/2010/05/11/1732834.html mysqldump备份还原和mysqldump导入导出语句大 ...

  8. [转]一次非常有意思的sql优化经历

    From :http://www.cnblogs.com/tangyanbo/p/4462734.html 补充:看到这么多朋友对sql优化感兴趣,我又重新补充了下文章的内容,将更多关于sql优化的知 ...

  9. cannot be resolved. It is indirectly referenced from required .class files

    缺少引用. 把缺少的引用在导入一下...如果是mavan 在当前moudle里也要把 dependency加进来

  10. 未能加载文件或程序集“Newtonsoft.Json”或它的某一个依赖项。找到的程序集清单定义与程序集引用不匹配。 (异常来自 HRESULT:0x80131040)

    "/"应用程序中的服务器错误. 未能加载文件或程序集"Newtonsoft.Json"或它的某一个依赖项.找到的程序集清单定义与程序集引用不匹配. (异常来自 ...