android电话管理器(TelephonyManger)实例:
TelephonyManger是管理电话状态、网络信息的服务类。
添加权限:
<uses-permission android:name="android.permission.READ_PHONE_STATE"/> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
逻辑功能:
package com.example.telephonystatus; import java.io.FileNotFoundException; import java.io.OutputStream; import java.io.PrintStream; import java.util.ArrayList; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import android.os.Bundle; import android.app.Activity; import android.content.Context; import android.telephony.PhoneStateListener; import android.telephony.TelephonyManager; import android.view.Menu; import android.widget.ListView; import android.widget.SimpleAdapter; public class MainActivity extends Activity { private ListView list1; // 声明代表状态名的数组 private String[] statusName; // 声明代表手机状态名的集合 private ArrayList<String> statusValues = new ArrayList<String>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); list1 = (ListView) findViewById(R.id.list1); // 获取系统的TelephonyManager TelephonyManager tele = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE); // 获取各种状态名的数组 statusName = getResources().getStringArray(R.array.statusNames); // 获取SIM卡的状态的数组 String[] simType = getResources().getStringArray(R.array.simState); // 获取电话网络类型的数组 String[] phoneType = getResources().getStringArray(R.array.phoneType); // 获取设备编号 statusValues.add(tele.getDeviceId()); // 获取系统平台的版本 statusValues.add(tele.getDeviceSoftwareVersion() != null ? tele .getDeviceSoftwareVersion() : "未知"); // 获取网络运营代号 statusValues.add(tele.getNetworkOperator()); // 获取网络运营商的名称 statusValues.add(tele.getNetworkOperatorName()); // 获取手机网络的类型 statusValues.add(phoneType[tele.getPhoneType()]); // 获取设为所在的位置 statusValues.add(tele.getCellLocation() != null ? tele .getCellLocation().toString() : "未知"); // 获取sim卡的国别 statusValues.add(tele.getSimCountryIso()); // 获取sim卡的序列号 statusValues.add(tele.getSimSerialNumber()); // 获取sim卡的状态 statusValues.add(simType[tele.getSimState()]); List<Map<String, Object>> list = new ArrayList<Map<String, Object>>(); for (int i = 0; i < statusValues.size(); i++) { HashMap<String, Object> hasp = new HashMap<String, Object>(); hasp.put("name", statusName[i]); hasp.put("values", statusValues.get(i)); list.add(hasp); } SimpleAdapter simple = new SimpleAdapter(this, list, R.layout.items, new String[] { "name", "values" }, new int[] { R.id.text1, R.id.text2 }); list1.setAdapter(simple); // 创建一个电话监听器 PhoneStateListener listener = new PhoneStateListener() { // 监听电话呼叫状态 @Override public void onCallStateChanged(int state, String incomingNumber) { switch (state) { // 无任何状态 case TelephonyManager.CALL_STATE_IDLE: break; case TelephonyManager.CALL_STATE_OFFHOOK: break; // 来电响铃 case TelephonyManager.CALL_STATE_RINGING: OutputStream os = null; try { os = openFileOutput("phoneList", MODE_APPEND); } catch (FileNotFoundException e) { e.printStackTrace(); } PrintStream ps = new PrintStream(os); // 讲电话号码记录到文件中 ps.println(new Date() + "来电:" + incomingNumber); ps.close(); break; default: break; } super.onCallStateChanged(state, incomingNumber); } }; tele.listen(listener, PhoneStateListener.LISTEN_CALL_STATE); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }
android短信管理器(SmsManager)实例
需要注册的权限:
<uses-permission android:name="android.permission.READ_CONTACTS"/> <uses-permission android:name="android.permission.SEND_SMS"/>
群发短信功能:
package com.android.xiong.groupsend; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.app.AlertDialog; import android.app.PendingIntent; import android.content.DialogInterface; import android.content.Intent; import android.database.Cursor; import android.os.Bundle; import android.provider.ContactsContract; import android.telephony.SmsManager; import android.view.Menu; import android.view.View; import android.view.ViewGroup; import android.view.View.OnClickListener; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.CheckBox; import android.widget.EditText; import android.widget.ListView; import android.widget.Toast; public class MainActivity extends Activity { private Button bt1, bt2; private EditText ed1, ed2; private SmsManager sManger; List<String> sendList = new ArrayList<String>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); bt1 = (Button) findViewById(R.id.bt1); bt2 = (Button) findViewById(R.id.bt2); ed1 = (EditText) findViewById(R.id.ed1); ed2 = (EditText) findViewById(R.id.ed2); // 获取SmsManger sManger = SmsManager.getDefault(); bt1.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { for (String send : sendList) { // 创建PendIntent对象 PendingIntent ped = PendingIntent.getActivity( MainActivity.this, 0, new Intent(), 0); // 发送信息 sManger.sendTextMessage(send, null, ed2.getText() .toString(), ped, null); } // 提示消息发送完毕 Toast.makeText(MainActivity.this, "短信群发完", Toast.LENGTH_LONG) .show(); } }); bt2.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 查看联系人的电话号码 final Cursor cursor = getContentResolver().query( ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, null, null, null); BaseAdapter adapter = new BaseAdapter() { @Override public View getView(int position, View convertView, ViewGroup parent) { cursor.moveToPosition(position); CheckBox rb = new CheckBox(MainActivity.this); // 获取联系人的电话号码 并去掉中间的中画、空格 String number = cursor .getString( cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER)) .replace("-", ""); rb.setText(number); // 如果该号码已经加入发送人名单,默认勾选该号码 if (sendList.contains(number)) { rb.setChecked(true); } return rb; } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } @Override public Object getItem(int position) { // TODO Auto-generated method stub return position; } @Override public int getCount() { // TODO Auto-generated method stub return cursor.getCount(); } }; // 加载list.xml布局文件对应的View View selectView = getLayoutInflater().inflate(R.layout.item, null); final ListView listView = (ListView) selectView .findViewById(R.id.list1); listView.setAdapter(adapter); new AlertDialog.Builder(MainActivity.this).setView(selectView).setPositiveButton("确定", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { //清空sendList集合 sendList.clear(); //遍历listView组件的每个列表项 for(int i=0;i<listView.getCount();i++){ CheckBox checkBox=(CheckBox)listView.getChildAt(i); //如果该列表项被勾选 if(checkBox.isChecked()){ //添加到该列表项中 sendList.add(checkBox.getText().toString()); ed1.append(checkBox.getText().toString()+","); } } } }).show(); } }); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context=".MainActivity" > <EditText android:id="@+id/ed1" android:layout_width="match_parent" android:layout_height="wrap_content"/> <EditText android:id="@+id/ed2" android:layout_width="match_parent" android:layout_height="wrap_content" /> <Button android:id="@+id/bt2" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="获取联系人"/> <Button android:id="@+id/bt1" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="发送信息"/> </LinearLayout>
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <ListView android:id="@+id/list1" android:layout_width="match_parent" android:layout_height="wrap_content" > </ListView> </LinearLayout>
本文向大家介绍Android编写简易文件管理模块,包括了Android编写简易文件管理模块的使用技巧和注意事项,需要的朋友参考一下 最近在做一个将word文档导入到SQLite的程序。对于文件选择问题,经过再三考虑决定写一个简易的文件管理模块,用来选择需要导入的文件文件 先看下效果图: 思路: 获取存储器接口 遍历当前目录 利用ListView显示文件文件夹 先是布局 用于加载文件的Item布局
本文向大家介绍Android studio编写简单的手电筒APP,包括了Android studio编写简单的手电筒APP的使用技巧和注意事项,需要的朋友参考一下 很不错的手电筒APP,分享给大家,希望大家喜欢。 1. Java代码 2. FireActivity.java 3. content_fire.xml 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程
主要内容:本节引言:,1.调用系统发送短信功能:,2.调用系统提供的短信接口发送短信,本节小结:本节引言: 本节带来的是Android中的SmsManager(短息管理器),见名知意,就是用来管理手机短信的, 而该类的应用场景并不多,一般是我们发短信的时候才会用到这个API,当然这种短信是 文字短信,对于彩信过于复杂,而且在QQ微信各种社交APP横行的年代,你会去发1块钱一条的 彩信吗?所以本节我们只讨论发送普通文字短信! 官方文档:SmsManager 1.调用系统发送短信功能: 就是把写
问题内容: 我有一个应用程序,当用户要求过滤图像时会生成一个新线程。 这是我唯一要做的任务,所有任务都同等重要。 如果我请求太多并发线程(我最多希望有9个),则线程管理器将抛出 RejectedExecutionException 。 在那一刻我要做的是; 只需将被拒绝的任务添加到队列中,下次启动线程时,将检查队列以查看是否存在积压。 显而易见的问题是,如果最终任务在第一次尝试时被拒绝,它将永远不
主要内容:本节引言:,1.获得TelephonyManager的服务对象,2.用法示例,3.本节示例代码下载,本节小结:本节引言: 本章节是Android基础入门教程的最后一章,主要讲解是一些零零散散的一些知识点,以及一些遗漏 知识点的补充,这些零散的知识点包括,各种系统服务的使用,比如本节的电话管理器,短信管理器, 振动器,闹钟,壁纸等等,还有传感器之类的东西!乱七八糟什么都有哈!好的,本节我们要学习的 是TelephonyManager,见名知义:用于管理手机通话状态,获取电话信息(设备信息
我正在尝试覆盖Android中的信任管理器。我想让基础信任管理器检查证书,但我需要确定证书是否过期。如果证书过期,我需要忽略它并接受证书。如果电池被移除,一些移动设备会将日期重置为旧日期,导致证书看起来好像过期了。我的应用程序必须继续保持运行,即使发生这种情况。 我遇到的问题是这行代码抛出了NullPointerException: 访问URL的代码:
本文向大家介绍Android实现电池管理系统,包括了Android实现电池管理系统的使用技巧和注意事项,需要的朋友参考一下 一、Android 电池服务 Android电池服务,用来监听内核上报的电池事件,并将最新的电池数据上报给系统,系统收到新数据后会去更新电池显示状态、剩余电量等信息。如果收到过温报警和低电报警,系统会自动触发关机流程,保护电池和机器不受到危害。 Android电池服务的启动和
本文向大家介绍C#实现简单学生信息管理系统,包括了C#实现简单学生信息管理系统的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了C#实现简单学生信息管理系统的具体代码,供大家参考,具体内容如下 一、运行环境windows,使用vs编译软件 二、主要功能 登录、添加学生信息、修改学生信息、删除学生信息、查询学生信息 三、实现步骤 1、登陆界面功能实现 老规矩,先贴下主要代码: 效果如下