4) Когда вы установили приложение на эмуляторе, откройте браузер и перейдите на локальный хост, нажмите на ссылку, и ваше приложение, если оно будет установлено, запустится, в противном случае это будет ошибка
мотрел несколько вопросов о переполнении стека с похожими названиями. Каждый отвечает, и оригинальный автор кажется удовлетворенным, но когда я пытаюсь повторить их результаты, я прихожу с пустыми руками. Очевидно, что я делаю что-то ужасно неправильно, но я не могу понять это.
Для справки, вот вопросы, на которые я смотрел:
Запустите пользовательское приложение для Android из браузера AndroidСделать ссылку в браузере Android Запустите мое приложениеURL-адрес Android Dev Callback не работаетФильтры Intent для Android: как вы правильно просматриваете категорию IntentВ конечном счете, я хочу использовать это для перезапуска моего приложения, когда пользователь выполнил запрос аутентификации OAuth. Тем не менее, мое реальное приложение слишком велико, чтобы публиковать здесь. Для этого вопроса я собрал простое приложение, чтобы показать вам, что я сделал. У меня есть два занятия. Это происходит главным образом потому, что каждый пример, который я видел, использует действие, использующее действие VIEW. Я бы предпочел использовать действие MAIN, но я использовал оба здесь, чтобы показать, что я пробовал оба.
AndroidManifest.xml (оригинал; см. Отредактированную версию ниже)
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="org.example" android:versionCode="1" android:versionName="1.0-SNAPSHOT">
<application android:icon="@drawable/icon" android:label="@string/app_name" android:debuggable="true">
<activity android:name=".HelloAndroidActivity">
<intent-filter>
<data android:scheme="ex1"/>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".CallbackActivity">
<intent-filter>
<data android:scheme="ex2"/>
<action android:name="android.intent.action.VIEW"/>
</intent-filter>
</activity>
</application>
AndroidManifest.xml (отредактировано в ответ на комментарий)
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="org.example" android:versionCode="1" android:versionName="1.0-SNAPSHOT">
<application android:icon="@drawable/icon" android:label="@string/app_name" android:debuggable="true">
<activity android:name=".HelloAndroidActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".CallbackActivity">
<intent-filter>
<action android:name="android.intent.action.VIEW"/>
<category android:name="android.intent.category.DEFAULT"/>
<category android:name="android.intent.category.BROWSABLE"/>
<data android:host="www.this-so-does-not-exist.com" android:scheme="http" />
</intent-filter>
</activity>
</application>
main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
HelloAndroidActivity.java
package org.example;
import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.widget.TextView;
public class HelloAndroidActivity extends Activity {
private TextView textView;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
textView = (TextView) findViewById(R.id.textView);
}
@Override
public void onResume() {
super.onResume();
Intent intent = getIntent();
Uri data = intent.getData();
if (data != null) {
textView.setText("Hello Web!");
}
}
}
CallbackActivity.java
package org.example;
import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.widget.TextView;
public class CallbackActivity extends Activity {
private TextView textView;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
textView = (TextView) findViewById(R.id.textView);
}
@Override
public void onResume() {
super.onResume();
Intent intent = getIntent();
Uri data = intent.getData();
if (data != null) {
textView.setText("Hello Web!");
}
}
}
Это строит достаточно счастливо. Затем, внутри браузера, если я ввожу ex1: // helloworld или ex2: // helloworld, я получаю разные результаты в зависимости от того, как это делается. Если я ввожу его в строке URL, я получаю в Google поиск ex1: // helloworld. Если я делаю это через перенаправление, я получаю «Веб-страница недоступна». Если я попытаюсь начать намерение непосредственно с чего-то похожего на:
Intent intent = new Intent(Intent.ACTION_MAIN);
ComponentName componentName = new ComponentName(
"org.example",
"org.example.HelloAndroidActivity");
intent.setComponent(componentName);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.setData(Uri.parse("ex1://helloworld"));
intent.addCategory(Intent.CATEGORY_BROWSABLE);
startActivity(intent);
Я получаю значение по умолчанию «Hello my-example!». Я не уверен, что я делаю неправильно. Есть идеи?