- 浏览: 142805 次
- 性别:
- 来自: 上海
最新评论
-
xueyinv86:
你这个增强版的wordcount是在哪个版本的hadoop上跑 ...
MapReduce入门程序WordCount增强版 -
chenjianjx:
很不错的收集!
几篇关于Hadoop+Hive数据仓库的入门文章 -
canedy:
import org.apache.hadoop.hbase. ...
使用HBase的一个典型例子,涉及了HBase中很多概念 -
天籁の圁:
你的图全部挂了啊
基于Eclipse的Hadoop应用开发环境的配置 -
landyer:
happinesss 写道你是做java开发的吗我是杂货铺,什 ...
MongoDB1.8安装、分布式自动分片(Auto-Sharding)配置备忘
1.手机信息查看助手可行性分析
开始进入编写程序前,需要对需求的功能做一些可行性分析,以做到有的放矢,如果有些无法实现的功能,可以尽快调整。
这里分析一下项目需要的功能,主要是信息查看和信息收集,如版本信息、硬件信息等,这些都可以通过读取系统文件或者运行系统命令获取,而像获取安装的软件信息和运行时信息则需要通过API提供的接口获取。实现API接口不是什么问题,主要把精力集中在如何实现运行系统命令,获取其返回的结果功能实现上。具体实现代码如下所示:
public class CMDExecute {
public synchronized String run ( String [] cmd,String workdirectory)
throws IOException {
String result = “ ” ;
try {
processBuilder builder = new ProcessBuilder ( cmd );
//设置一个路径
if ( workdirectory ! = null )
builder.directory ( new File ( workdirectory ) ) ;
builder.redirectErrorStream (true) ;
Process process = builder.start ( ) ;
InputStream in = process.getInputStream ( ) ;
byte[] re = new byte[1024] ;
while ( in.read ( re ) ) ;
result = result + new String ( re ) ;
}
in.close ( ) ;
} catch ( Exception ex ) {
Ex.printStackTrace ( ) ;
}
Return result ;
}
}
1.2手机信息查看助手功能实现
1.2.1手机信息查看助手主界面
按照预设的规划,将4类信息的查看入口放在主界面上,其布局文件为mail.xml,基本上是用一个列表组件组成的,实现代码如下所示:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:/orientation="vertical" android:layout_width="fill_parent"
android:layout_height="fill_parent">
<ListView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/itemlist" />
</LinearLayout>
在这里mail.xml中使用的是LinearLayout布局,其中放置了一个ListView组件。
1.2.2查看系统信息实现
当在运行的主界面单击第一行时,也就是“系统信息”这一行,将执行代码如下:
case 0;
intent.setClass(eoeInfosAssistant.this, System.class);
startActivity(intent);
break;
代码运行后将显示系统(System)这个界面,这就是查看系统信息的主界面,其和主界面差不多,也就是列表显示几个需要查看的系统信息,
1.2.2.1操作系统版本
单击图9所示的界面第一行“操作系统版本”项,则会打开一个新的界面,其对应的是ShowInfo.java文件,然后需要显示该设备的操作系统版本信息,而这个信息在/proc/version中有,可以直接调用。在可行性分析中给出的CMDExencute类来调用系统的cat命令获取该文件的内容,实现代码如下:
Public static String fetch_version_info( ) {
String result = null;
CMDExecute cmdexe = new CMDExecute ( );
Try {
String[ ] args = {"/system/bin/cat", "/proc/version" };
result = cmdexe.run(args, "system/bin/");
} catch (IOException ex) {
ex.printStackTrace( );
}
Return result;
}
上述代码使用的是CMDExecute类,调用系统的“"/system/bin/cat"”工具,获取“"/proc/version"”中内容。其运行效果如图9。从图中显示的查寻结果可以看到,这个设备的系统版本是Linux version 2.6.25-018430-gfea26b0。
1.2.2.2系统信息
在Android中,想要获取系统信息,可以调用其提供的方法System.getProperty(propertyStr),而系统信息诸如用户根目录(user.home)等都可以通过这个方法获取,实现代码如下:
private static String initProperty(String description,String propertyStr) {
if (buffer == null) {
buffer = new StringBuffer();
}
buffer.append(description).append(":");
buffer.append (System.getProperty(propertyStr)).append("\n");
return buffer.toString();
}
private static String getSystemProperty() {
buffer = new StringBuffer();
initProperty("java.vendor.url","java.vendor.url");
initProperty("java.class.path","java.class.path");
. . .
return buffer.toString();
}
上述代码主要是通过调用系统提供的System.getProperty方法获取指定的系统信息,并合并成字符串返回。
1.2.2.3运营商信息
运营商信息中包含IMEI、手机号码等,在Android中提供了运营商管理类(TelephonyManager),可以通过TelephonyManager来获取运营商相关的信息,实现的关键代码如下:
public static String fetch_tel_status(Context cx) {
String result = null;
TelephonyManager tm = (TelephonyManager) cx
.getSystemService(Context.TELEPHONY_SERVICE);//
string str = " ";
str += "DeviceId(IMEI) = " + tm.getDetDeviceId() + "\n";
str += "DeviceSoftwareVersion = " + tm.getDeviceSoftwareVersion()+"\n";
. . .
int mcc = cx.getResources().getConfiguration().mcc;
int mcc = cx.getResources().getConfiguration().mcc;
str +="IMSI MCC (Mobile Country Code): " +String.valueOf(mcc) + "\n";
str +="IMSI MCC (Mobile Country Code): " +String.valueOf(mnc) + "\n";
result = str;
return result;
}
在上述的代码中,首先调用系统的getSystemService (Context.TELEPHONY_SERVICE)方法获取一个TelephonyManager对象tm,进而调用其方法getDeviceId()获取DeviceId信息,调用getDeviceSoftware Version()获取设备的软件版本信息等。
1.2.3查看硬件信息
1.2.3.1获取CPU信息
可以在手机设备的/proc/cpuinfo中获取CPU信息,调用CMDEexecute执行系统的cat的命令,读取/proc/cpuinfo的内容,显示的就是其CPU信息,实现代码如下:
public static String fetch_cpu_info() {
String result = null;
CMDExecute cmdexe = new CMDExecute();
try {
String[ ] args = { "/system/bin/cat", "/proc/cpuinfo" }
result = cmdexe.run(args, "/system/bin/");
Log.i("result","result=" + result);
} catch (IOException ex) {
ex.printStackTrace();
}
return result;
}
上述代码使用CMDExecute,调用系统中的"/system/bin/cat"命令查看"/proc/cpuinfo"中的内容,即可得到CPU信息。
1.2.3.2获取内存信息
获取内存信息的方法和获取CPU信息的实现差不多,可以读取/proc/meminfo信息,另外还可以通过getSystemService(Context.ACTIVIT_SERV-
ICE)获取ActivityManager.MemoryInfo对象,进而获取可用内存信息,主要代码如下:
/**
*系统内存情况查看
*/
public static String getMemoryInfo(Context context) {
StringBuffer memoryInfo = new StringBuffer();
final ActivityManager activityManager = (AcctivityManager) context
.getSystemService(Context.ACTIVITY_SERVICE);
ActivityManager. MemoryInfo outInfo = new ActivityManager. MemoryInfo();
activityManager.getMemoryInfo(outInfo);
memoryInfo.append("\nTotal Available Memory :").append(
outInfo.availMem >> 10).append("k");
memoryInfo.append("\nTotal Available Memory :").append(
outInfo.availMem >> 20).append("k");
memoryInfo.append("\nIn low memory situation:").append(
outInfo. Lowmemory);
String result = null;
CMDExecute cmdexe = new CMDExecute();
try {
String[ ] args = { "/system/bin/cat", "/proc/meminfo" };
result = cmdexe.run(args, "/system/bin/");
} catch (IOException ex) {
Log.i("fetch_process_info","ex=" + ex.toString());
}
Return memoryInfo.toString()+"\n\n"+result;
}
上述代码中首先通过ActivityManager对象获取其可用的内存,然后通过查看“/proc/meminfo”内容获取更详细的信息。
1.2.3.3获取磁盘信息
手机设备的磁盘信息可以通过df命令获取,所以,这里获取磁盘信息的方法和前面类似,惟一不同的是,这个是直接执行命令,获取其命令的返回就可以了,关键代码如下:
//磁盘信息
public static String fetch_disk_info() {
String result = null;
CMDExecute cmdexe = new CMDExecute();
try {
String[ ] args = { "/system/bin/df"}
result = cmdexe.run(args, "/system/bin/");
Log.i("result","result=" + result);
} catch (IOException ex) {
ex.printStackTrace();
}
return result;
}
1.2.3.4获取网络信息
要获取手机设备的网络信息,只要读取/system/bin/netcfg中的信息就可以了,关键代码如下:
public static String fetch_netcfg_info() {
String result = null;
String result = null;
CMDExecute cmdexe = new CMDExecute();
try {
String[ ] args = { "/system/bin/netcfg"}
result = cmdexe.run(args, "/system/bin/");
} catch (IOException ex) {
Log.i("fetch_process_info","ex=" + ex.toString());
}
return result;
}
1.2.3.5获取显示频信息
除了显示手机的CPU、内存、磁盘信息外,还有个非常重要的硬件,显示频。在Android中,它提供了DisplayMetrics类,可以通过getApplication Context()、getResources()、getDisplayMetrics()初始化,进而读取其屏幕宽(widthPixels)、高(heightPixels)等信息,实现的关键代码如下:
public static String getDisplayMetrics(Context cx) {
String str = " ";
DisplayMetrics dm = new DisplayMetrics();
dm = cx.getApplicationContext().getResources().getDisplayMetrics();
int screenWidth = dm.widthPixels;
int screenHeight = dm.heightPixels;
float density = dm.density;
float xdpi = dm.xdpi;
float ydpi = dm.ydpi;
str += "The absolute width: " + String.valueOf(screenWidth) + "pixels\n";
str += "The absolute heightin: " + String.valueOf(screenHeight) + "pixels\n";
str += "The logical density of the display. : " + String.valueOf(density) + "\n";
str += "X dimension : " + String.valueOf(xdpi) +"pixels per inch\n";
str += "Y dimension : " + String.valueOf(ydpi) +"pixels per inch\n";
renturn str;
}
1.2.4查看软件信息
在Android上,可以在手机上随便安装自己喜欢的应用软件,查看软件信息的功能就是收集并显示已经安装的应用软件信息。
在Android中,它提供了getPackageManager()、getInstalledApplications(0)方法,可以直接返回全部已经安装的应用列表。这个功能就是只需要获取列表,再进行显示在列表中就可以了。但是,如果安装的软件比较多,那么获取信息所花费的时间会比较多,为了更好地完善用户使用的体验,在获取列表时,需要在界面提示用户耐心等待,这就需要用到Android提供的另外一个功能Runnable。
引入Runnable比较简单,只需要在定义类的时候实现Runnable接口就可以了,所以,这里的软件信息查看界面对应的Software.java类声明代码如下:
public class Software extends Activity implements Runnable {
. . .
}
然后需要在这个Activity启动的时候,引入进度条ProgressDialog来显示一个提示界面,onCreate代码如下所示:
Public void onCreate(Bundle icicle) {
Super.onCreate(icicle);
setContentView(R.layout.softwares);
setTitle("软件信息")
itemlist = (ListView) findViewById(R.id.itemlist);
pd = ProgressDialog.show(this, "请稍候. .", "正在收集你已经安装的软件信息. . .", true,flase);
Thread thread = new Thread(this);
Thread.start();
}
该方法创建了一个ProgressDialog,并设定其提示信息。然后实现其线程的run()方法,该方法实现其真正执行的逻辑,实现代码如下:
@Override
Public void run() {
fetch_installed_apps();
handler.sendEmptyMessage(0);
}
上述代码调用自定义的fetch_installed_app()方法获取已经安装的应用信息,这个方法是比较消耗时间的,实现代码如下:
public List fetch_installed_apps () {
List<ApplicationInfo> packages = getPackageManager().getInstalledApplications(0);
list = new ArrayList<Ma<String, Object>>(
packages.size());
Iterator<ApplicationInfo> l = packages.iterator();
while (l.hasNext()) {
Map<String, Object> map = new HashMap<String, Object>();
ApplicationInfo app = (ApplicationInfo) l.next();
String packageName = app.packageName;
String label = " ";
try {
label = getPackageManager().getApplicationLabel(app).toString();
} catch (Exception e) {
Log.i("Exception", e.toString());
}
map = new HashMap<String, Object>();
map.put("name", label);
map.put("desc", packageName);
list.add(map);
}
Return list;
}
上述代码使用getPackageManager().getInstalledApplications(0)获取已经安装的软件信息,进而构造用来显示的列表(List)对象,同时,界面通过进度条(ProgressDialog)显示提示信息,运行效果如图18所示。
当这个方法运行完成后,会调用handler.sendEmptyMessage(0)语句给handler发送一个通知消息,使其执行下面的动作,下面就是这个handler的实现方法:
private Handler handler = new Handler() {
public void handleMessage msg) {
refreshListItems();
pd.dismiss();
}; }
上述代码中,当其接收到run()线程传递的消失后,先调用refreshListItems()方法显示列表,最后调用进度条ProgressDialog的dismiss方法使其等待提示消失。而refreshListItems()的实现代码如下:
private void refreshListItems() {
list = fetch_installed_apps();
SimpleAdapter notes = new SimpleAdater(this, list, R.layout.info_row,
New String[ ] { "name", "desc" },new int[ ] { R.id.name,
R.id.desc });
Itemlist.setAdapter(notes);
setTitle("软件信息,已经安装"+list.size()+"款应用.");
}
这些代码,显示已经安装的应用列表的同时,在Title上显示一共安装了多少款应用
1.2.5获取运行时信息
运行时的一些信息,包括后台运行的Service、Task,以及进程信息,其运行界面如图20。
1.2.5.1获取正在运行的Service信息
可以通过调用context.getSystemService(Context.ACTIVITY_SERVICE)获取ActivityManager,进而通过系统提供的方法getRunningServices(int maxNum)获取正在运行的服务列表(RunningServiceInfo),再对其结果进一步分析,得到服务对应的进程名及其他信息,实现的关键代码如下:
//正在运行的服务列表
public static String getRunningServicesInfo(Context context) {
StringBuffer serviceInfo = new StringBuffer();
final ActivityManager activityManager = (ActivityManager) context
.getSystemService(Context. ACTIVITY_SERVICE);
List<RunningServiceInfo> services = activityManager.getRunningServices(100);
Iterator<RunningserviceInfo> l = services.iterator();
while (l.hasNext()) {
RunningServiceInfo si = (RunningServiceInfo) l.next();
serviceInfo.append("pid: ").append(si.pid);
serviceInfo.append("\nprocess: ").append(si. process);
serviceInfo.append("\nservice: ").append(si. service);
serviceInfo.append("\ncrashCount: ").append(si. crashCount);
serviceInfo.append("\nclicentCount: ").append(si. clicentCount);
serviceInfo.append("\nactiveSince:").append(ToolHelper.formatData(si.activeSince));
serviceInfo.append("\nlastActivityTime: ").append(ToolHelper.formatData(si.lastAct-
ivityTime));
serviceInfo.append("\n\n ");
}
return serviceInfo.toString();
}
上述代码调用activityManager.getRunningServices(100)获取正在运行的服务,并依次遍历得到每个服务对应的pid,进程等信息,
1.2.5.2获取正在运行的Task信息
获取正在运行的Task信息调用的是activityManager.getRunningTasks(int maxNum)来获取对应的正在运行的任务信息列表(RunningTaskInfo),进而分析、显示任务信息,其关键代码如下:
public static String getRunningTaskInfo(Context context) {
StringBuffer sInfo = new StringBuffer();
final ActivityManager activityManager = (ActivityManager) context
.getSystemService(Context. ACTIVITY_SERVICE);
List<RunningTaskInfo> tasks = activityManager.getRunningTasks(100);
Iterator<RunningTaskInfo> l = tasks.iterator();
while (l.hasNext()) {
RunningTaskInfo ti = (RunningTaskInfo) l.next();
sInfo.append("id: ").append(ti.id);
sInfo.append("\nbaseActivity: ").append(ti. baseActivity.flattenToString());
sInfo.append("\nnumActivities: ").append(ti. nnumActivities);
sInfo.append("\nnumRunning: ").append(ti. numRunning);
sInfo.append("\ndescription: ").append(ti. description);
sInfo.append("\n\n);
}
Return sInfo.toString();
}
上述代码调用系统提供的activityManager.getRunningTasks(100)方法获取任务列表,依次获取对应的id等信息,运行效果如图22。从图中显示可以看出,获取手机上正在运行的Task的列表和其对应的进程信息,这对用户了解设备运行情况非常有用。
1.2.5.3获取正在运行的进程信息
该段程序是通过CMD Executo的方式来运行系统命令。关键代码如下:
public static String fetch_process_info() {
Log.i("fetch_process_info","start. . . . ");
String result = null;
CMDExecutr cmdexe = new CMDExecute();
try {
String [ ] args = { "/system/bin/top", "-n", "l" };
result = cmdexe.run(args, "/system/bin/");
} catch (IOException ex) {
Log.i("fetch_process_info","ex=" + ex.toString());
}
return result;
}
通过这个功能可以非常详细地了解到正在运行的进程和各个进程所消耗的资源情况。
1.2.6文件浏览器
文件浏览器的这个功能,用户可以遍历浏览整个文件系统,以便更好地了解手机设备状况。在主界面单击最后一行将执行下列代码:
case 4:
intent.setClass(eoeInfosAssistant.this, FSExplorer.class);
startActivity(intent);
break;
对于如何进入子目录,并获取和显示其内部的文件夹和文件,也就是单击每行时响应的实现,代码如下:
@Override
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
Log.i(TAG, "item clicked! [" + position + "]");
if (position == 0) {
path = "/";
refreshListItems(path);
}else if(position ==1) {
goToParent();
} else {
path = (String) list.get(position).get("path");
File file = new File(path);
if (file.isDirectory())
refreshListItems(path);
else
Toast.makeText(FSExplorer.this,
getString(R.string.is_file)’
Toast.LENGTH_SHORT).show();
}
}
2. Android编程获取手机型号,網絡類型,本机电话号码,sdk版本及firmware版本号(即系统版本号)
Android开发平台中,可通过TelephonyManager获取本机号码。
TelephonyManager phoneMgr=(TelephonyManager)this.getSystemService(Context.TELEPHONY_SERVICE);
txtPhoneNumber.setText(phoneMgr.getLine1Number()); //txtPhoneNumber是一个EditText 用于显示手机号
注:
根据Android的安全机制,在使用TelephonyManager时,必须在AndroidManifest.xml中添加<uses-permission android:name="READ_PHONE_STATE" /> 否则无法获得系统的许可。
private void loadPhoneStatus()
{
TelephonyManager phoneMgr=(TelephonyManager)this.getSystemService(Context.TELEPHONY_SERVICE);
int mNetworkType = mManager.getNetworkType();//獲取網絡類型
txtPhoneModel.setText(Build.MODEL); //手机型号
txtPhoneNumber.setText(phoneMgr.getLine1Number());//本机电话号码
txtSdkVersion.setText(Build.VERSION.SDK);//SDK版本号
txtOsVersion.setText(Build.VERSION.RELEASE);//Firmware/OS 版本号
}
Build能向我们提供包括 硬件厂商,硬件编号,序列号等很多信息 调用方法也都同上.
3. 得到系統的一些相關的屬性,通過調用 System.getProperties(); 來獲取
02-09 02:24:55.863: INFO/Tag(661): System Property: {java.vm.version=1.2.0
02-09 02:24:55.863: INFO/Tag(661): System Property: java.vendor.url=http://www.android.com/
02-09 02:24:55.863: INFO/Tag(661): System Property: java.vm.vendor.url=http://www.android.com/
02-09 02:24:55.863: INFO/Tag(661): System Property: user.dir=/
02-09 02:24:55.872: INFO/Tag(661): System Property: java.vm.name=Dalvik
02-09 02:24:55.872: INFO/Tag(661): System Property: java.home=/system
02-09 02:24:55.872: INFO/Tag(661): System Property: user.region=US
02-09 02:24:55.872: INFO/Tag(661): System Property: javax.net.ssl.trustStore=/system/etc/security/cacerts.bks
02-09 02:24:55.872: INFO/Tag(661): System Property: java.runtime.name=Android Runtime
02-09 02:24:55.882: INFO/Tag(661): System Property: user.home=
02-09 02:24:55.882: INFO/Tag(661): System Property: java.io.tmpdir=/sdcard
02-09 02:24:55.882: INFO/Tag(661): System Property: http.agent=Dalvik/1.2.0 (Linux; U; Android 2.2; google_sdk Build/FRF91)
02-09 02:24:55.882: INFO/Tag(661): System Property: java.net.preferIPv6Addresses=true
02-09 02:24:55.882: INFO/Tag(661): System Property: java.version=0
02-09 02:24:55.882: INFO/Tag(661): System Property: java.boot.class.path=/system/framework/core.jar:/system/framework/ext.jar:/system/framework/framework.jar:/system/framework/android.policy.jar:/system/framework/services.jar
02-09 02:24:55.882: INFO/Tag(661): System Property: java.library.path=/system/lib
02-09 02:24:55.882: INFO/Tag(661): System Property: file.separator=/
02-09 02:24:55.882: INFO/Tag(661): System Property: java.specification.vendor=The Android Project
02-09 02:24:55.894: INFO/Tag(661): System Property: file.encoding=UTF-8
02-09 02:24:55.894: INFO/Tag(661): System Property: line.separator=
02-09 02:24:55.894: INFO/Tag(661): System Property: java.vm.specification.version=0.9
02-09 02:24:55.894: INFO/Tag(661): System Property: java.vm.specification.vendor=The Android Project
02-09 02:24:55.894: INFO/Tag(661): System Property: os.name=Linux
02-09 02:24:55.894: INFO/Tag(661): System Property: java.vm.vendor=The Android Project
02-09 02:24:55.894: INFO/Tag(661): System Property: path.separator=:
02-09 02:24:55.904: INFO/Tag(661): System Property: android.vm.dexfile=true
02-09 02:24:55.904: INFO/Tag(661): System Property: java.ext.dirs=
02-09 02:24:55.904: INFO/Tag(661): System Property: java.class.path=.
02-09 02:24:55.904: INFO/Tag(661): System Property: os.version=2.6.29-00261-g0097074-dirty
02-09 02:24:55.904: INFO/Tag(661): System Property: java.specification.name=Dalvik Core Library
02-09 02:24:55.904: INFO/Tag(661): System Property: java.compiler=
02-09 02:24:55.913: INFO/Tag(661): System Property: user.language=en
02-09 02:24:55.913: INFO/Tag(661): System Property: user.name=
02-09 02:24:55.913: INFO/Tag(661): System Property: os.arch=armv5tejl
02-09 02:24:55.913: INFO/Tag(661): System Property: java.runtime.version=0.9
02-09 02:24:55.913: INFO/Tag(661): System Property: java.class.version=46.0
02-09 02:24:55.913: INFO/Tag(661): System Property: java.vendor=The Android Project
02-09 02:24:55.923: INFO/Tag(661): System Property: java.vm.specification.name=Dalvik Virtual Machine Specification
02-09 02:24:55.923: INFO/Tag(661): System Property: java.specification.version=0.9}
4. 得到鍵盤信息,使用的語言,手機的網絡代碼(mnc),手機的國家代碼(mcc),手機的模式,手機的方向,觸摸屏的判斷等,通過以下語句獲取: Configuration config = getResources().getConfiguration();
這些屬性都在config的屬性變量中進行判斷。
发表评论
-
Android游戏开发之Tween动画的实现
2011-12-19 22:51 1640今天和大伙讨论一下Android开发中的Tween动画 ... -
Android 动画之Tween动画详细讲解及java源码实现
2011-12-19 22:43 1636Tween动画又称“补间动画”、“中间动画”,这并不重要,就好 ... -
Android Animation Tween动画效果的使用
2011-12-19 22:40 1625Animation Tween动画可以通过java代码实现,也 ... -
Android自定义控件-ReflectionImage
2011-12-17 12:31 1007ReflectionImage是一个有倒影效果的图片.先 ... -
一个用java读取XML文件的简单方法
2011-08-14 20:02 1084XML文件 book.xml <book& ... -
android SAX
2011-08-14 19:17 785SAXBuilder builder = new SAX ... -
Android DOM 解析 xml
2011-08-11 09:34 1135原文地址:http://blog.163.com/joe_zh ... -
Android开发中保存数据的四种方法方法
2011-07-28 22:31 891在Android开发中我们会接触到四种数据存储方式,每种存储方 ... -
android读取原始的xml文件
2011-04-24 15:45 1423项目中经常会用到一些原始的xml文件,那么我们可以定义 ... -
Android开发必备武器,处理XML的利器--SAX快速上手
2011-04-24 10:00 699相信各位android开发者,对SAX已经并不陌生了,SAX( ... -
三个特殊的资源目录 /res/xml /res/raw 和 /assets
2011-04-24 09:50 859原帖地址:http://www.eoeandroid.com/ ...
相关推荐
在Android系统中,读取系统参数是一项常见的任务,特别是在开发应用程序时,可能需要获取设备的各种信息,如硬件配置、系统版本、设备标识等。本文将详细介绍如何在Android中读取这些系统参数,并提供一个名为“项目...
Android系统原生并不直接支持串口通信,因为其主要设计为移动设备操作系统,考虑到电池续航和安全性,不开放低级硬件接口。然而,通过JNI(Java Native Interface)或第三方库,开发者可以实现串口通信功能。 二、...
在Android/Linux系统中,读取硬件寄存器的值是一项重要的任务,特别是在设备驱动开发、系统调试和性能优化中。`devmem`工具是Linux内核提供的一种实用程序,允许用户空间程序直接访问物理内存,从而能够读写特定地址...
在Android系统中,读取和拨打电话联系人是常见的功能,尤其对于开发者来说,理解这一过程对于构建涉及通讯录管理的应用至关重要。这篇博客主要探讨如何通过源码来实现这一功能,我们将深入Android的API和权限管理...
总的来说,"读取cache信息 android系统 三星Nexus S"这个主题涉及了Android系统中缓存的基本知识、内核驱动的使用以及如何通过C语言程序获取和解析这些信息。这对于开发高性能、低功耗的Android应用至关重要。
在Android Studio中进行安卓实验,查看系统短信是一个常见的学习任务,它涉及到Android系统的权限管理、内容提供者(Content Provider)以及SQLite数据库的操作。这个实验旨在帮助开发者了解如何访问和读取设备上的...
这份"安卓Android源码——安卓Android系统访问串口设备源码.rar"压缩包提供了相关的源代码和资料,帮助开发者理解和实现这一功能。 首先,我们需要了解的是Android系统对串口的支持。在Linux内核的基础上构建的...
- 由于Android系统的权限控制,可能在部分设备上无法正常工作,需要做好兼容性测试。 综上所述,实现“Android即时读取短信内容”功能,主要涉及权限管理、广播接收器的创建与注册、短信数据的解析以及业务逻辑...
在安卓Android系统中,日历和日程管理是用户日常使用的重要功能之一。这份压缩包文件"安卓Android源码——安卓Android系统日历日程操作.zip"包含了与Android日历API相关的源代码,用于理解如何在Android应用中进行...
9. **SQLite数据库**:Android系统自带SQLite数据库,`SQLiteOpenHelper`类用于数据库的创建和版本管理,`SQLiteDatabase`类提供CRUD(创建、读取、更新、删除)操作。 10. **SharedPreferences**:...
在Android系统中,GPS(全球定位系统)是一个关键的组件,用于获取设备的位置信息。"Android GPS读取框架"是一个专为Android应用设计的库,它简化了从GPS接收器连续读取位置数据的过程。这个框架适用于那些需要实时...
这个类可能会包含初始化串口、设置波特率、数据位、奇偶校验、停止位等参数的方法,以及读取和写入数据的函数。这些函数通常会调用Linux系统调用来实现,比如`open()`、`write()`、`read()`、`ioctl()`等。 在...
在Android系统中,读取短信是一项常见的功能,尤其对于开发者来说,可能需要通过程序来获取短信数据进行分析或实现特定的业务逻辑。本篇将详细讲解如何在Android中读取短信,以及涉及到的相关知识点。 首先,我们...
首先,Android系统提供了LocationManager服务来获取位置信息,包括GPS数据。开发者需要在AndroidManifest.xml文件中添加必要的权限,如`<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /...
Android提供了一个ContentResolver接口,用于与系统的内容提供者进行交互,如通讯录。ContactsContract类是Android中用于访问联系人数据的类,它包含了一系列常量和类,用于构建查询语句。 3. **查询联系人数据**...
Assets适合存放那些需要动态加载或不需要系统资源管理器处理的文件,比如游戏数据包、自定义字体、大型文本数据等。而Raw则适用于小型静态资源,如音乐片段、短音频等,这些资源通常在应用启动时就已经明确需要,...
在Android系统中,读取手机联系人是一项常见的功能,它涉及到Android的核心组件——ContentProvider。ContentProvider是Android四大组件之一,用于在不同的应用程序之间共享数据。在这个场景下,我们将主要探讨如何...
ContentResolver是Android系统提供的一个接口,它允许应用程序与系统内容提供者进行交互,而通讯录就是由Android内置的一个内容提供者管理。 首先,我们需要在AndroidManifest.xml文件中添加读取联系人权限,这是...
* -system <dir>:指定系统镜像文件的读取目录。 * -datadir <dir>:指定用户数据的写入目录。 * -kernel <file>:指定模拟器使用的内核文件。 * -ramdisk <file>:指定 RAM 磁盘镜像文件。 * -image <file>:指定...