Я веду блог одновременно в ВК и в Телеграме, и всегда для набора текста открывал именно ВК. Потому что в Телеграме набирать длинный текст очень неудобно, даже в десктопной версии. О мобильной вообще не говорим. Причина в фиксированной (и небольшой) высоте поля ввода в Телеге, которое в ВК расширялось.
А вот вам свежий апдейт от ВК. На декстопе! Блок для картинки занимает 80% площади этой модалки, а текстовая подпись где-то там стыдливо прячется внизу. При наборе длинного текста, к счастью, скроллится содержимое модалки целиком, а не только поле под дроп-зоной, и это всё ещё удобнее Телеги, но уже максимально не тексто-ориентировано. Я не первый год пишу, что интернет планомерно убивает тексты, и вот очередная веха этого процесса.
Иронично, что сегодня обсуждали случай, когда человек либеральных взглядов лайкнул в инсте не слишком либеральный текст, а потом оказалось, что лайкал он картинку, и о наличии под ней текста особо не подумал. Потому что да, UI/UX инсты он вообще не про тексты, и попытка отдельных людей, охочих до дешёвой (во всех смыслах) аудитории, вести там текстовые блоги выглядит, как забивание гвоздей микроскопом.
Тем не менее, всё ещё не хочу переходить на какой-нибудь видео-формат. Хорошее видео это дорого, плохое не хочется. Вертикальное тем более не хочется.
#web
🚀 Вышел стабильный JavaScript движок от Google для Android
Новая стабильная библиотека Jetpack JavaScript Engine позволит разработчикам выполнять JS код в изолированной и ограниченной среде.
class MainActivity : ComponentActivity() {
// Теперь nullable, без lateinit
private var jsSandbox: JavaScriptSandbox? = null
private var jsIsolate: JavaScriptIsolate? = null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
if (!JavaScriptSandbox.isSupported()) {
Log.e("JS", "JavaScriptSandbox не поддерживается")
return
}
lifecycleScope.launch {
// Создаём и сохраняем в nullable-поле
jsSandbox = JavaScriptSandbox
.createConnectedInstanceAsync(applicationContext)
.await()
jsIsolate = jsSandbox?.createIsolate()
// При выполнении гарантируем, что jsIsolate != null
val result: String = jsIsolate
?.evaluateJavaScriptAsync(JS_SCRIPT_SCRING)
?.await()
?: "Ошибка: isolate не инициализирован"
Log.d("JS", "Результат выполнения: $result")
}
}
override fun onDestroy() {
super.onDestroy()
// Закрываем только если не null
jsIsolate?.close()
jsSandbox?.close()
}
}
#jetpack#js