Butterflynet. Обзор приложения с JS на Android

Предисловие

Доброго времени суток, уважаемый читатель.

Чуть больше года назад у меня появилась идея сделать мобильное приложение, в котором можно будет писать код и смотреть результат прямо «не отходя от кассы». Для реализации такого «механизма» был выбран язык JS и HTML в качестве каркаса для представления. Т.к. сам я пишу на .net, разработка велась на Xamarin. Давайте посмотрим, что из этого вышло.

Внешний вид

Интерфейс

Интерфейс

Примеры приложений

Примеры приложений

Описание

В Butterflynet есть три основных элемента, для которых можно написать код: сами приложения, интерфейсы и задачи.

Для приложений отдельно (пользователями) выдаются привилегии, которые расширяют их возможности. На данный момент это:

  1. NoCors для получения файлов и их содержимого без CorsPolicy.

  2. ViewAppSources для получения доступа к просмотру исходников других приложений из текущего.

  3. EditAppSources для получения доступа к изменению исходников других приложений из текущего.

  4. PackApps для упаковки/распаковки приложений в файлы-пакеты.

Интерфейсы — это лаунчеры для отображения списка приложений. На первом скриншоте показан пример default-лаунчера.

Задачи — это диспетчеры задач для работы со свернутыми приложениями, позволяющие либо вернуться к ним, либо закрыть их. На первом скриншоте также показан пример default диспетчера задач.

Default интерфейсы и задачи нельзя изменять, т.к. они являются базовым функционалом для работы программы. Но можно создавать свои, на любой вкус и в неограниченном количестве.

В Butterflynet предусмотрен довольно большой выбор языков. Также прямо из него всегда можно скачать актуальную версию apk из соответствующего пункта меню.

В разделе меню «Разработчикам» можно посмотреть полное описание всех api для текущей версии программы.

Пример кода приложения «Hello World»


  
    
	
	
  

  


Enter your name:

Собственно, здесь есть поле для ввода имени и три кнопки «Сохранить», «Сбросить» и «Перезагрузить». После того как пользователь ввел имя и нажал «сохранить» ему выдается случайное приветствие из массива. То же самое будет происходить при повторном запуске приложения. Если пользователь сбросит данные, то приложение снова начнет выдавать фразу «Hello world».

Работа с API приложения реализована через три функции: SaveDataAsync, DeleteDataAsync и LoadData. Они позволяют работать с сохраненными для текущего приложения данными.

Разрешения

В приложении добавлены два разрешения:

  1. Доступ к памяти устройства (для работы с загрузкой/выгрузкой данных устройства).

  2. Доступ к геолокации (если кто-то захочет написать приложения для работы с ней).

C Butterflynet можно работать не выдавая разрешений, они необязательны.

Преимущества

  1. Прозрачность. Вы всегда можете посмотреть код приложения и понять как он работает.

  2. Гибкость. В любой момент можно изменить приложение.

  3. Размер приложений. По сути, приложения состоят из текстовых файлов с кодом и небольших изображений, поэтому весят считанные килобайты.

  4. Большая функциональность. Можно написать различные виды приложений.

  5. Кастомизация. Можно создавать не только свои приложения, но и свои лаунчеры и диспетчеры задач (внутри приложения).

Заключение

В google play приложения нет. Думаю, причины того, почему его туда не пропустят, понятны. Поэтому отдельно прикрепляю ссылку на скачивание apk и архив с некоторым приложениями.

Для кого Butterflynet? Возможно, кто-то придумает как использовать Butterflynet в коммерческих целях, кто-то давно хотел написать небольшую утилиту или игру для себя, а возможно кто-то просто захочет побаловаться с JS, чтобы скоротать время.

Спасибо за прочтение и хорошего дня!

© Habrahabr.ru