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

Всем добрый вечер! Я создаю проект в WebView. Ниже приведен код.Я

загружаю фотографии на сайт. Через камеру и память.

Но мобильное приложение не может скачать файл, не нажимается кнопка скачать. Можете ли вы помочь мне исправить код?

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("https://")
}

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()
}
}
}

6 ответов

117 просмотров

https://pastebin.com/ pls

kotleni 🇺🇦
https://pastebin.com/ pls

PASTEBIN API TOOLS FAQ paste Search... LOGIN SIGN UP Advertisement SHARE TWEET Guest User Untitled A GUEST OCT 14TH, 2023 1 0 NEVER ADD COMMENT NOTE: Your guest paste has been posted. If you sign up for a free account, you can edit and delete your pastes! 3.98 KB | None | 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() } } }

Senior Coffee ☕️ Drinker 👨‍💻
PASTEBIN API TOOLS FAQ paste Search... LOGIN SIGN...

Оберните код в теги: 3 символа ` до и после кода (в случае одиночной конструкции достаточно 1 ` с обеих сторон). Спасибо!

Senior Coffee ☕️ Drinker 👨‍💻
PASTEBIN API TOOLS FAQ paste Search... LOGIN SIGN...

Всё ещё неправильно :( Оберните код в теги: 3 символа ` до и после кода (в случае одиночной конструкции достаточно 1 ` с обеих сторон). Спасибо!

Senior Coffee ☕️ Drinker 👨‍💻
PASTEBIN API TOOLS FAQ paste Search... LOGIN SIGN...

лол ты вставил код на пастбин и скопировал страницу?

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

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

30500 за редактор? )
Владимир
47
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
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
Он в одиночку это дело запилил или была какая-то команда?
Aquinary
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
Oh sorry did you want it in Gunter's chains?
Martin Rys
15
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта