Android联机或者模拟器单独测试Activity的辅助Activity示例开发

简介:

   想起写个单独测试Activity的辅助Activity的原因是在联机测试的时候IDEA或者Android Studio中的指定运行Activity功能没法使用了。

 

   下面付IDE中指定运行Activity的界面截图:

    wKiom1ZId3ezyUiNAAEPbwkDMQM234.png



    辅助Activity要做的事情是将辅助Activity作为启动的默认Activity,其主界面中以ListView的形式展示所有Activity,通过单击ListView的Item项来启动要测试的Activity。


   1. 辅助Activity代码示例:

    

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
package  secondriver.app;
 
import  android.app.Activity;
import  android.content.Context;
import  android.content.Intent;
import  android.content.pm.ActivityInfo;
import  android.content.pm.PackageInfo;
import  android.content.pm.PackageManager;
import  android.os.Bundle;
import  android.util.Log;
import  android.view.View;
import  android.view.ViewGroup;
import  android.widget.AdapterView;
import  android.widget.ArrayAdapter;
import  android.widget.LinearLayout;
import  android.widget.ListView;
 
import  java.util.ArrayList;
import  java.util.Arrays;
import  java.util.List;
 
/**
  * Created by Broncho on 2015/11/15.
  */
public  class  TestActivitiesActivity  extends  Activity  implements  AdapterView.OnItemClickListener {
 
     private  LinearLayout mRootView;
     private  ListView mListView;
     private  ArrayAdapter mAdapter;
     private  List<Class> mAllActivities;
 
     @Override
     protected  void  onCreate(Bundle savedInstanceState) {
         super .onCreate(savedInstanceState);
         initView();
         mAllActivities = getActivities( this this .getPackageName(), Arrays.<Class>asList( this .getClass()));
         mAdapter =  new  ArrayAdapter( this , android.R.layout.simple_list_item_1, android.R.id.text1, mAllActivities);
         mListView.setAdapter(mAdapter);
         mListView.setOnItemClickListener( this );
     }
 
     private  void  initView() {
         mRootView =  new  LinearLayout( this );
         mListView =  new  ListView( this );
         mListView.setId(android.R.id.list);
         mRootView.addView(mListView, ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
         setContentView(mRootView);
     }
 
     @Override
     public  void  onItemClick(AdapterView<?> parent, View view,  int  position,  long  id) {
         Class activity = mAllActivities.get(position);
         //启动指定的Activity
         startActivity( new  Intent( this , activity));
     }
 
     /**
      * 获取所有要测试的Activity Class
      *
      * @param context
      * @param packageName
      * @param excludeActivities
      * @return
      */
     public  static  List<Class> getActivities(Context context, String packageName, List<Class> excludeActivities) {
         final  String TAG =  "GET_ACTIVITY" ;
         List<Class> includeActivities =  new  ArrayList<>();
         try  {
             PackageInfo packageInfo = context.getPackageManager().getPackageInfo(packageName, PackageManager.GET_ACTIVITIES);
             if  (packageInfo.activities !=  null ) {
                 ActivityInfo[] activityInfos = packageInfo.activities;
                 Log.d(TAG,  "Find "  + activityInfos.length +  " activity in AndroidManifest.xml." );
                 for  (ActivityInfo activityInfo : activityInfos) {
                     Class activityClass;
                     String activityName = activityInfo.name;
                     try  {
                         activityClass = Class.forName(activityName);
                         if  (Activity. class .isAssignableFrom(activityClass)) {
                             includeActivities.add(activityClass);
                         }
                     catch  (ClassNotFoundException e) {
                         Log.d(TAG,  "Class not found activity "  + activityName +  " in package "  + packageName);
                     }
                 }
             }
             Log.d(TAG,  "Found  "  + includeActivities.size() +  " activity list is :"  + Arrays.toString(includeActivities.toArray()));
             if  ( null  != excludeActivities) {
                 includeActivities.removeAll(excludeActivities);
             }
             Log.d(TAG,  "Last  "  + includeActivities.size() +  " activity  list is :"  + Arrays.toString(includeActivities.toArray()));
         catch  (PackageManager.NameNotFoundException e) {
             Log.d(TAG,  "Android system not found package "  + packageName);
         }
         return  includeActivities;
     }
}


   在AndroidManifest.xml中讲辅助Activity设置为默认启动的Activity,之后就可以通过选择点击要启动的Activity来进行测试。该示例还可以通过添加一些代码来增强,比如启动Activity的时候可以通过输入对话框的方式携带数据至启动的Activity。测试完成后删除或者充足默认启动的Activity即可。


  2.  配置AndroidManifest.xml :

  

1
2
3
4
5
6
7
8
< activity  android:name = ".TestActivitiesActivity" >
     < intent-filter >
         < action  android:name = "android.intent.action.MAIN" />
         < category  android:name = "android.intent.category.LAUNCHER" />
     </ intent-filter >
</ activity >
< activity  android:name = ".OneActivity" />
< activity  android:name = ".TwoActivity" />


    3. 调试日志:

    

1
2
3
11 - 15  20 : 07 : 31.899  10665 - 10665 /secondriver.app D/GET_ACTIVITY: Find  3  activity in AndroidManifest.xml.
11 - 15  20 : 07 : 31.899  10665 - 10665 /secondriver.app D/GET_ACTIVITY: Found activity have  3  list is :[ class  secondriver.app.TestActivitiesActivity,  class  secondriver.app.OneActivity,  class  secondriver.app.TwoActivity]
11 - 15  20 : 07 : 31.899  10665 - 10665 /secondriver.app D/GET_ACTIVITY: Last activity have  2  list is :[ class  secondriver.app.OneActivity,  class  secondriver.app.TwoActivity]


   从日志中可以看到一共发现了3个Activity类,去除辅助的Activity,在ListView中讲显示2个Item项。

   

   


        后期追加内容:

    4. 结果效果图

      

      wKiom1Z9CICQdz3EAADuSj8GZYI065.png


    新源码参见附件:TestActivitiesActivity.java.txt

       Item状态变化Drawable文件内容如下:

    wKioL1Z9ClrwclwZAABCZpQXEH0764.png



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

相关文章
|
5月前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
853 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
5月前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
725 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
5月前
|
移动开发 Rust JavaScript
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
938 4
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
6月前
|
开发工具 Android开发
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
718 11
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
|
6月前
|
存储 API Android开发
【02】完整的安卓二次商业实战-配置gradle-构建打包原生安卓项目-调试本地运行模拟器-优雅草伊凡
【02】完整的安卓二次商业实战-配置gradle-构建打包原生安卓项目-调试本地运行模拟器-优雅草伊凡
489 4
【02】完整的安卓二次商业实战-配置gradle-构建打包原生安卓项目-调试本地运行模拟器-优雅草伊凡
|
5月前
|
移动开发 Android开发
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
278 0
|
6月前
|
Java 开发工具 Maven
【01】完整的安卓二次商业实战-详细的初级步骤同步项目和gradle配置以及开发思路-优雅草伊凡
【01】完整的安卓二次商业实战-详细的初级步骤同步项目和gradle配置以及开发思路-优雅草伊凡
649 6
|
8月前
|
安全 数据库 Android开发
在Android开发中实现两个Intent跳转及数据交换的方法
总结上述内容,在Android开发中,Intent不仅是活动跳转的桥梁,也是两个活动之间进行数据交换的媒介。运用Intent传递数据时需注意数据类型、传输大小限制以及安全性问题的处理,以确保应用的健壯性和安全性。
540 11
|
12月前
|
JavaScript Linux 网络安全
Termux安卓终端美化与开发实战:从下载到插件优化,小白也能玩转Linux
Termux是一款安卓平台上的开源终端模拟器,支持apt包管理、SSH连接及Python/Node.js/C++开发环境搭建,被誉为“手机上的Linux系统”。其特点包括零ROOT权限、跨平台开发和强大扩展性。本文详细介绍其安装准备、基础与高级环境配置、必备插件推荐、常见问题解决方法以及延伸学习资源,帮助用户充分利用Termux进行开发与学习。适用于Android 7+设备,原创内容转载请注明来源。
3354 77
|
8月前
|
移动开发 Java 编译器
Kotlin与Jetpack Compose:Android开发生态的演进与架构思考
本文从资深Android工程师视角深入分析Kotlin与Jetpack Compose在Android系统中的技术定位。Kotlin通过空安全、协程等特性解决了Java在移动开发中的痛点,成为Android官方首选语言。Jetpack Compose则引入声明式UI范式,通过重组机制实现高效UI更新。两者结合不仅提升开发效率,更为跨平台战略和现代架构模式提供技术基础,代表了Android开发生态的根本性演进。
347 0