当前位置:  编程技术>移动开发
本页文章导读:
    ▪index -一 requested , with a size of 1        index -1 requested , with a size of 1   访问行如下:  int type =  blackWhiteCursor.getInt(blackWhiteCursor.getColumnIndex(Filters.TYPE)); 出现log信息:   05-06 10:10:06.865: ERROR/AndroidRuntime(4061): Caused by: android.database.Curso.........
    ▪ 引见桌面widgets和AppWidget框架        介绍桌面widgets和AppWidget框架 本文翻译自Android Developers Blog:Introducing home screen widgets and the AppWidget frameworkAndroid 1.5 SDK一个令人兴奋的新特性是AppWidget framework,这个框架允许开发者开发widgets.........
    ▪ Contacts的构造       Contacts的结构 private String testOne() throws Exception {                      final Cursor people = getContentResolver().query(Contacts.CONTENT_URI, null, null, null, null);             StringBuilder sb = new Stri.........

[1]index -一 requested , with a size of 1
    来源: 互联网  发布时间: 2014-02-18
index -1 requested , with a size of 1

 

访问行如下: 

int type =  blackWhiteCursor.getInt(blackWhiteCursor.getColumnIndex(Filters.TYPE));

出现log信息:

 

05-06 10:10:06.865: ERROR/AndroidRuntime(4061): Caused by: android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 1

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at android.database.AbstractCursor.checkPosition(AbstractCursor.java:580)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:214)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at android.database.AbstractWindowedCursor.getInt(AbstractWindowedCursor.java:84)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at android.database.CursorWrapper.getInt(CursorWrapper.java:123)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at cn.flyfot.filter.callfilter.RuleService.blockCommonModehandler(RuleService.java:293)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at cn.flyfot.filter.callfilter.RuleService.blockingHandler(RuleService.java:574)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at cn.flyfot.filter.callfilter.PhoneStateListenerReceiver.blockingHandler(PhoneStateListenerReceiver.java:172)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at cn.flyfot.filter.callfilter.PhoneStateListenerReceiver.doReceiver(PhoneStateListenerReceiver.java:57)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at cn.flyfot.filter.callfilter.PhoneStateListenerReceiver.onReceive(PhoneStateListenerReceiver.java:39)

05-06 10:10:06.865: ERROR/AndroidRuntime(4061):     at android.app.ActivityThread.handleReceiver(ActivityThread.java:2810)


解决问题:
出现以上错误是由于没有移动游标或是没有查询到需要的数据而移动了游标强制获取某一行数据而导致的,注意查询条件和右边移动。

1 楼 chen299135 2012-04-14  

package com.gallery.detail;

import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.database.Cursor;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.provider.MediaStore.Images.Media;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;

/**
* 该类完成图片的检索,显示功能
*
* @author Administrator
*
*/
public class DetailActivity extends Activity implements OnClickListener {
private ImageView photo;
private Button next = null;
private Button previous = null;
private Button message = null;
private TextView position = null;
private Cursor cursor;
private int photoIndex;
private int photoNameIndex;
private int photoIDIndex;
private int photoTitleIndex;
private int photoSizeIndex;
private String Message = null;
private int totalNum = 0;

public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
next = (Button) findViewById(R.id.next);
next.setOnClickListener(this);
previous = (Button) findViewById(R.id.previous);
previous.setOnClickListener(this);
message = (Button) findViewById(R.id.message);
message.setOnClickListener(this);
photo = (ImageView) this.findViewById(R.id.image_view);
position = (TextView) findViewById(R.id.number);
// 指定获取的列
String columns[] = new String[] { Media.DATA, Media._ID, Media.TITLE,
Media.DISPLAY_NAME, Media.SIZE };
// 得到一个游标

cursor = this.getContentResolver().query(Media.EXTERNAL_CONTENT_URI,
columns, null, null, null);
// 获取指定列的索引
photoIndex = cursor.getColumnIndexOrThrow(Media.DATA);
System.out.println("photoIndex" + photoIndex);
photoNameIndex = cursor.getColumnIndexOrThrow(Media.DISPLAY_NAME);
photoIDIndex = cursor.getColumnIndexOrThrow(Media._ID);
photoTitleIndex = cursor.getColumnIndexOrThrow(Media.TITLE);
photoSizeIndex = cursor.getColumnIndexOrThrow(Media.SIZE);
// 获取图片总数
totalNum = cursor.getCount();
System.out.println("共有这么多图片"+totalNum);
System.out.println("IDyyy:" + cursor.getInt(photoNameIndex));
// 跳到第一个图片
if (cursor.moveToFirst()) {
setImage();
position.setText("(1/" + totalNum + ")");
}
}

public void onClick(View arg0) {
switch (arg0.getId()) {
// 下一个
case R.id.next:
if (cursor.moveToNext()) {
setImage();

}
break;
// 上一个
case R.id.previous:
if (cursor.moveToPrevious()) {
setImage();
}
break;
case R.id.message:
// Dialog显示详细信息
AlertDialog.Builder builder = new AlertDialog.Builder(
DetailActivity.this);
builder.setTitle("详细信息");
builder.setMessage(Message);
builder.setPositiveButton("关闭",
new android.content.DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
});
builder.show();
break;
}
}

private void setImage() {
// 获取图片的Name
String name = cursor.getString(photoNameIndex);
// 获取图片的ID
String number = cursor.getString(photoIDIndex);
System.out.println("IDyyy:" + cursor.getInt(photoNameIndex));
// 获取图片的Title
String title = cursor.getString(photoTitleIndex);
// 获取图片的大小
String size = cursor.getString(photoSizeIndex);
// 获取图片存储路径
String path = cursor.getString(photoIndex);
// 为TextView:position赋值(现在所在的位置)
position.setText("(" + number + "/" + totalNum + ")");
Message = "Name:" + name + "\n" + "Number:" + number + "\n" + "ID:"
+ cursor.getInt(photoIDIndex) + "Title:" + title + "\n"
+ "Size:" + size + "\n" + "Path:" + path;
// 通过路径获取图片
Drawable image = Drawable.createFromPath(path);
photo.setImageDrawable(image);
}
}

04-14 20:39:50.060: ERROR/AndroidRuntime(9771): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.gallery.detail/com.gallery.detail.DetailActivity}: android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 39

我想查询所有图片的id,楼主有办法么?
2 楼 chen299135 2012-04-14  
这个项目比较急,都愁了很久了。。。

    
[2] 引见桌面widgets和AppWidget框架
    来源: 互联网  发布时间: 2014-02-18
介绍桌面widgets和AppWidget框架
本文翻译自Android Developers Blog:Introducing home screen widgets and the AppWidget framework
Android 1.5 SDK一个令人兴奋的新特性是AppWidget framework,这个框架允许开发者开发widgets,这些widgets可以被用户拖到用户的桌面并且可以交互。
widgets可以提供一个full-featured apps的预览,例如可以显示即将到来的日历事件,或者一首后台播放的歌曲的详细信息。
当widgets被拖到桌面上,他们被指定一个保留的空间来显示应用提供的自定义内容。用户可以通过这个widget来和你的应用交互,例如暂停或切换歌曲。如果你有一个后台服务,你可以按照你自己的schedule更新你的widget,或者使用AppWidget framework提供的一个自动的更新机制。
在更高层次上,每个widget就是一个BroadcastReceiver,他们用XML metadata来描述widget的细节。AppWidget framework通过broadcast intents和你的widget通信,例如当需要更新的时候。Widget更新使用RemoteViews被构建和发送。这个RemoteViews被包装成一个layout和特定内容来显示到桌面上。
你可以非常容易的添加widgets到你的应用中,在这篇文章里我将给一个简单的例子:写一个widget来显示Wiktionary “Word of the day.”你可以从这里获取所有的源代码,我将在这里解释Appwidget相关的代码。
首先,你需要一个XML metadata描述这个widget,包括你想在桌面上保留的区域,一个你想展示的初始的layout,和你打算何时更新。Android桌面默认使用cell-based layout,因而它会rounds你请求的尺寸为最接近的cell的尺寸。这是有点疑惑,不过这里有个公式可以帮助你:
Minimum size in dip = (Number of cells * 74dip) – 2dip
在这个例子中,我想使我们的widget占用2 cells的宽度和1 cell的高度,这意味着我应该请求的最小尺寸为146dip * 72dip。我们将要每天更新一次我们的widget,大约是每86,400,000毫秒更新一次。以下是我们的widget的XML metadata:
接下来,让我们把XML metadata捆绑到AndroidManifest的BroadcasrReicever:

最后,让我们写BroadcastReceiver的代码来处理AppWidget的请求。为了帮助widgets管理所有broadcasr事件,有个helper class叫AppWidgetProvider,这里我们将使用这个类。其中需要注意的最重要的一件事是我们将调用一个后台服务执行定期的更新。这是因BroadcastReceivers是一个Application Not Responding(ANR) timer,这意味着如果运行时间太长,可能需要提示用户强制关闭我们的应用。制作一个web请求可能需要花费一些时间,因此我们使用服务来避免ANR timeouts.

/**
* Define a simple widget that shows the Wiktionary “Word of the day.” To build
* an update we spawn a background {@link Service} to perform the API queries.
*/
public class WordWidget extends AppWidgetProvider {
@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
int[] appWidgetIds) {
// To prevent any ANR timeouts, we perform the update in a service
context.startService(new Intent(context, UpdateService.class));
}

public static class UpdateService extends Service {
@Override
public void onStart(Intent intent, int startId) {
// Build the widget update for today
RemoteViews updateViews = buildUpdate(this);

// Push update for this widget to the home screen
ComponentName thisWidget = new ComponentName(this, WordWidget.class);
AppWidgetManager manager = AppWidgetManager.getInstance(this);
manager.updateAppWidget(thisWidget, updateViews);
}

/**
* Build a widget update to show the current Wiktionary
* “Word of the day.” Will block until the online API returns.
*/
public RemoteViews buildUpdate(Context context) {
// Pick out month names from resources
Resources res = context.getResources();
String[] monthNames = res.getStringArray(R.array.month_names);

// Find current month and day
Time today = new Time();
today.setToNow();

// Build today’s page title, like “Wiktionary:Word of the day/March 21″
String pageName = res.getString(R.string.template_wotd_title,
monthNames[today.month], today.monthDay);
RemoteViews updateViews = null;
String pageContent = “”;

try {
// Try querying the Wiktionary API for today’s word
SimpleWikiHelper.prepareUserAgent(context);
pageContent = SimpleWikiHelper.getPageContent(pageName, false);
} catch (ApiException e) {
Log.e(”WordWidget”, “Couldn’t contact API”, e);
} catch (ParseException e) {
Log.e(”WordWidget”, “Couldn’t parse API response”, e);
}

// Use a regular expression to parse out the word and its definition
Pattern pattern = Pattern.compile(SimpleWikiHelper.WORD_OF_DAY_REGEX);
Matcher matcher = pattern.matcher(pageContent);
if (matcher.find()) {
// Build an update that holds the updated widget contents
updateViews = new RemoteViews(context.getPackageName(), R.layout.widget_word);
String wordTitle = matcher.group(1);
updateViews.setTextViewText(R.id.word_title, wordTitle);
updateViews.setTextViewText(R.id.word_type, matcher.group(2));
updateViews.setTextViewText(R.id.definition, matcher.group(3).trim());

// When user clicks on widget, launch to Wiktionary definition page
String definePage = res.getString(R.string.template_define_url,
Uri.encode(wordTitle));
Intent defineIntent = new Intent(Intent.ACTION_VIEW, Uri.parse(definePage));
PendingIntent pendingIntent = PendingIntent.getActivity(context,
0 /* no requestCode */, defineIntent, 0 /* no flags */);
updateViews.setOnClickPendingIntent(R.id.widget, pendingIntent);

} else {
// Didn’t find word of day, so show error message
updateViews = new RemoteViews(context.getPackageName(),
R.layout.widget_message);
CharSequence errorMessage = context.getText(R.string.widget_error);
updateViews.setTextViewText(R.id.message, errorMessage);
}
return updateViews;
}

@Override public IBinder onBind(Intent intent) {
// We don’t need to bind to this service
return null;
}
}
}
到这里,你已经完成了一个简单的widget,它将显示Wiktionary “Word of the day.”。当一个更新被请求时,我们读在线API将最新的数据push到widget上。AppWidget framework会按我们的需要自动更新,例如当一个新的widget添加时,或者新的一天加载新的Word of the day.”。
最后,这里给出一些建议。
Widgets推荐被设计成longer-term的内容,不应该经常的被更新。超过每小时的频繁更新会快速消耗掉电量和带宽。建议尽可能的不要频繁更新,或者让你的用户自定义一个更新周期。例如有些人可能想stock ticker每15分钟更新一次,或者可能是一天更新四次。
最后要提的一件比较酷的事是AppWidget framework对方向并不关心(is abstracted in both directions).这意味着你可以在两个home screen都可以包含widgets。你的widgets可以被添加到任何一个支持AppWidgetframework的home screen上。

    
[3] Contacts的构造
    来源: 互联网  发布时间: 2014-02-18
Contacts的结构
private String testOne() throws Exception {  
          
        final Cursor people = getContentResolver().query(Contacts.CONTENT_URI, null, null, null, null);  
 
        StringBuilder sb = new StringBuilder();  
        while(people.moveToNext()) {  
            long id = people.getLong(people.getColumnIndex(Contacts._ID));  
            String name = people.getString(people.getColumnIndex(PhoneLookup.DISPLAY_NAME));  
            if(id==1) {  
                  
                sb.append("---id is "+id+",name is "+name+"\n");  
                  
                //String IsPhone = people.getString(people.getColumnIndex(Contacts.HAS_PHONE_NUMBER));  
                //if( (Integer.parseInt(IsPhone) > 0) ){}  
                  
                Cursor c = null;   
            // Cursor c = getContentResolver().query(CommonDataKinds.Phone.CONTENT_URI,   
            //      null,CommonDataKinds.Phone.CONTACT_ID+"="+id,null,null);  
            //while(c.moveToNext()){  
            //  long i = c.getLong(c.getColumnIndex(Contacts._ID));  
            //    String num=c.getString(c.getColumnIndex(CommonDataKinds.Phone.NUMBER));  
            //    sb.append("phone=id:"+i+", n:"+num+"\n");  
            //}  
            //c.close();  
                  
                c=getContentResolver().query(Data.CONTENT_URI, null, Data.CONTACT_ID+"="+id, null, null);  
                while(c.moveToNext()){  
                    long j=c.getLong(c.getColumnIndex(Contacts._ID));  
                    String typ=c.getString(c.getColumnIndex(Data.MIMETYPE));  
                    String str="";  
                    if(typ.equals(CommonDataKinds.Im.CONTENT_ITEM_TYPE)){  
                        str=c.getString(c.getColumnIndex(CommonDataKinds.Im.PROTOCOL))+",";  
                        str+=c.getString(c.getColumnIndex(CommonDataKinds.Im.DATA));  
                    }  
                    else if(typ.equals(CommonDataKinds.Email.CONTENT_ITEM_TYPE)){  
                        str=c.getString(c.getColumnIndex(CommonDataKinds.Email.TYPE))+",";  
                        str+=c.getString(c.getColumnIndex(CommonDataKinds.Email.DATA));  
                    }  
                    else if(typ.equals(CommonDataKinds.Note.CONTENT_ITEM_TYPE)){  
                        str=c.getString(c.getColumnIndex(CommonDataKinds.Email.DATA));  
                    }  
                    else if(typ.equals(CommonDataKinds.Phone.CONTENT_ITEM_TYPE)){  
                        str=c.getString(c.getColumnIndex(CommonDataKinds.Phone.TYPE))+",";  
                        str+=c.getString(c.getColumnIndex(CommonDataKinds.Phone.DATA));  
                    }  
                    else if(typ.equals(CommonDataKinds.Photo.CONTENT_ITEM_TYPE)){  
                        byte[] buf = c.getBlob(c.getColumnIndex(CommonDataKinds.Photo.PHOTO));  
                        str="len is "+buf.length;  
                    }  
                    else if(typ.equals(CommonDataKinds.Nickname.CONTENT_ITEM_TYPE)){  
                        str=c.getString(c.getColumnIndex(CommonDataKinds.Nickname.TYPE))+",";  
                        str+=c.getString(c.getColumnIndex(CommonDataKinds.Nickname.DATA));  
                    }  
                    sb.append("data=id"+j+", t:"+typ+"\n, n:"+str+"\n");  
                }  
                c.close();  
                  
                  
            }  
              
        }  
          
        people.close();  
        return sb.toString();  
    } 

    
最新技术文章:
▪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详解
windows iis7站长之家
▪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