《Android第一行代码》笔记

学习Android开发差不多有两年时间了,期间也做了大大小小的一些项目。近来抽出闲暇想把Android基础强化一下,之前在网上看到了郭霖郭大神的几篇博客,从中受益不少。于是花了近一周时间看完了郭神的一本Android教材——《Android第一行代码》。这本书相比其他教材个人感觉更为基础,内容很实用。看完之后我也有一些收获,学到了一些可以很好的运用到实际中的Android小技巧,下面从中选出我认为很有价值的地方做个记录。同时欢迎各位指正补充~~

1、查看当前界面处于哪个Activity。

很多时候当我们接手一个较为复杂的源代码的时候,里面会有很多个Acvitity。此时我们往往很难从中找出哪个界面对应哪个源码,这无疑会降低我们的开发效率。下面介绍书中一个小技巧:

1. 编写一个新Activity如BaseActivity去继承Activity,代码如下:

public  class  BaseActivity extends Activity
{
           @Override
           protected void onCreate(Bundle savedInstanceState)
           {
                        super.onCreate(savedInstanceState);
                        Log.d("BaseActivity", getClass().getSimpleName());
           }
}
  1. 让工程里所有的Activity都继承自BaseActivity;
  2. 点击进入你想查看代码的界面,同时观察LogCat中的输出,打印出的信息就是相应的Activity的类名了。

个人心得:看到这里,也许你会觉得,如果拿到一个源码工程,然后进去一个个的改还是会很麻烦。我认为作者在这里主要是想介绍这样一种方法,我们在编程的时候可以考虑加入这样一种技巧,这样可以更好的与人合作一个项目。

2、当启动一个需要传递数据的Activity时,避免参数混淆。

大家对Intent的都很熟悉,他是Android系统的搬运工。当我们启动一个Acivity并希望向它传递一些数据,这时候通常都会用到intent。

一个项目中可能会有很多个Activity都需要传递数据,而开发者完全有可能不确定这些Activity分别要传递什么数据,这时候我们可以用一个技巧来规范这样一种“通信协议”。

public class AnotherActivity extends BaseActivity
{
        public static void actionStart(Context context,String val1,String val2)
        {
                  Intent intent = new Intent(context, AnotherActivity.class);
                  intent.putExtra("val1", val1);
                  intent.putExtra("val2", val2);
                  context.startActivity(intent);
        }
}

这样一来,在使用的过程中,当需要跳转的时候可以用以下代码

AnotherActivity.actionStart(FirstActivity.this, "val1", "val2");

个人心得:个人觉得这是一个很不错的习惯,如果系统中带参数的跳转比较多就应该将跳转全部换成统一规范,这样可以减少合作开发中不必要的麻烦。

3、TableLayout的使用

TableLayout是在开发中很少用到的一个布局。当然对于这个控件有几个地方我觉得也需要注意。

- TableRow标签(TableLayout的一行)中的控件是不能指定宽度的。

- 正由于TableRow不能设置宽度当需要布局自动拉伸宽度时,可以通过在TableLayout标签下设置

android:stretchColunms="1"

属性来指定某一列被拉伸解决(以上是指定拉伸第二列)。

- 当某一行少一列数据的时候,最后会多出一列的空白。如果希望系统自动拉伸空间占满这一行,可以在当前行的某个控件标签下设置:

android:layout_span="2"

这样一来该控件就会占2个位置。

个人心得:在我所做过的项目中,尚未用过TableLayout,不过作为一个Android开发者,应该对其有一定的了解,在恰当的时候能够很好的使用之。

4、自定义继承ArrayAdapter的适配器

我们在用listview的时候都会用到适配器,Android为我们做了两个常用的适配器:SimpleAdapter和ArrayAdapter等,当我们有特殊要求的时候需要自定义一个适配器继承自BaseAdapter,这样可以更加灵活的完成我们需要的特殊功能。但其实大多时候我们可以编写一个继承自ArrayAdapter的适配器,这样更加简单:

public class MCAdapter extends ArrayAdapter<Fruit>
 {

    private int resourceId;

    public FruitAdapter(Context context, int textViewResourceId,
            List<Fruit> objects) {
        super(context, textViewResourceId, objects);
        resourceId = textViewResourceId;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ... ...
        return view;
    }

这样一来,我们只需要重写getView这样一个方法,而如果是继承自BaseAdapter,我们需要至少重写4个方法。可以是我们的代码更加简化。

个人心得:也许这个大家都知道吧, 反正我以前都是自定义适配器继承自BaseAdapter,然后重写4个方法,其中3个都是用不上的。。

5、Fragment回退栈

这里只是想记录一个Fragment的方法:transaction.addToBackStack(null);

6、Broadcast Receiver

  • 广播接收器类中不允许开启线程
  • 发送有序广播:sendOrderedBroadcast
  • 在广播接收器中注册有序广播优先级:
              <intent-filter **android:priority="50">
              ... ...
              <intent/>
      <receive/>
  • 阻止广播:abortBroadcast();
  • 本地广播:LocalBroadcastManager.sendBroadcast(intent);(无法用静态注册方式)

个人心得:广播接收器是很常用的。其中有序广播的优先级由应用自己来定这一点让我很诧异,那岂不是又给了应用程序漏洞可钻?在以前应用程序要拦截短信都是通过设置更高的广播优先级,然后阻断广播来实现,但是在Android4.4之后,加入了默认短信管理功能,这使得用户来决定谁来管理短信、电话本等等。看来谷歌也发现了这个潜在的问题。

7、调用系统相机

在使用系统相机的过程中,我们可以通过startActivityForResult启动相机,从而接收拍照成功与否的返回值。并且可以对拍照后的图片进行裁剪。

-启动相机拍照:

Intent intent = new intent("android.media.action.IMAGE_CAPTURE");
intent.putExtra(MediaStore.EXTRA_OUTPUT, imageUri);
startActivityForResult(intent, TAKE_PHOTO);
  • 拍照完成后裁剪:
Intent intent = new intent("android.media.action.CROP");
intent.setDataAndType(imageUri, "image/*");
intent.putExtra("scale", true);
intent.putExtra(MediaStore.EXTRA_OUTPUT, imageUri);
startActivityForResult(intent, CROP_PHOTO);

个人心得:这里主要是对系统中的action的了解程度以及对action的参数的熟悉。详见Android action大全

好了,以上是我在读这本书中所收获的一些东西,坐着提供的一些小技巧如果可以运用得当,可以很好的帮助我们开发项目,提高我们的效率。今后我也会不断加入所学的实用技巧。也欢迎大家对内容进行指正、补充。谢谢!

                                                                                                                 ——超低空
时间: 2024-10-24 11:58:53

《Android第一行代码》笔记的相关文章

SQL 笔记 By 华仔

-------------------------------------读书笔记------------------------------- 笔记1-徐 最常用的几种备份方法 笔记2-徐 收缩数据库的大小的方法 笔记3-徐 设置数据库自动增长注意要点 笔记4-徐 模仿灾难发生时还原adventurework数据库 示例 stopat 笔记5-徐 检查日志文件不能被截断的原因 笔记6-徐 检测孤立用户并恢复孤立用户到新的服务器 解决数据库镜像孤立用户问题 笔记7-徐 SQLSERVER日志记录

SQL笔记---多表左联

这是实际场景当中的一个例子,拿出来分析总结思路. -- SQL 查询 --SELECT  orderQuery.Rk_SkuCode ,        orderQuery.SkuName,        SUM(ISNULL(orderQuery.OrderTotal, 0))        - SUM(ISNULL(removeQuery.RemoveTotal, 0))        - SUM(ISNULL(pickQuery.PickTotal, 0))        - SUM(IS

SQL笔记---分页

随用随想,随用随记. 通过实际应用掌握SQL语句. 一. SQL分页 1. 第一种方法:利用ID大于多少进行筛选 SELECT TOP 20        *FROM    dbo.WMS_StockWHERE   ( Rk_SkuCode > ( SELECT MAX(Rk_SkuCode)                         FROM   ( SELECT TOP 40                                            *           

《HeadFirst SQL》笔记

规范化 0 约束 1 原子性 2 第一范式 1NF 3 数据模式 4 依赖 5 联接查询 6 交叉联接(AKA 笛卡尔联接,叉积) 7 内联接 8 子查询 9 外联接 10 自联接 11 集合 12 事务 13 ACID 14 管理事务 15 常用语句 16 注意 17 规范化 约束 NOT NULL UNIQUE PRIMARY KEY DEFAULT FOREIGN KEY:引用父表的某个唯一值引用完整性:插入外键列的值必须已经存在于父表的来源列中 --创建外键 create table i

SQL笔记1:SELECT及SELECT高级应用

T-SQL笔记1:SELECT及SELECT高级应用 本章摘要 1:安装AdventureWorks 2:基本运算符和表达式 3:between 4:like 5:escape 6:TOP 7:GROUP BY 7.1:GROUP BY ALL 7.2:HAVING 8:SELECT字句技术 8.1:使用DISTINCT消除重复值 8.2:返回拼接的结果 8.3使用INTO字句 9:子查询 9.1:子查询类型 9.2:代替表达式的查询 9.3:多层嵌套 10:比较使用 EXISTS 和 IN 的

金典 SQL笔记(6)

page223-索引 --利用SQL 语句创建索引 --CREATE INDEX 索引名称on 表名(字段 ,字段, 字段字段n) --索引名称必须为唯一的,字段 ,字段, 同意一个到多个 --范例为T_person 表中给FName创建索引索引名为 idx_person_name CREATE INDEX idx_person_name ON T_Person (FName) --删除索引 --drop index 表名索引名 DROP INDEX T_person.idx_person_na

Mybatis 项目开发实际常用SQL笔记总结

parameterType 和 resultType parameterType:单个参数用String,多个参数用map resultType:   可以是 Integer.String.Object    <select id="countGroupMasterByUid" parameterType="String" resultType="Integer">      SELECT              COUNT(id)

sql笔记/分页存储过程

[email protected]c#中进行++操作可以是整数或小数,sql中只能对整数进行++操作.char类型 适合存储长度波动较小不回收效率高varchar 类型 适合存储长度波动较大可以回收nchar代表unicode 存储内容包括汉字时候考虑加n SQL语句特点1不区分大小写2没有双引号所有字符串都包含在单引号3没有逻辑相等,逻辑相等和赋值一样都是用=4没有bool值得概念,但是在视图中可以输入true/false5也有关系运算符.6也有逻辑运算符 &&-- and || --o

sql笔记

1. 看下面sql,重点有两个,一个是distinct  ,一个是树形结构查询 select DISTINCT t.unit_code from t_unit_relation t where t.corp_tn='jiaozhougongan' start with t.unit_code='0001' connect by prior t.unit_code = t.unit_upcode 分析: ① distinct:去重复值 ② 树形结构查询,这个博客:http://www.cnblog

HeadFirst SQL 读书摘要

数据库都是用 圆柱形表示的. 数据库中包含表 表中包含行和列 行又叫记录record,  列又叫 字段field 创建数据库 create database mypipe_l; 选择数据库 use mypipe_l; 创建表 create table doughnut( name VARCHAR(10), type VARCHAR(6) ); 查看表 desc doughnut; 删除表 drop table doughnut; 插入数据 insert into doughnut (name,