android学习笔记分析3

------------------------------------------------
本文系本站原创,欢迎转载!

转载请注明出处:http://sjj0412.cublog.cn/
------------------------------------------

前面说到intent的另外一种赋值方式:

这个就是指定其component属性(调用setComponent(ComponentName)或者setClass(Context, Class)来指定)。通过这种方式的赋值的intent,其实就直接指出了activity类,这样就没有必要到androidmanfest.xmlprovider,然后通过providergettype返回加上action来找activity了,而是直接创建activity类的实例。

其实android还提供了一种创建activity的方式,那就是动态menu的方式,通过

public boolean onCreateOptionsMenu(Menu menu) {

        super.onCreateOptionsMenu(menu);

 

        // This is our one standard application action -- inserting a

        // new note into the list.

        menu.add(0, MENU_ITEM_INSERT, 0, R.string.menu_insert)

                .setShortcut('3', 'a')

                .setIcon(android.R.drawable.ic_menu_add);

 

        // Generate any additional actions that can be performed on the

        // overall list.  In a normal install, there are no additional

        // actions found here, but this allows other applications to extend

        // our menu with their own actions.

        Intent intent = new Intent(null, getIntent().getData());

        intent.addCategory(Intent.CATEGORY_ALTERNATIVE);

        menu.addIntentOptions(Menu.CATEGORY_ALTERNATIVE, 0, 0,

                new ComponentName(this, NotesList.class), null, intent, 0, null);

 

        return true;

}

上面的addIntentOptions就是这种方式。

这个函数其实是,系统通过Intent查询是否有符合条件的activity,这个过程和上面的一样,如果找到了,就生成一个menu,这个menu的名字是androidmanfest.xml中的符合条件的activity中的label中指定的字符。

<intent-filter android:label="@string/resolve_edit">

如这个就是string/resolve_edit,这个也是指向一个string资源。

在上面的onCreateOptionsMenu中:

由于intent的uri是content://com.google.provider.NotePad/notes,因此得到的type是vnd.android.cursor.dir/vnd.google.note

而category是Intent.CATEGORY_ALTERNATIVE

然后到androidmanfest.xml去找,大家自己看一下,应该找不到合适的。这样也是为什么menu只有一个add_note。

如果修改Intent.CATEGORY_ALTERNATIVEIntent.CATEGORY_DEFAULT,然后

再执行,这个时相当于uri=content://com.google.provider.NotePad/notes

category=android.intent.category.DEFAULT

到androidmanfest.xml查找,发现有一个满足。

 <intent-filter>

                <action android:name="android.intent.action.INSERT" />

                <category android:name="android.intent.category.DEFAULT" />

                <data android:mimeType="vnd.android.cursor.dir/vnd.google.note" />

            </intent-filter>

但是执行发现没有增加菜单,为什么啊,其实这个是是由于onCreateOptionsMenu和onPrepareOptionsMenu函数中都有menu.addIntentOptions(Menu.CATEGORY_ALTERNATIVE),相当在同一个groupid建菜单,这样后一个执行的会覆盖掉前一个的。

而onPrepareOptionsMenu在onCreateOptionsMenu后执行,所以onPrepareOptionsMenu中覆盖了onCreateOptionsMenu添加的菜单,而由于onPrepareOptionsMenu没有给Menu.CATEGORY_ALTERNATIVE附新值,故Menu.CATEGORY_ALTERNATIVE还是为空。

 

怎么解决,好解决,在onCreateOptionsMenu中改groupid号,即将Menu.CATEGORY_ALTERNATIVE改为Menu.first,其他的也行,但注意不要改为menu.none,这样会覆盖掉

menu.add(0, MENU_ITEM_INSERT, 0, R.string.menu_insert)

                .setShortcut('3', 'a')

                .setIcon(android.R.drawable.ic_menu_add);

添加的菜单。因为menu.none也为0

改完后运行可以看到。

 

 

总结下函数
 
int android.view.Menu.addIntentOptions(int groupId, int itemId, int order, ComponentName caller, Intent[] specifics, Intent intent, int flags, MenuItem[] outSpecificItems)

函数参数分析:

1.       groupid就是菜单组的编号;

2.       itemId

3.       Call就是发起activityactivity

4.       Specifics 是用来指定菜单顺序的,一般以uri+action来选择的activity

5.       Intent 这个一般式uri+categroy形式来选择的activity

6.       outSpecificItems这个是返回MenuItem值,用来给你跟多的设置菜单。

显示的菜单是满足specifics和满足intent的所有activity,然后显示时是满足specifics的菜单先显示。

actionandroid.app.action.MAIN,类型为android.app.category.LAUNCHERactivity是特殊的activity,也就是入口activity,当一个应用执行时,其实是到androidmandfest.xml查看

actionandroid.app.action.MAIN,类型为android.app.category.LAUNCHERactivity,如果发现就创建这个activity实例运行,如果没发现就不启动,大家可以试着去将android.app.action.MAIN改为android.app.action.MAIN1,然后运行,你发现,运行不了,没有窗体创建。

为什么要这样呢,因为android程序中没有main等函数,系统不知道该从哪个activity开始运行,必须有个约定。

 

service

service其实可以看成是activity的简化版,activity除去主窗体的功能外,就是service了。

一个简单的Servce实例如下:

package com.wissen.testApp.service;

public class MyService extends Service {
    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    @Override
    public void onCreate() {
        super.onCreate();
        Toast.makeText(this, 
“Service created…”, Toast.LENGTH_LONG).show();
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        Toast.makeText(this, 
“Service destroyed…”, Toast.LENGTH_LONG).show();
    }
}

上例中的这个Service主要做了这些事:当服务创建和销毁时通过界面消息提示用户。
如Android中的其它部件一样, Service也会和一系列Intent关联。Service的运行入口需要在AndroidManifest.xml中进行配置,如下:

<service class=”.service.MyService”>
    <intent-filter>
        <action android:value=”com.wissen.testApp.service.MY_SERVICE”
 />
    </intent-filter>
</service>

 

 之后我们的Service就可以被其他代码所使用了。
这个和activity几乎没什么差别,就是将

<activity android:name="NoteEditor"…>

改成<service class=”.service.MyService”>


使用Service:
   应用程序可以通过调用 Context.startService方法来启动Service。如果当前没有指定的Service实例被创建,则该方法会调用 Service的onCreate方法来创建一个实例;否则调用Service的onStart方法。参见下列代码:

Intent serviceIntent = new Intent();
serviceIntent.setAction(
”com.wissen.testApp.service.MY_SERVICE”);
startService(serviceIntent);//也许你会说为什么没有contexta啊,因为activity是                      context的继承,也就是context上面等价this. startService

也就是context. startService

和activity的使用也没什么差别,将startActivity

 变成startService,其他的就不详谈。

content-provider

      其实在activity和intent都说到了content-provider.不过说的只是provider的gettype功能在寻找activity的作用,其实provider还有其他的作用,且是主要作用,那就是内容提供商。应用程序可以在Content Provider中执行如下操作:

 

Content-provider要提供五个功能。


查询数据

修改数据

添加数据

删除数据

返回数据类型

分别对应:

public int delete(Uri uri, String selection, String[] selectionArgs) {

       // TODO Auto-generated method stub

       return 0;

    }

 

    @Override

    public String getType(Uri uri) {

       // TODO Auto-generated method stub

       return null;

    }

 

    @Override

    public Uri insert(Uri uri, ContentValues values) {

       // TODO Auto-generated method stub

       return null;

    }

 

    @Override

    public boolean onCreate() {

       // TODO Auto-generated method stub

       return false;

    }

 

    @Override

    public Cursor query(Uri uri, String[] projection, String selection,

           String[] selectionArgs, String sortOrder) {

       // TODO Auto-generated method stub

       return null;

    }

 

    @Override

    public int update(Uri uri, ContentValues values, String selection,

           String[] selectionArgs) {

       // TODO Auto-generated method stub

       return 0;

    }

这些都要你自己实现,不同的实现就是对应不同的content-provider。

但是activity使用content-provider不是直接创建一个对象,然后调用这些具体方法。

而是调用managedQuery,getContentResolver().delete,update等来实现,这些函数其实是先找到符合条件的content-provider,然后再调用具体的content-provider的函数来实现,那又是怎么找到content-provider,就是通过uri中的authority来找到content-provider,这些都是通过系统完成,应用不用管,这样有效的隔离了应用和内容提供商具体实现。

   利用uri如何找到content-provider在前面已经讲过了,就不讲了。

到此为止,android程序的框架就讲完了,具体就看对API的把握,及其他内容的深入了解了。

后记:

Anroid平台:

  非常佩服google,google的android刚出来就这么引人瞩目,且吸引这么都人去从事这个,这就是google的强大。android不仅仅是一个优化了的嵌入式linux操作系统,也不仅仅是java开发环境,也不仅仅是改版的java虚拟机Dalvik,也不仅仅是创新android窗体系统,而是整个平台,这一整个平台的各个部分google都针对嵌入式应用做了优化。结果是,这平台大大降低了开发者进入门槛,只要你会java你就可以开发,同时平台的设计考虑,使得其在嵌入式终端上运行的效率也能得到保证,估计也只有google这种大公司,极具创新的公司才有这种实力和魄力。google的几十万linux服务器可以看出其在Linux上的实力,同时google的创新能力不让人怀疑其能够提出一些创新的框架,有了这些,不难看出google搞出android是实至名归。

   估计大家当初用c#就是看好c#程序的开发非常方便,容易上手,现在嵌入式的软件的开发随着android平台的诞生也将变得如此容易,也难怪越来越多的手机厂商将采用android平台。

   同时手机应用商店的模式,使得应用程序员可以靠开发养活自己,靠开发赚钱,靠开发支撑一个公司,所以现在越来越多的商业公司切入到android应用软件开发中了,而不单单是个人或团队程序员的专利了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值