WebView в Amazon Fire OS
Начиная с 3.3.0, Cordova можно использовать в качестве компонента приложений Amazon Fire OS. Amazon Fire ОС ссылается на этот компонент как CordovaWebView
. CordovaWebView
расширяет Amazon WebView, который построен на открытом исходном коде проекта Chromium. Используя эту функцию, веб-приложений можно использовать последние веб-стандарты HTML5, работающие в современной веб среде.
Если вы не знакомы с Amazon Fire ОС, необходимо сначала ознакомиться с руководством ОС платформы Amazon огонь и установили последнюю SDK, прежде чем пытаться более необычный вариант развития встраивания WebView.
Необходимые условия
Кордова 3.3.0 или больше
Android SDK, последней версии
Amazon WebView SDK
Руководство по использованию CordovaWebView в проекте OS Amazon Fire
Следовать этим инструкциям, убедитесь, что у вас есть дистрибутив последней Кордова. Скачать его с cordova.apache.org и распакуйте его пакет Amazon Fire OS.
Скачать и распаковать Amazon WebView SDK, затем скопируйте awv_interface.jar в каталог
/framework/libs
. Создайте каталог libs/, если он не существует.Перейдите к пакету
/framework
директорию и запуститьant jar
. Он создаёт Кордова.jar
файл, как/framework/cordova-x.x.x.jar
.Скопируйте файл
.jar
в каталог/libs
Android-проекта.Добавьте в приложение следующий файл
/res/xml/main.xml
, сlayout_height
,layout_width
иid
модицифированными в соответствии с нуждами приложения:<org.apache.cordova.CordovaWebView android:id="@+id/tutorialView" android:layout_width="match_parent" android:layout_height="match_parent" />
Измените вашу деятельность так, чтобы этот класс реализовал
CordovaInterface
. Вы должны реализовать описанные методы этого интерфейса. Вы можете скопировать их из/framework/src/org/apache/cordova/CordovaActivity.java
, или реализовать их самостоятельно. Нижеуказанный фрагмент кода показывает простое приложение , которое использует интерфейс. Обратите внимание, что id упоминаемого окна соответствуетid
атрибут, указанный в XML-фрагменте показаном выше:public class CordovaViewTestActivity extends Activity implements CordovaInterface { CordovaWebView cwv; /* Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); cwv = (CordovaWebView) findViewById(R.id.tutorialView); Config.init(this); cwv.loadUrl(Config.getStartUrl()); }
Если вы используете камеру, следует также реализовать следующее:
@Override
public void setActivityResultCallback(CordovaPlugin plugin) {
this.activityResultCallback = plugin;
}
/**
* Launch an activity for which you would like a result when it finished. When this activity exits,
* your onActivityResult() method is called.
*
* @param command The command object
* @param intent The intent to start
* @param requestCode The request code that is passed to callback to identify the activity
*/
public void startActivityForResult(CordovaPlugin command, Intent intent, int requestCode) {
this.activityResultCallback = command;
this.activityResultKeepRunning = this.keepRunning;
// If multitasking turned on, then disable it for activities that return results
if (command != null) {
this.keepRunning = false;
}
// Start activity
super.startActivityForResult(intent, requestCode);
}
@Override
/**
* Called when an activity you launched exits, giving you the requestCode you started it with,
* the resultCode it returned, and any additional data from it.
*
* @param requestCode The request code originally supplied to startActivityForResult(),
* allowing you to identify who this result came from.
* @param resultCode The integer result code returned by the child activity through its setResult().
* @param data An Intent, which can return result data to the caller (various data can be attached to Intent "extras").
*/
protected void onActivityResult(int requestCode, int resultCode, Intent intent) {
super.onActivityResult(requestCode, resultCode, intent);
CordovaPlugin callback = this.activityResultCallback;
if (callback != null) {
callback.onActivityResult(requestCode, resultCode, intent);
}
}
Наконец, не забудьте добавить пул потоков, в противном случае у плагинов не будет потоков где можно будет выполняться:
@Override
public ExecutorService getThreadPool() {
return threadPool;
}
Скопировать HTML и JavaScript файлы приложения в каталог
/assets/www
проекта Amazon Fire OS.Скопируйте
config.xml
из/framework/res/xml
для в каталог/res/xml
вашего проекта.