169 похожих чатов

Package com.example.qazaqkeruen import android.content.pm.PackageManager import android.os.Build import android.os.Bundle import androidx.appcompat.app.AppCompatActivity import androidx.core.app.ActivityCompat import androidx.core.content.ContextCompat import android.Manifest import

android.net.Uri
import android.webkit.*

class MainActivity : AppCompatActivity() {

private lateinit var webView: WebView

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)

webView = findViewById(R.id.webview)

// Настройка WebView
val webSettings: WebSettings = webView.settings
webSettings.javaScriptEnabled = true // Включаем поддержку JavaScript
webSettings.domStorageEnabled = true // Включаем локальное хранилище для JavaScript
webSettings.allowFileAccess = true
webSettings.allowContentAccess = true
webView.settings.setGeolocationEnabled(true)

// Запрашиваем разрешения на доступ к хранилищу и камере
val storagePermission = Manifest.permission.WRITE_EXTERNAL_STORAGE
val cameraPermission = Manifest.permission.CAMERA
val granted = PackageManager.PERMISSION_GRANTED

if (ContextCompat.checkSelfPermission(this, storagePermission) != granted ||
ContextCompat.checkSelfPermission(this, cameraPermission) != granted) {
ActivityCompat.requestPermissions(
this,
arrayOf(storagePermission, cameraPermission),
0
)
}

webView.webChromeClient = object : WebChromeClient() {
override fun onShowFileChooser(
webView: WebView,
filePathCallback: ValueCallback<Array<Uri>>,
fileChooserParams: FileChooserParams
): Boolean {
// Handle file upload here
return true
}
}

// Настройка WebViewClient
webView.webChromeClient = object : WebChromeClient() {
override fun onGeolocationPermissionsShowPrompt(
origin: String,
callback: GeolocationPermissions.Callback
) {
if (ContextCompat.checkSelfPermission(this@MainActivity, Manifest.permission.ACCESS_FINE_LOCATION) == granted) {
// Уже есть разрешение на геолокацию
callback.invoke(origin, true, false)
} else {
// Запрашиваем разрешение у пользователя
ActivityCompat.requestPermissions(
this@MainActivity,
arrayOf(Manifest.permission.ACCESS_FINE_LOCATION),
0
)
}
}
}

// Загружаем веб-страницу
webView.loadUrl("")
}

override fun onRequestPermissionsResult(
requestCode: Int,
permissions: Array<String>,
grantResults: IntArray
) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults)

if (requestCode == 0) {
// Это код запроса разрешения, который мы использовали в requestPermissions
if (grantResults.isNotEmpty() && grantResults.all { it == PackageManager.PERMISSION_GRANTED }) {
// Разрешения на геолокацию, хранилище и камеру были предоставлены
webView.reload()
}
}
}

override fun onBackPressed() {
if (webView.canGoBack()) {
webView.goBack()
} else {
super.onBackPressed()
}
}
}

5 ответов

51 просмотр

снова мимо

Senior, воспользуйтесь pastebin, пожалуйста

а вопрос где

Di7aK
а вопрос где

Он выше задавал, гы

Похожие вопросы

Обсуждают сегодня

https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Ребят в СИ можно реализовать ООП?
Николай
33
Доброго вечера. Поскажите, как изменить код number_fomat, что цена была без копеек. <?php if(!empty($value)) { $parts = explode('.',$value); echo number_format ($part...
Katerina Beliayeva
12
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
core\config\database\connections\default.php На всякий случай проверь всё же файл <?php return [ 'driver' => env('DB_TYPE', 'mysql'), //$database_type 'host' => env('D...
Andrey K
2
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Карта сайта