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 ответов

52 просмотра

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...

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

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

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

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Есть ли смысл устраиваться на 1с ? Даст это плюс в дальнейшем трудоустройстве на php? Просто у меня в городе вакансий на пхп нету. Или лучше удаленно искать. Опыта работы нету...
Azamat
14
Не ну фпц - это уже просто троллинг какой-то. Элементарный код нельзя собрать. ЧЯДНТ? program Project1; {$mode delphi} uses SysUtils, Classes, Generics.Collections; var...
Peter
4
а где есть mysql cloud кроме яндекс-клауд?
Oleg Nosov
13
hi im a cs student. i need some advice from people who have enough experience in Embedded Software. I need to know whether this profession is suitable for me. I have watched s...
Sahand 🏔️
8
А кто-нибудь запихивал сборку перловых модулей/образов с perl приложениями в окружения без интернета (в специализированном CI/CD)? У меня сейчас есть ряд cpanfile, которые н...
Andrey Smirnov / 𝓪𝓵𝓵𝓽𝓮𝓻 /
14
Карта сайта