当前位置:  编程技术>移动开发
本页文章导读:
    ▪widget的设计与使用        widget的设计与应用 1.AppWidgetProviderInfo对象      这个对象为AppWidget提供元数据,包括布局、更新频率等信息,这个对象定义在xml文件中,不需要自己生成,时系统自己生成的。2.AppWidgetPro.........
    ▪ 应用SlideMenu和ActionBarSherlock libs时,怎样让slidemenu展开时,actionbar也缩进去        使用SlideMenu和ActionBarSherlock libs时,怎样让slidemenu展开时,actionbar也缩进去。 Setup with ActionBarSherlockSetup as above.Checkout a clean copy of ActionBarSherlock and import into your Eclipse workspace.Add ActionBarSherlock.........
    ▪ QuickContactBadge 联系人效能控件       QuickContactBadge 联系人功能控件     在Activity中存在一个图标,点击该图标后弹出一个窗口,窗口中会有几个图标,不同的图标表示针对该联系人进行的不同操作,比如打电话,发短信,发送.........

[1]widget的设计与使用
    来源: 互联网  发布时间: 2014-02-18
widget的设计与应用
1.AppWidgetProviderInfo对象

      这个对象为AppWidget提供元数据,包括布局、更新频率等信息,这个对象定义在xml文件中,不需要自己生成,时系统自己生成的。

2.AppWidgetProvider

      这个类定义了AppWidget的基本生命周期函数,具体如下:

onReceive(Context, Intent)   接收广播事件
onUpdate(Context , AppWidgetManager, int[] appWidgetIds)  到达指定的更新时间或用户向桌面添加widget时候调用
onEnabled(Context)  当AppWidget实例第一次被创建时调用
onDeleted(Context, int[] appWidgetIds)  当AppWidget被删除时调用
onDisabled(Context)  当最后一个AppWidget被删除时调用

四.创建AppWidget的基本步骤

1.定义AppWidgetProviderInfo:在res中新建文件夹xml,在其中定义AppWidget_ProviderInfo.xml文件,主要设置的参数如下:
minWidth: 定义Wdiget组件的宽度
minHeight: 定义Wdiget组件的高度
updatePeriodMillis: 更新的时间周期
initialLayout: Widget的布局文件

代码示例:

<?xml version="1.0" encoding="utf-8"?> 

<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" 

      android:minWidth="80dp" 

      android:minHeight="32dp" 

      android:updatePeriodMillis="86400000" 

      android:initialLayout="@layout/appwidgetlayout"   > 

</appwidget-provider>

其中的appwidgetlayout为layout文件夹下面新建一个xml文件,在这个文件中描述了appWidget的控件和布局等等信息,如:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:orientation="horizontal"
  android:background="@drawable/appbackground"
  android:gravity="center">
 
  <TextView
   android:id="@+id/title"
   android:layout_width="90dip"
   android:layout_height="wrap_content"
   android:text="无歌曲播放"
   android:textColor="#ffffff"
   android:textSize="15dip"
   android:layout_marginLeft="30dip"
   />
    <ImageButton
   android:id="@+id/lastButton"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:background="@drawable/latest_selecor"
   android:layout_marginRight="5dip"
   />
 
  <ImageButton
   android:id="@+id/playButton"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_marginRight="5dip"
   android:layout_marginLeft="5dip"

   />
  <ImageButton
   android:id="@+id/nextButton"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:background="@drawable/next_selecor"
   android:layout_marginLeft="5dip"
   />
  </LinearLayout>

2.为AppWidget指定布局和样式,即此AppWidget在手机桌面上显示的样式,其实就是一个布局xml文件。需要注意的是使用的组件必须是RemoteViews所支持的,目前原生API中支持的组件如下:
FrameLayout
LinearLayout
RelativeLayout

AnalogClock
Button
Chronmeter
ImageButton
ImageView
ProgressBar
TextView
如果使用了除此之外的组件,则在Widget创建时会导致android.view.InflateExceptionn异常。这就导致有一些功能或样式无法实现,如很基本的list或文本编辑框都是无法直接实现的。

3.实现AppWidgetProvider。

      覆写其中的回调函数,后边会详细介绍。

4.在AndroidManifest.xml中声明(用receiver标签声明)

   <receiver android:name="music.dreamer.useful.AppWidget">
         <meta-data android:name="android.appwidget.provider" //name固定这么写
            android:resource="@xml/appwidgetprovider"/>//在xml文件夹下建立的AppWidgetProviderInfo文件
         <intent-filter>
                <action android:name="android.appwidget.action.APPWIDGET_UPDATE"></action> //接收什么样的广播,默认的action有4种,对应除onReceive外的4种生命周期函数,也可以自己写。自己写的如以下4个:

             <action android:name="music.dreamer.playmusic"></action>
             <action android:name="music.dreamer.pause"></action>
             <action android:name="music.dreamer.play"></action>
             <action android:name="music.dreamer.musictitle"></action>
            </intent-filter>
        </receiver>

五.在AppWidget中使用控件

1.一个重要的概念

      AppWidget和其原本的App并不在同一个进程中,而是运行在HomeScreen进程当中,因此,在控件监听器的绑定,更新等操作都会与以前基本的方法有所不同。

2.PendingIntent

(1)概念

      PendingIntent是一个特殊的Intent,实际上它像一个邮包,其中包裹着真正的Intent,当邮包未打开时,Intent是被“挂起”的,所以并不执行,只有当邮包拆开时才会执行。它与Intent的区别在于:Intent 是及时启动,intent 随所在的activity 消失而消失。
PendingIntent 可以看作是对intent的包装,通常通过getActivity,getBroadcast ,getService来得到pendingintent的实例,当前activity并不能马上启动它所包含的intent,而是在外部执行 pendingintent时,调用intent的。正由于pendingintent中 保存有当前App的Context,使它赋予外部App一种能力,使得外部App可以如同当前App一样的执行pendingintent里的 Intent, 就算在执行时当前App已经不存在了,也能通过存在pendingintent里的Context照样执行Intent。另外还可以处理intent执行后的操作。常和alermanger 和notificationmanager一起使用。
Intent一般是用作Activity、Sercvice、BroadcastReceiver之间传递数据,而Pendingintent,一般用在 Notification上,可以理解为延迟执行的intent,PendingIntent是对Intent一个包装。

(2)执行过程

      进程A创建PendingIntent,发送给进程B,进程B此事并不执行,直到用户出发某一事件时,包裹被拆开,里面的Intent真正执行。所以Intent什么时候被执行是不知道的,由用户出发事件来决定,整个过程类似回调函数的原理。

(3)创建

有三种方法创建PendingIntent:

getActivity(Context context,int requestCode,Intent intent,int flags)        这时的PendingIntent作用是启动一个新的Activity

getBroadcast(Context context,int requestCode,Intent intent,int flags)   这时的PendingIntent作用是发送一个广播

getService(Context context,int requestCode,Intent intent,int flags)       这时的PendingIntent作用是启动一个Service

3.RemoteViews

(1)RemoteViews表示了一系列view对象,即AppWidget所有的控件。

(2)RemoteViews所标示的对象都运行在另外的进程中。

(3)应用

      RemoteViews.setOnClickPendingIntent(R.id.widgetButtonId,pendingIntent);      //第一个参数就是需要绑定的控件,

                                                                                                                                 //第二个参数是点击后触发执行的PendingIntent。

4.为控件绑定监听器的实现(点击按钮,开启新的Activity)

   @Override 

    public void onUpdate(Context context, AppWidgetManager appWidgetManager, 

            int[] appWidgetIds) {      //appWidgetManager用来管理appWidget,而appWidgetIds[]指的是,每当新建一个appWidget,

                                                  //系统就会给新建的appWidget一个ID,而这个数组中储存的就是这些ID。

        // TODO Auto-generated method stub  

        final int N = appWidgetIds.length; 

        for (int i = 0; i < N; i++) { 

         //创建Intent 对象

         Intent intent=new Intent(context,TargetActivity,.class);

         //创建PendingIntent  对象,即把intent装进pendingIntent中

         PendingIntent  pendingIntent=new PendingIntent.getActivity(context,0,intent,0);

         //通过布局文件得到RemoteViews 对象

         RemoteViews remoteViews=new RemoteViews (context.getPackageName,R.layout.my_AppWidget);

         //绑定监听事件,即当widgetButtonId控件有onClick事件时,会执行pendingIntent(就是之前所说的拆邮包)

         remoteViews.setOnClickPendingIntent(R.id.widgetButtonId,pendingIntent);

         //使用appWidgetManager更新AppWidge。第一个参数指明更新的是哪一个appWidgetId,第二个参数指明了更新的远程Views。

         appWidgetManager.updateAppWidget(appWidgetIds[i],remoteViews);  

        } 

         super.onUpdate(context,appWidgetManager,appWidgetIds);

    } 

六.接收AppWidget中的广播(AppWidget与AppWidgetProvider的互动)

1.机制

      其实,AppWidgetProvider就是一个广播接收器。在AppWidgetProvider中,pendingIntent传来后由onReceive方法接收,之后检查intent对象中的action,由action来决定分发给哪一个函数。Android默认设置了四种action,对应了除onReceive外剩下的四种方法。因此,我们可以理解为AppWidgetProvider中的方法其实又依赖于onReceive。

2.实现步骤

(1)在AndroidManifest.xml中为AppWidgetProvider注册intent-filter,如前介绍。

(2)使用getBroadcast方法创建一个PendingIntent对象。

(2)为AppWidget中的控件注册处理器(即绑定监听器)。

(4)在onReceive方法中接收广播消息。

3.代码示例(本人写的更新播放按钮的WIDGET)

  @Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
   int[] appWidgetIds) {
  Log.i("info", "onUpdate...");
  RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.appwidgetlayout);
  /*设置播放键的动作*/
  views.setImageViewResource(R.id.playButton, R.drawable.play_selecor);
  Intent playIntent = new Intent(PLAY_ACTION);

  //设置pendingIntent的作用
  PendingIntent playPending = PendingIntent.getBroadcast(context, 0, playIntent, 0);
  views.setOnClickPendingIntent(R.id.playButton, playPending);
  /*设置上一首按钮的动作*/
  Intent lastIntent = new Intent(lAST_ACTION);
  PendingIntent lastPending = PendingIntent.getBroadcast(context, 0, lastIntent, 0);
  views.setOnClickPendingIntent(R.id.lastButton, lastPending);
  /*设置下一首按钮的动作*/
  Intent nextIntent = new Intent(NEXT_ACTION);
  PendingIntent nextPending = PendingIntent.getBroadcast(context, 0, nextIntent, 0);
  views.setOnClickPendingIntent(R.id.nextButton, nextPending);
 
  /*获取正在播放的音乐名*/
  Intent intent = new Intent();
  intent.setAction(START_APP);
  context.sendBroadcast(intent);
   //使用appWidgetManager更新AppWidge。第一个参数指明更新的是哪一个appWidgetId,第二个参数指明了更新的远程Views。
  appWidgetManager.updateAppWidget(appWidgetIds, views);
}

      之后覆写onReceive方法,实现接收广播后需要执行的操作即可(如“七”将要介绍)。当点击button时,会触发pendingIntent的执行,这时候会发送一个广播,而onReceive会接收广播并执行相应操作。

七.更新AppWidget中控件的状态

1.AppWidget中的更新操作是使用RemoteViews的一系列方法进行的。(比如更换图片:RemoteViews.setImageViewResource等)

2.更新后应记得使用AppWidgetManager通知AppWidget进行更新。

3.代码示例

说明:这里实现的即是点击某按钮,发送一个广播,在onReceive方法里实现更新操作,即需要覆写onReceive方法。

@Override
public void onReceive(Context context, Intent intent) {
  RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.appwidgetlayout);
  if (intent.getAction().equals("music.dreamer.pause")){
   views.setImageViewResource(R.id.playButton, R.drawable.play_selecor);
  } else if (intent.getAction().equals("music.dreamer.play")){

//将id为playButton的控件中的图片更新为pause_selecor

   views.setImageViewResource(R.id.playButton, R.drawable.pause_selecor);
  } else if (intent.getAction().equals("music.dreamer.musictitle")){
   String musicName = intent.getExtras().getString("title");
   if (musicName.length()>6){
    musicName = musicName.substring(0, 5)+"...";
   }
   views.setTextViewText(R.id.title, musicName);
  }
  AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(context);
        ComponentName componentName = new ComponentName(context,AppWidget.class);

      //通知AppWidgetProvider更新
        appWidgetManager.updateAppWidget(componentName, views);
  Log.i("info", "onReceive...");
  super.onReceive(context, intent);
}

    
[2] 应用SlideMenu和ActionBarSherlock libs时,怎样让slidemenu展开时,actionbar也缩进去
    来源: 互联网  发布时间: 2014-02-18
使用SlideMenu和ActionBarSherlock libs时,怎样让slidemenu展开时,actionbar也缩进去。
Setup with ActionBarSherlock
Setup as above.
Checkout a clean copy of ActionBarSherlock and import into your Eclipse workspace.
Add ActionBarSherlock as a dependency to SlidingMenu
Go into the SlidingActivities that you plan on using make them extend Sherlock___Activity instead of ___Activity.


https://github.com/jfeinstein10/SlidingMenu#setup-with-actionbarsherlock

    
[3] QuickContactBadge 联系人效能控件
    来源: 互联网  发布时间: 2014-02-18
QuickContactBadge 联系人功能控件

一、简介
    QuickContact是为了应用程序能够快速方便的访问联系人,并且快速的运用联系人的信息执行相应操作而设计的。最常见的在Contacts应用程序中如下图所示:

    在Activity中存在一个图标,点击该图标后弹出一个窗口,窗口中会有几个图标,不同的图标表示针对该联系人进行的不同操作,比如打电话,发短信,发送邮件,进入主页等等。图标的显示和不显示取决于该联系人是否存在该种操作相关的信息。比如,如果该联系人中如果存在邮箱的话,就可以出现发送邮件的图标,否则就不会出现。


二、在自己的应用程序中应用QuickContact
    在自己的程序中加入QuickContact十分方便,可以用Framework中的组件QuickContactBadge。
    比如,我们创建一个Activity,设置它的layout如下:

  • <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  •               android:orientation="vertical" 
  •               android:layout_width="fill_parent" 
  •               android:layout_height="fill_parent" 
  •         > 
  •     <QuickContactBadge 
  •             android:id="@+id/badge_small" 
  •             android:layout_width="wrap_content" 
  •             android:layout_height="wrap_content" 
  •             android:src="/blog_article/@drawable/icon/index.html"> 
  •     </QuickContactBadge> 
  • </LinearLayout> 
  •     Activity的onCreate代码如下:

  • QuickContactBadge smallBadge = (QuickContactBadge) findViewById(R.id.badge_small); 
  • smallBadge.assignContactFromEmail("winuxxan@gmail.com", true); 
  • smallBadge.setMode(ContactsContract.QuickContact.MODE_LARGE); 
  •     主要还有一点,要在AndroidManifest中设置android.permission.READ_CONTACTS的权限,否则,不会弹出窗口,而是直接进入Contacts中的联系人详情界面。
        运行效果如图:

        由于本文不是针对QuickContactBadge的详细讲解,而是讲解它的实现方法,从而能够见贤思齐,设计出类似的功能。要了解QuickContactBadge的详细用法可以看Android文档,和google。


        
    最新技术文章:
    ▪Android开发之登录验证实例教程
    ▪Android开发之注册登录方法示例
    ▪Android获取手机SIM卡运营商信息的方法
    ▪Android实现将已发送的短信写入短信数据库的...
    ▪Android发送短信功能代码
    ▪Android根据电话号码获得联系人头像实例代码
    ▪Android中GPS定位的用法实例
    ▪Android实现退出时关闭所有Activity的方法
    ▪Android实现文件的分割和组装
    ▪Android录音应用实例教程
    ▪Android双击返回键退出程序的实现方法
    ▪Android实现侦听电池状态显示、电量及充电动...
    ▪Android获取当前已连接的wifi信号强度的方法
    ▪Android实现动态显示或隐藏密码输入框的内容
    ▪根据USER-AGENT判断手机类型并跳转到相应的app...
    ▪Android Touch事件分发过程详解
    ▪Android中实现为TextView添加多个可点击的文本
    ▪Android程序设计之AIDL实例详解
    ▪Android显式启动与隐式启动Activity的区别介绍
    ▪Android按钮单击事件的四种常用写法总结
    ▪Android消息处理机制Looper和Handler详解
    ▪Android实现Back功能代码片段总结
    ▪Android实用的代码片段 常用代码总结
    ▪Android实现弹出键盘的方法
    ▪Android中通过view方式获取当前Activity的屏幕截...
    ▪Android提高之自定义Menu(TabMenu)实现方法
    ▪Android提高之多方向抽屉实现方法
    ▪Android提高之MediaPlayer播放网络音频的实现方法...
    ▪Android提高之MediaPlayer播放网络视频的实现方法...
    ▪Android提高之手游转电视游戏的模拟操控
     


    站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3