Android 开发之旅:短信的收发及在android模拟器之间实践(一)

简介:

引言

本文通过运行两个Android模拟器,介绍在Android中如何实现短信服务(SMS,short message service)的功能。通过这个例子,我想带给大家的是:更加熟悉之前介绍过的Android应用程序的概念及技术细节,且通过实例调度大家的兴趣。我之所以选择SMS为例子,主要原因是SMS已经非常成熟了,从中可以发掘更多的信息和技术细节,而且我相信大部分人发短信比打电话多。

本文的主要内容如下:

  1. 1、温故知新
  2. 2、准备工作:SMS涉及的主要类SmsManager
  3. 3、简单的SMS发送程序
    1. 3.1、运行SMS程序给另一个android模拟器发短
  4. 4、SMS增强(一)
  5. 5、SMS增强(二)
  6. 6、SMS接收程序(下篇)
  7. 7、emulator工具(下篇)
  8. 8、…

1、温故知新

广播接收者:一个广播接收者是这样一个组件,它不做什么事,仅是接受广播公告并作出相应的反应。许多广播源自于系统代码,例如公告时区的改变、电池电量低、已采取图片、用户改变了语言偏好。应用程序也可以发起广播,例如为了他其他程序知道某些数据已经下载到设备且他们可以使用这些数据

BroadcastReceiver类:是接受sendBroadcast()发送的意图(intents)的基类。可以用Context.registerReceiver()动态地注册这个类的实例,或者通过AndroidManifest.xml中<receiver>标签静态发布。

广播接收者不显示一个用户界面。然而,它们启动一个活动去响应收到的信息,或者他们可能使用NotificationManager去通知用户。通知可以使用多种方式获得用户的注意——闪烁的背光、振动设备、播放声音等等。典型的是放在一个持久的图标在状态栏,用户可以打开获取信息。

2、准备工作:SMS涉及的主要类SmsManager

实现SMS主要用到SmsManager类,该类继承自java.lang.Object类,下面我们介绍一下该类的主要成员。

公有方法:

  1. ArrayList<String> divideMessage(String text) 
    当短信超过SMS消息的最大长度时,将短信分割为几块。 
    参数text——初始的消息,不能为空 
    返回值:有序的ArrayList<String>,可以重新组合为初始的消息
  2. static SmsManager getDefault() 
    获取SmsManager的默认实例。 
    返回值SmsManager的默认实例
  3. void SendDataMessage(String destinationAddress, String scAddress, short destinationPort, byte[] data, PendingIntent sentIntent, PendingIntent deliveryIntent) 
    发送一个基于SMS的数据到指定的应用程序端口。 
    参数: 
    1)、destinationAddress——消息的目标地址 
    2)、scAddress——服务中心的地址or为空使用当前默认的SMSC 3)destinationPort——消息的目标端口号 
    4)、data——消息的主体,即消息要发送的数据 
    5)、sentIntent——如果不为空,当消息成功发送或失败这个PendingIntent就广播。结果代码是Activity.RESULT_OK表示成功,或RESULT_ERROR_GENERIC_FAILURE、RESULT_ERROR_RADIO_OFF、RESULT_ERROR_NULL_PDU之一表示错误。对应RESULT_ERROR_GENERIC_FAILURE,sentIntent可能包括额外的“错误代码”包含一个无线电广播技术特定的值,通常只在修复故障时有用。 
    每一个基于SMS的应用程序控制检测sentIntent。如果sentIntent是空,调用者将检测所有未知的应用程序,这将导致在检测的时候发送较小数量的SMS。 
    6)、deliveryIntent——如果不为空,当消息成功传送到接收者这个PendingIntent就广播。
    异常:如果destinationAddressdata是空时,抛出IllegalArgumentException异常。
  4. void sendMultipartTextMessage(String destinationAddress, String scAddress, ArrayList<String> parts, ArrayList<PendingIntent> sentIntents, ArrayList<PendingIntent>  deliverIntents) 
    发送一个基于SMS的多部分文本,调用者应用已经通过调用divideMessage(String text)将消息分割成正确的大小。 
    参数: 
    1)、destinationAddress——消息的目标地址 
    2)、scAddress——服务中心的地址or为空使用当前默认的SMSC 
    3)、parts——有序的ArrayList<String>,可以重新组合为初始的消息 
    4)、sentIntents——跟SendDataMessage方法中一样,只不过这里的是一组PendingIntent 
    5)、deliverIntents——跟SendDataMessage方法中一样,只不过这里的是一组PendingIntent 
    异常:如果destinationAddressdata是空时,抛出IllegalArgumentException异常。
  5. void sendTextMessage(String destinationAddress, String scAddress, String text, PendingIntent sentIntent, PendingIntent deliveryIntent) 
    发送一个基于SMS的文本。参数的意义和异常前面的已存在的一样,不再累述。

常量:

  1. public static final int RESULT_ERROR_GENERIC_FAILURE 
    表示普通错误,值为1(0x00000001)
  2. public static final int RESULT_ERROR_NO_SERVICE 
    表示服务当前不可用,值为4 (0x00000004)
  3. public static final int RESULT_ERROR_NULL_PDU 
    表示没有提供pdu,值为3 (0x00000003)
  4. public static final int RESULT_ERROR_RADIO_OFF 
    表示无线广播被明确地关闭,值为2 (0x00000002)
  5. public static final int STATUS_ON_ICC_FREE 
    表示自由空间,值为0 (0x00000000)
  6. public static final int STATUS_ON_ICC_READ 
    表示接收且已读,值为1 (0x00000001)
  7. public static final int STATUS_ON_ICC_SENT 
    表示存储且已发送,值为5 (0x00000005)
  8. public static final int STATUS_ON_ICC_UNREAD 
    表示接收但未读,值为3 (0x00000003)
  9. public static final int STATUS_ON_ICC_UNSENT 
    表示存储但为发送,值为7 (0x00000007)

3、简单的SMS发送程序

1)、首先,编辑布局文件res/layout/main.xml,达到我们想要的结果,界面如下:

Android 开发之旅:短信的收发及在android模拟器之间实践(一)

图1、程序运行界面

 对应的xml代码如下:

 
  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:orientation="vertical"   
  4.     android:layout_width="fill_parent" 
  5.     android:layout_height="fill_parent" > 
  6.     <TextView android:layout_width="fill_parent" 
  7.             android:layout_height="wrap_content"   
  8.             android:text="@string/txtPhoneNo"/>    <!-- text's value define in res/values/strings.xml --> 
  9.       
  10.     <EditText android:layout_width="fill_parent" 
  11.             android:layout_height="wrap_content" 
  12.             android:id="@+id/edtPhoneNo"/> 
  13.       
  14.     <TextView android:layout_width="fill_parent" 
  15.             android:layout_height="wrap_content" 
  16.             android:text="@string/txtContent"/> 
  17.       
  18.     <EditText android:layout_width="fill_parent" 
  19.             android:layout_height="wrap_content" 
  20.             android:minLines="3" 
  21.             android:id="@+id/edtContent"/> 
  22.      
  23.     <Button android:layout_width="wrap_content" 
  24.             android:layout_height="wrap_content" 
  25.             android:text="@string/btnText" 
  26.             android:id="@+id/btnSend"/> 
  27. </LinearLayout> 

相应的要在res/values/strings.xm中添加上面定义的视图的text的值,如下:

 
  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <resources> 
  3.     <string name="txtPhoneNo">Please input phone NO:</string> 
  4.     <string name="txtContent">Please input SMS\'s content:</string> 
  5.     <string name="btnText">send!</string> 
  6.     <string name="app_name">SMS</string> 
  7. </resources> 

2)、做完这些准备工作之后,我么要开始编写代码实现简单的短信发送了。

通过第一步我们构建好界面之后,现在要在上面的基础上编写业务逻辑了。大致过程为:在java源文件中,获取用户在edtPhoneNo中输入的电话号码,edtContent中输入要发送的内容;然后点击btnSend按钮发送短信,要达到这个目的我们要设置btnSend的OnClickListener以达到当点击它触发发送短信的功能,而且要发送短信就要用到我们前面介绍的SmsManager类提供的方法接口。

设置btnSend的OnClickListener的代码如下:

 
  1. btnSend.setOnClickListener(new View.OnClickListener() {  
  2.     public void onClick(View v) {  
  3.         String phoneNo = edtPhoneNo.getText().toString();  
  4.         String message = edtContent.getText().toString();  
  5.         if (phoneNo.length() > 0 && message.length() > 0){  
  6.             //call sendSMS to send message to phoneNo  
  7.             sendSMS(phoneNo, message);  
  8.         }  
  9.         else 
  10.             Toast.makeText(getBaseContext(),  
  11.                 "Please enter both phone number and message.",  
  12.                 Toast.LENGTH_SHORT).show();  
  13.     }  
  14. }); 

发送短信的功能的代码如下:

 
  1. private void sendSMS(String phoneNumber, String message) {  
  2.     // ---sends an SMS message to another device---  
  3.     SmsManager sms = SmsManager.getDefault();  
  4.     PendingIntent pi = PendingIntent.getActivity(this0,                new Intent(this,TextMessage.class), 0);  
  5.     //if message's length more than 70 ,  
  6.     //then call divideMessage to dive message into several part         //and call sendTextMessage()  
  7.     //else direct call sendTextMessage()  
  8.     if (message.length() > 70) {  
  9.         ArrayList<String> msgs = sms.divideMessage(message);  
  10.         for (String msg : msgs) {  
  11.             sms.sendTextMessage(phoneNumber, null, msg, pi, null);  
  12.         }  
  13.     } else {  
  14.         sms.sendTextMessage(phoneNumber, null, message, pi, null);  
  15.     }  
  16.     Toast.makeText(TextMessage.this"短信发送完成", Toast.LENGTH_LONG).show();  

如果你已经看了第2节介绍的SmsManager类的介绍,代码应该很好理解。在这里要说明的是,sendTextMessage方法中的第4个和第5个参数PendingIntent设为null,这样的话不能根据短信发出之后的状态做相应的事情,如短信发送失败后的提醒、接收者成功接收后的回执……完整的流程源码如下:

 
  1. package skynet.com.cnblogs.www;  
  2.  
  3. import java.util.ArrayList;  
  4.  
  5. import android.app.Activity;  
  6. import android.app.PendingIntent;  
  7. import android.content.Intent;  
  8. import android.os.Bundle;  
  9. import android.telephony.SmsManager;  
  10. import android.view.View;  
  11. import android.widget.*;  
  12.  
  13. public class TextMessage extends Activity {  
  14.     /** Called when the activity is first created. */ 
  15.     @Override 
  16.     public void onCreate(Bundle savedInstanceState) {  
  17.         super.onCreate(savedInstanceState);  
  18.  
  19.         setContentView(R.layout.main);  
  20.         btnSend = (Button) findViewById(R.id.btnSend);  
  21.         edtPhoneNo = (EditText) findViewById(R.id.edtPhoneNo);  
  22.         edtContent = (EditText) findViewById(R.id.edtContent);  
  23.  
  24.         btnSend.setOnClickListener(new View.OnClickListener() {  
  25.             public void onClick(View v) {  
  26.                 String phoneNo = edtPhoneNo.getText().toString();  
  27.                 String message = edtContent.getText().toString();  
  28.                 if (phoneNo.length() > 0 && message.length() > 0) {  
  29.                     // call sendSMS to send message to phoneNo  
  30.                     sendSMS(phoneNo, message);  
  31.                 } else 
  32.                     Toast.makeText(getBaseContext(),  
  33.                             "Please enter both phone number and message.",  
  34.                             Toast.LENGTH_SHORT).show();  
  35.             }  
  36.         });  
  37.     }  
  38.  
  39.     private Button btnSend;  
  40.     private EditText edtPhoneNo;  
  41.     private EditText edtContent;  
  42.  
  43.     private void sendSMS(String phoneNumber, String message) {  
  44.         // ---sends an SMS message to another device---  
  45.         SmsManager sms = SmsManager.getDefault();  
  46.         PendingIntent pi = PendingIntent.getActivity(this0new Intent(this,  
  47.                 TextMessage.class), 0);  
  48.         // if message's length more than 70 ,  
  49.         // then call divideMessage to dive message into several part ,and call  
  50.         // sendTextMessage()  
  51.         // else direct call sendTextMessage()  
  52.         if (message.length() > 70) {  
  53.             ArrayList<String> msgs = sms.divideMessage(message);  
  54.             for (String msg : msgs) {  
  55.                 sms.sendTextMessage(phoneNumber, null, msg, pi, null);  
  56.             }  
  57.         } else {  
  58.             sms.sendTextMessage(phoneNumber, null, message, pi, null);  
  59.         }  
  60.         Toast.makeText(TextMessage.this"短信发送完成", Toast.LENGTH_LONG).show();  
  61.     }  

3)运行前,还要在清单文件AndroidManifest.xml中加入允许发送短信的权限:

 
  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android" 
  3.       package="skynet.com.cnblogs.www" 
  4.       android:versionCode="1" 
  5.       android:versionName="1.0"> 
  6.     <application android:icon="@drawable/icon" android:label="@string/app_name"> 
  7.         <activity android:name=".TextMessage" 
  8.                   android:label="@string/app_name"> 
  9.             <intent-filter> 
  10.                 <action android:name="android.intent.action.MAIN" /> 
  11.                 <category android:name="android.intent.category.LAUNCHER" /> 
  12.             </intent-filter> 
  13.         </activity> 
  14.  
  15.     </application> 
  16.     <uses-permission android:name="android.permission.SEND_SMS"/> 
  17. </manifest>  

3.1、运行SMS程序给另一个android模拟器发短信

运行上面我们编写的TextMessage程序,另外在Windows的命令行下切换到tools目录下,并输入emulator –data smsReceiver,我的如下:

Android 开发之旅:短信的收发及在android模拟器之间实践(一)

这样就会启动一个android模拟器,如下所示:(注意它的编号:5556,就是用这个编号与它通信的

Android 开发之旅:短信的收发及在android模拟器之间实践(一)

图2、通过emulator启动一个android模拟器

通过我们TextMessage程序启动的android模拟器,编写短信:

Android 开发之旅:短信的收发及在android模拟器之间实践(一)

图3、TextMessage程序个5556模拟器发短信

点击发送之后,通过命令行启动的5556号android模拟器会收到我们刚才发送的短信,如下所示:

Android 开发之旅:短信的收发及在android模拟器之间实践(一)

图4、收到短信的提示

tips:

如果通过命令行的emulator启动android模拟器提示“NO DNS servers found!”,这时我们发的短信模拟器是收不到的。

  1. 在Windows下,如果电脑没有介入网络,即找不DNS服务器的话会出现这种情况!
  2. 在Mac下,如果提示这个警告的话,可以这样解决:检查你是否有 /etc/resolv.conf文件,如果没有的话,通过下面的命令行
    ln -s /private/var/run/resolv.conf /etc/resolv.conf可以解决。

4、SMS增强(一)

上面我们实现了一个简单的SMS程序,下面我们要对它进行增强!你肯定已经注意到了,我们上面的SMS程序的sendTextMessage方法中的第4个和第5个参数PendingIntent设为null,即sentIntent和deliveryIntent。

第4个参数-sendIntent,当消息成功发送或发送失败都将被触发。广播接收者的结果码,Activity.RESULT_OK表示成功,或RESULT_ERROR_GENERIC_FAILURE、RESULT_ERROR_RADIO_OFF、RESULT_ERROR_NULL_PDU之一表示错误。对应RESULT_ERROR_GENERIC_FAILURE,sentIntent可能包括额外的“错误代码”包含一个无线电广播技术特定的值,通常只在修复故障时有用。第5个参数-deliveryIntent,仅当目标接收到你的SMS消息才触发。

为了跟踪发出的短信的状态,实现和注册Broadcast Receiver(广播接收者)监听传递给sendTextMessage方法的参数Pending Intents。下面我们就实现和注册这个广播接收者:

 
  1. String SENT_SMS_ACTION="SENT_SMS_ACTION";  
  2. String DELIVERED_SMS_ACTION="DELIVERED_SMS_ACTION";  
  3.  
  4. //create the sentIntent parameter  
  5. Intent sentIntent=new Intent(SENT_SMS_ACTION);  
  6. PendingIntent sentPI=PendingIntent.getBroadcast(  
  7.         this,  
  8.         0,   
  9.         sentIntent,   
  10.         0);  
  11.  
  12. //create the deilverIntent parameter  
  13. Intent deliverIntent=new Intent(DELIVERED_SMS_ACTION);  
  14. PendingIntent deliverPI=PendingIntent.getBroadcast(  
  15.         this,  
  16.         0,   
  17.         deliverIntent,   
  18.         0);  
  19.  
  20. //register the Broadcast Receivers  
  21. registerReceiver(new BroadcastReceiver(){  
  22.     @Override 
  23.     public void onReceive(Context _context,Intent _intent)  
  24.     {  
  25.         switch(getResultCode()){  
  26.             case Activity.RESULT_OK:  
  27.                 Toast.makeText(getBaseContext(),   
  28.                         "SMS sent success actions",  
  29.                         Toast.LENGTH_SHORT).show();  
  30.                 break;  
  31.             case SmsManager.RESULT_ERROR_GENERIC_FAILURE:  
  32.                 Toast.makeText(getBaseContext(),   
  33.                         "SMS generic failure actions",  
  34.                         Toast.LENGTH_SHORT).show();  
  35.                 break;  
  36.             case SmsManager.RESULT_ERROR_RADIO_OFF:  
  37.                 Toast.makeText(getBaseContext(),  
  38.                         "SMS radio off failure actions",  
  39.                         Toast.LENGTH_SHORT).show();  
  40.                 break;  
  41.             case SmsManager.RESULT_ERROR_NULL_PDU:  
  42.                 Toast.makeText(getBaseContext(),   
  43.                         "SMS null PDU failure actions",  
  44.                         Toast.LENGTH_SHORT).show();  
  45.                 break;  
  46.         }  
  47.     }  
  48. },  
  49. new IntentFilter(SENT_SMS_ACTION));  
  50. registerReceiver(new BroadcastReceiver(){  
  51.     @Override 
  52.     public void onReceive(Context _context,Intent _intent)  
  53.     {  
  54.         Toast.makeText(getBaseContext(),   
  55.                 "SMS delivered actions",  
  56.                 Toast.LENGTH_SHORT).show();               
  57.     }  
  58. },  
  59. new IntentFilter(DELIVERED_SMS_ACTION)); 

在基本完成了要做的工作,接下来要做的就是将sendTextMessage的第4个和第5个参数改为sentPI、deliverPI,这样工作基本完成,修改后的sendSMS方法如下:

 
  1. private void sendSMS(String phoneNumber, String message) {  
  2.     // ---sends an SMS message to another device---  
  3.     SmsManager sms = SmsManager.getDefault();  
  4.     String SENT_SMS_ACTION = "SENT_SMS_ACTION";  
  5.     String DELIVERED_SMS_ACTION = "DELIVERED_SMS_ACTION";  
  6.  
  7.     // create the sentIntent parameter  
  8.     Intent sentIntent = new Intent(SENT_SMS_ACTION);  
  9.     PendingIntent sentPI = PendingIntent.getBroadcast(this0, sentIntent,  
  10.             0);  
  11.  
  12.     // create the deilverIntent parameter  
  13.     Intent deliverIntent = new Intent(DELIVERED_SMS_ACTION);  
  14.     PendingIntent deliverPI = PendingIntent.getBroadcast(this0,  
  15.             deliverIntent, 0);  
  16.  
  17.     // register the Broadcast Receivers  
  18.     registerReceiver(new BroadcastReceiver() {  
  19.         @Override 
  20.         public void onReceive(Context _context, Intent _intent) {  
  21.             switch (getResultCode()) {  
  22.             case Activity.RESULT_OK:  
  23.                 Toast.makeText(getBaseContext(),  
  24.                         "SMS sent success actions", Toast.LENGTH_SHORT)  
  25.                         .show();  
  26.                 break;  
  27.             case SmsManager.RESULT_ERROR_GENERIC_FAILURE:  
  28.                 Toast.makeText(getBaseContext(),  
  29.                         "SMS generic failure actions", Toast.LENGTH_SHORT)  
  30.                         .show();  
  31.                 break;  
  32.             case SmsManager.RESULT_ERROR_RADIO_OFF:  
  33.                 Toast  
  34.                         .makeText(getBaseContext(),  
  35.                                 "SMS radio off failure actions",  
  36.                                 Toast.LENGTH_SHORT).show();  
  37.                 break;  
  38.             case SmsManager.RESULT_ERROR_NULL_PDU:  
  39.                 Toast.makeText(getBaseContext(),  
  40.                         "SMS null PDU failure actions", Toast.LENGTH_SHORT)  
  41.                         .show();  
  42.                 break;  
  43.             }  
  44.         }  
  45.     }, new IntentFilter(SENT_SMS_ACTION));  
  46.     registerReceiver(new BroadcastReceiver() {  
  47.         @Override 
  48.         public void onReceive(Context _context, Intent _intent) {  
  49.             Toast.makeText(getBaseContext(), "SMS delivered actions",  
  50.                     Toast.LENGTH_SHORT).show();  
  51.         }  
  52.     }, new IntentFilter(DELIVERED_SMS_ACTION));  
  53.  
  54.     // if message's length more than 70 ,  
  55.     // then call divideMessage to dive message into several part ,and call  
  56.     // sendTextMessage()  
  57.     // else direct call sendTextMessage()  
  58.     if (message.length() > 70) {  
  59.         ArrayList<String> msgs = sms.divideMessage(message);  
  60.         for (String msg : msgs) {  
  61.             sms.sendTextMessage(phoneNumber, null, msg, sentPI, deliverPI);  
  62.         }  
  63.     } else {  
  64.         sms.sendTextMessage(phoneNumber, null, message, sentPI, deliverPI);  
  65.     }  

运行之后的,发送短信成功的话就可以看到如下界面:

Android 开发之旅:短信的收发及在android模拟器之间实践(一)

图5、增强SMS(一)

5、SMS增强(二)

下面这个增强是使SMS能够发送二进制数据。要发送数据要使用SmsManager类的sendDataMessage方法,跟sendTextMessage方法类似,只不过该方法多了一个目标端口的参数,构建该SMS的过程跟前面的类似这里就不在累述。

 

本系列的其它文章:

  1. Android 开发之旅:环境搭建及HelloWorld
  2. Android 开发之旅:HelloWorld项目的目录结构
  3. Android 开发之旅:android架构
  4. Android 开发之旅:应用程序基础及组件
  5. Android 开发之旅:应用程序基础及组件(续)
  6. Android 开发之旅:活动与任务
  7. Android 开发之旅:进程与线程
  8. Android 开发之旅:组件生命周期(一)
  9. Android 开发之旅:组件生命周期(二)
  10. Android 开发之旅:组件生命周期(三)
  11. Android 开发之旅:又见Hello World!
  12. Android 开发之旅:深入分析布局文件&又是"Hello World!"
  13. Android 开发之旅:view的几种布局方式及实践
  14. Android 开发之旅:短信的收发及在android模拟器之间实践(一)
  15. 请期待Android 开发之旅:短信的收发及在android模拟器之间实践(二)…







     本文转自Saylor87 51CTO博客,原文链接:http://blog.51cto.com/skynet/363493,如需转载请自行联系原作者





相关文章
|
4天前
|
存储 安全 Android开发
安卓应用开发:构建一个高效的用户登录系统
【5月更文挑战第3天】在移动应用开发中,用户登录系统的设计与实现是至关重要的一环。对于安卓平台而言,一个高效、安全且用户体验友好的登录系统能够显著提升应用的用户留存率和市场竞争力。本文将探讨在安卓平台上实现用户登录系统的最佳实践,包括对最新身份验证技术的应用、安全性考量以及性能优化策略。
|
6天前
|
移动开发 Java Android开发
构建高效Android应用:Kotlin协程的实践之路
【4月更文挑战第30天】在移动开发领域,随着用户需求的不断增长和设备性能的持续提升,实现流畅且高效的用户体验已成为开发者的首要任务。针对Android平台,Kotlin协程作为一种新兴的异步编程解决方案,以其轻量级线程管理和简洁的代码逻辑受到广泛关注。本文将深入探讨Kotlin协程的概念、优势以及在实际Android应用中的运用,通过实例演示如何利用协程提升应用性能和响应能力,为开发者提供一条构建更高效Android应用的实践路径。
|
6天前
|
前端开发 Android开发 iOS开发
【Flutter前端技术开发专栏】Flutter在Android与iOS上的性能对比
【4月更文挑战第30天】Flutter 框架实现跨平台移动应用,通过一致的 UI 渲染(Skia 引擎)、热重载功能和响应式框架提高开发效率和用户体验。然而,Android 和 iOS 的系统差异、渲染机制及编译过程影响性能。性能对比显示,iOS 可能因硬件优化提供更流畅体验,而 Android 更具灵活性和广泛硬件支持。开发者可采用代码、资源优化和特定平台优化策略,利用性能分析工具提升应用性能。
【Flutter前端技术开发专栏】Flutter在Android与iOS上的性能对比
|
22小时前
|
Android开发
Android 盒子开发过程中遇到的问题及解决方法
Android 盒子开发过程中遇到的问题及解决方法
7 2
|
1天前
|
安全 Linux Android开发
FFmpeg开发笔记(十六)Linux交叉编译Android的OpenSSL库
该文介绍了如何在Linux服务器上交叉编译Android的FFmpeg库以支持HTTPS视频播放。首先,从GitHub下载openssl源码,解压后通过编译脚本`build_openssl.sh`生成64位静态库。接着,更新环境变量加载openssl,并编辑FFmpeg配置脚本`config_ffmpeg_openssl.sh`启用openssl支持。然后,编译安装FFmpeg。最后,将编译好的库文件导入App工程的相应目录,修改视频链接为HTTPS,App即可播放HTTPS在线视频。
FFmpeg开发笔记(十六)Linux交叉编译Android的OpenSSL库
|
2天前
|
存储 前端开发 Java
Android应用开发中的MVP架构模式实践
【5月更文挑战第5天】随着移动应用开发的复杂性增加,传统的MVC(Model-View-Controller)架构在应对大型项目时显得笨重且不灵活。本文将探讨一种更适应现代Android应用开发的架构模式——MVP(Model-View-Presenter),并展示如何在Android项目中实现该模式以提升代码的可维护性和可测试性。通过对比分析MVP与传统MVC的差异,以及提供一个实际案例,读者将能深入了解MVP的优势和实施步骤。
|
6天前
|
移动开发 调度 Android开发
构建高效Android应用:Kotlin协程的实践之路
【4月更文挑战第30天】 在移动开发领域,性能优化与流畅的用户体验始终是开发者追求的目标。随着Kotlin语言在Android开发中的普及,其提供的协程特性成为了解决异步编程问题的有力工具。本文将通过深入分析Kotlin协程的原理与实践,展示如何在Android应用中利用协程提升响应速度和处理效率,同时保证代码的简洁性和可维护性。我们将从基本概念出发,逐步深入到协程的高级使用场景,帮助开发者构建更加高效的Android应用。
|
6天前
|
存储 Java Android开发
安卓应用开发中的内存优化策略
【4月更文挑战第30天】在移动开发领域,尤其是安卓平台上,内存管理是影响应用性能和用户体验的关键因素。由于安卓设备的硬件资源有限,不合理的内存使用会导致应用响应缓慢、消耗过多电量甚至崩溃。本文将探讨针对安卓平台的内存优化技巧,旨在帮助开发者提高应用的性能和稳定性,从而提升用户满意度。我们将详细讨论内存泄漏的预防、合理的内存分配策略以及高效的内存回收方法。
|
6天前
|
机器学习/深度学习 人工智能 缓存
安卓应用性能优化实践探索深度学习在图像识别中的应用进展
【4月更文挑战第30天】随着智能手机的普及,移动应用已成为用户日常生活的重要组成部分。对于安卓开发者而言,确保应用流畅、高效地运行在多样化的硬件上是一大挑战。本文将探讨针对安卓平台进行应用性能优化的策略和技巧,包括内存管理、多线程处理、UI渲染效率提升以及电池使用优化,旨在帮助开发者构建更加健壮、响应迅速的安卓应用。 【4月更文挑战第30天】 随着人工智能技术的迅猛发展,深度学习已成为推动计算机视觉领域革新的核心动力。本篇文章将深入分析深度学习技术在图像识别任务中的最新应用进展,并探讨其面临的挑战与未来发展趋势。通过梳理卷积神经网络(CNN)的优化策略、转移学习的实践应用以及增强学习与生成对
|
7天前
|
缓存 监控 API
Android应用性能优化实践
【4月更文挑战第30天】 随着智能手机的普及,用户对移动应用的性能要求越来越高。对于Android开发者而言,提升应用的性能是吸引和保留用户的关键因素之一。本文将深入探讨影响Android应用性能的主要因素,并提供一系列的优化策略,旨在帮助开发者构建更加流畅和高效的应用体验。