Я пишу приложение для Твиттера и следую руководству Linkify от разработчиков Android (http://android -deve..linkify-your-text.html ) для создания имен пользователей (например, @ brk3 ) кликабелен.
Затем я создал реализацию контент-провайдера, чтобы выбрать намерения, которые запускаются при нажатии. Моя проблема в том, что намерение, похоже, не находит моего провайдера, поэтому при нажатии на одну из ссылок я получаю следующее исключение: (например, при нажатии на имя пользователя 'Arubin')
E/AndroidRuntime( 5228): android.content.ActivityNotFoundException: No Activity found to handle Intent {
act=android.intent.action.VIEW dat=content://com.bourke.test/screenname/Arubin (has extras) }
E/AndroidRuntime( 5228): at android.app.Instrumentation.checkStartActivityResult(Instrumentation.j
ava:1512)
E/AndroidRuntime( 5228): at android.app.Instrumentation.execStartActivity(Instrumentation.java:138
4)
...
Вот соответствующий фрагмент моего AndroidManifest.xml:
<application
android:label="@string/app_name"
android:icon="@drawable/ic_launcher"
android:name="TestApplication"
android:uiOptions="splitActionBarWhenNarrow">
<provider
android:name="com.bourke.test.provider.TestProvider"
android:authorities="com.bourke.test.provider" />
<activity android:name="TestActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<data android:mimeType=
"vnd.android.cursor.item/vnd.test.screenname" />;
</intent-filter>
</activity>
...
И провайдер:
package com.bourke.test.provider;
public class TestProvider extends ContentProvider {
/* The root authority for this provider */
public static final String AUTHORITY = "com.bourke.test.provider";
private static final String BASE_PATH = "screenname";
public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY
+ "/" + BASE_PATH);
public static final int SCREEN_NAMES = 0;
public static final int SCREEN_NAME = 1;
private static final UriMatcher mUriMatcher = new UriMatcher(
UriMatcher.NO_MATCH);
static {
mUriMatcher.addURI(AUTHORITY, BASE_PATH, SCREEN_NAMES);
mUriMatcher.addURI(AUTHORITY, BASE_PATH+"/*", SCREEN_NAME);
}
@Override
public boolean onCreate() {
Log.d(TAG, "XXX: onCreate()");
/* The provider was successfully loaded */
return true;
}
@Override
public int update(Uri uri, ContentValues values, String where,
String[] whereArgs) {
throw new UnsupportedOperationException();
}
@Override
public int delete(Uri uri, String where, String[] whereArgs) {
throw new UnsupportedOperationException();
}
@Override
public Uri insert(Uri uri, ContentValues initialValues) {
throw new UnsupportedOperationException();
}
@Override
public String getType(Uri uri) {
Log.d(TAG, "XXX: getType()");
switch (mUriMatcher.match(uri)) {
case SCREEN_NAMES:
Log.d(TAG, "XXX1: SCREEN_NAMES");
return "vnd.android.cursor.dir/vnd.test.screenname";
case SCREEN_NAME:
Log.d(TAG, "XXX2: SCREEN_NAME");
return "vnd.android.cursor.item/vnd.test.screenname";
default:
// any other kind of URL is illegal
throw new IllegalArgumentException("Unknown URL " + uri);
}
}
@Override
public Cursor query(Uri uri, String[] projection, String selection,
String[] selectionArgs, String sort) {
throw new UnsupportedOperationException();
}
}
Как вы можете заметить, я не очень заинтересован в использовании базы данных, хотя это может быть полезно добавить в ближайшем будущем. Прямо сейчас я просто хочу достаточно, чтобы иметь возможность получать контент: //com.bourke.test/screenname/ URI стиля, поэтому моя деятельность может затем вызывать вызовы API Twitter для отображения информации о соответствующем пользователе.
Любая обратная связь или информация о том, почему происходит сбой, будет очень полезна.