实际开发中比较有用的小技巧

 

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

  1. 编写一个新Activity如BaseActivity去继承Activity,代码如下:
    public  class  BaseActivity extends Activity
    {
            @Override
            protected void onCreate(Bundle savedInstanceState)
            {
                         super.onCreate(savedInstanceState);
                         Log.d("BaseActivity", getClass().getSimpleName());
            }
    }
  2. 让工程里所有的Activity都继承自BaseActivity;
  3. 点击进入你想查看代码的界面,同时观察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个位置。

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
  • 在广播接收器中注册有序广播优先级:
    ```<receive android:name=".MC>
            <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);
posted @ 2016-04-04 18:54  AnglusWang  阅读(279)  评论(0编辑  收藏  举报