Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Sign in / Register
Toggle navigation
P
PDF Viewer Scanner White
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wanglei
PDF Viewer Scanner White
Commits
0005e831
Commit
0005e831
authored
Dec 19, 2024
by
周文华
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
【新增】新增高版本所有文件权限检测自动跳转的功能。(待验证,经测试自己的android14和模拟器api 35可以)
parent
a73bb014
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
43 additions
and
5 deletions
+43
-5
PermissionActivity.kt
...pdfviewerscannerwhite/ui/permission/PermissionActivity.kt
+22
-1
DialogView.kt
...java/com/base/pdfviewerscannerwhite/ui/view/DialogView.kt
+21
-4
No files found.
app/src/main/java/com/base/pdfviewerscannerwhite/ui/permission/PermissionActivity.kt
View file @
0005e831
...
@@ -2,10 +2,13 @@ package com.base.pdfviewerscannerwhite.ui.permission
...
@@ -2,10 +2,13 @@ package com.base.pdfviewerscannerwhite.ui.permission
import
android.annotation.SuppressLint
import
android.annotation.SuppressLint
import
android.graphics.Color
import
android.graphics.Color
import
android.os.Build
import
android.os.Environment
import
android.text.SpannableString
import
android.text.SpannableString
import
android.text.SpannableStringBuilder
import
android.text.SpannableStringBuilder
import
android.text.style.ForegroundColorSpan
import
android.text.style.ForegroundColorSpan
import
androidx.activity.addCallback
import
androidx.activity.addCallback
import
androidx.annotation.RequiresApi
import
androidx.core.content.ContextCompat
import
androidx.core.content.ContextCompat
import
androidx.core.view.updatePadding
import
androidx.core.view.updatePadding
import
com.base.pdfviewerscannerwhite.R
import
com.base.pdfviewerscannerwhite.R
...
@@ -13,6 +16,9 @@ import com.base.pdfviewerscannerwhite.databinding.ActivityPermissionBinding
...
@@ -13,6 +16,9 @@ import com.base.pdfviewerscannerwhite.databinding.ActivityPermissionBinding
import
com.base.pdfviewerscannerwhite.helper.BaseActivity
import
com.base.pdfviewerscannerwhite.helper.BaseActivity
import
com.base.pdfviewerscannerwhite.utils.BarUtils
import
com.base.pdfviewerscannerwhite.utils.BarUtils
import
com.base.pdfviewerscannerwhite.utils.PermissionUtils.requestStoragePermission
import
com.base.pdfviewerscannerwhite.utils.PermissionUtils.requestStoragePermission
import
kotlinx.coroutines.MainScope
import
kotlinx.coroutines.delay
import
kotlinx.coroutines.launch
class
PermissionActivity
:
BaseActivity
<
ActivityPermissionBinding
>()
{
class
PermissionActivity
:
BaseActivity
<
ActivityPermissionBinding
>()
{
...
@@ -52,10 +58,25 @@ class PermissionActivity : BaseActivity<ActivityPermissionBinding>() {
...
@@ -52,10 +58,25 @@ class PermissionActivity : BaseActivity<ActivityPermissionBinding>() {
onBackPressedDispatcher
.
onBackPressed
()
onBackPressedDispatcher
.
onBackPressed
()
}
}
binding
.
tvAllow
.
setOnClickListener
{
binding
.
tvAllow
.
setOnClickListener
{
requestStoragePermission
(
launcher
)
{
requestStoragePermission
(
launcher
,
jumpAction
=
{
MainScope
().
launch
{
if
(!
delayOpen
()){
delayOpen
()
}
}
})
{
onBackPressedDispatcher
.
onBackPressed
()
onBackPressedDispatcher
.
onBackPressed
()
}
}
}
}
}
}
@RequiresApi
(
Build
.
VERSION_CODES
.
R
)
private
suspend
fun
delayOpen
():
Boolean
{
delay
(
600
)
if
(
Environment
.
isExternalStorageManager
())
{
onBackPressedDispatcher
.
onBackPressed
()
return
true
}
return
false
}
}
}
\ No newline at end of file
app/src/main/java/com/base/pdfviewerscannerwhite/ui/view/DialogView.kt
View file @
0005e831
...
@@ -9,6 +9,7 @@ import android.content.Intent
...
@@ -9,6 +9,7 @@ import android.content.Intent
import
android.graphics.Color
import
android.graphics.Color
import
android.net.Uri
import
android.net.Uri
import
android.os.Build
import
android.os.Build
import
android.os.Environment
import
android.text.SpannableString
import
android.text.SpannableString
import
android.text.SpannableStringBuilder
import
android.text.SpannableStringBuilder
import
android.text.style.ForegroundColorSpan
import
android.text.style.ForegroundColorSpan
...
@@ -52,7 +53,6 @@ import com.base.pdfviewerscannerwhite.utils.KotlinExt.toFormatSize
...
@@ -52,7 +53,6 @@ import com.base.pdfviewerscannerwhite.utils.KotlinExt.toFormatSize
import
com.base.pdfviewerscannerwhite.utils.KotlinExt.toFormatTime2
import
com.base.pdfviewerscannerwhite.utils.KotlinExt.toFormatTime2
import
com.base.pdfviewerscannerwhite.utils.KotlinExt.toFormatTime3
import
com.base.pdfviewerscannerwhite.utils.KotlinExt.toFormatTime3
import
com.base.pdfviewerscannerwhite.utils.KotlinExt.toFormatTime4
import
com.base.pdfviewerscannerwhite.utils.KotlinExt.toFormatTime4
import
com.base.pdfviewerscannerwhite.utils.PermissionUtils.checkNotificationPermission
import
com.base.pdfviewerscannerwhite.utils.PermissionUtils.checkStorePermission
import
com.base.pdfviewerscannerwhite.utils.PermissionUtils.checkStorePermission
import
com.base.pdfviewerscannerwhite.utils.PermissionUtils.requestStoragePermission
import
com.base.pdfviewerscannerwhite.utils.PermissionUtils.requestStoragePermission
import
com.base.pdfviewerscannerwhite.utils.SpStringUtils
import
com.base.pdfviewerscannerwhite.utils.SpStringUtils
...
@@ -60,6 +60,9 @@ import com.base.pdfviewerscannerwhite.utils.SpStringUtils.LAST_VIEW_KEY
...
@@ -60,6 +60,9 @@ import com.base.pdfviewerscannerwhite.utils.SpStringUtils.LAST_VIEW_KEY
import
com.base.pdfviewerscannerwhite.utils.ToastUtils.toast
import
com.base.pdfviewerscannerwhite.utils.ToastUtils.toast
import
com.google.android.material.bottomsheet.BottomSheetBehavior
import
com.google.android.material.bottomsheet.BottomSheetBehavior
import
com.google.android.material.bottomsheet.BottomSheetDialog
import
com.google.android.material.bottomsheet.BottomSheetDialog
import
kotlinx.coroutines.MainScope
import
kotlinx.coroutines.delay
import
kotlinx.coroutines.launch
import
java.io.File
import
java.io.File
object
DialogView
{
object
DialogView
{
...
@@ -84,7 +87,19 @@ object DialogView {
...
@@ -84,7 +87,19 @@ object DialogView {
binding
.
tvSet
.
setOnClickListener
{
binding
.
tvSet
.
setOnClickListener
{
dialog
.
dismiss
()
dialog
.
dismiss
()
requestStoragePermission
(
launcher
)
{
requestStoragePermission
(
launcher
,
{
MainScope
().
launch
{
delay
(
600
)
if
(
Environment
.
isExternalStorageManager
())
{
startActivity
(
Intent
(
this
@showStoragePermission
,
MainActivity
::
class
.
java
))
}
else
{
delay
(
600
)
if
(
Environment
.
isExternalStorageManager
())
{
startActivity
(
Intent
(
this
@showStoragePermission
,
MainActivity
::
class
.
java
))
}
}
}
})
{
launcherAction
?.
invoke
(
it
)
launcherAction
?.
invoke
(
it
)
}
}
}
}
...
@@ -196,7 +211,8 @@ object DialogView {
...
@@ -196,7 +211,8 @@ object DialogView {
val
file
=
File
(
path
)
val
file
=
File
(
path
)
binding
.
tvName
.
text
=
file
.
name
binding
.
tvName
.
text
=
file
.
name
binding
.
tvPath
.
text
=
file
.
absolutePath
binding
.
tvPath
.
text
=
file
.
absolutePath
val
lastView
=
SpStringUtils
.
getSpStringList
(
LAST_VIEW_KEY
).
find
{
it
.
contains
(
file
.
absolutePath
)
}
val
lastView
=
SpStringUtils
.
getSpStringList
(
LAST_VIEW_KEY
).
find
{
it
.
contains
(
file
.
absolutePath
)
}
if
(
lastView
!=
null
)
{
if
(
lastView
!=
null
)
{
val
lastTime
=
lastView
.
split
(
"_/_"
)[
1
]
val
lastTime
=
lastView
.
split
(
"_/_"
)[
1
]
binding
.
tvLastView
.
text
=
lastTime
.
toLong
().
toFormatTime3
()
binding
.
tvLastView
.
text
=
lastTime
.
toLong
().
toFormatTime3
()
...
@@ -233,7 +249,8 @@ object DialogView {
...
@@ -233,7 +249,8 @@ object DialogView {
val
file
=
File
(
item
.
path
)
val
file
=
File
(
item
.
path
)
binding
.
tvName
.
text
=
file
.
name
binding
.
tvName
.
text
=
file
.
name
binding
.
tvInfo
.
text
=
file
.
lastModified
().
toFormatTime4
()
+
" "
+
file
.
length
().
toFormatSize
()
binding
.
tvInfo
.
text
=
file
.
lastModified
().
toFormatTime4
()
+
" "
+
file
.
length
().
toFormatSize
()
if
(
item
.
isBookmarked
)
{
if
(
item
.
isBookmarked
)
{
binding
.
ivBookmark
.
setImageResource
(
R
.
mipmap
.
h_soucang_s
)
binding
.
ivBookmark
.
setImageResource
(
R
.
mipmap
.
h_soucang_s
)
}
else
{
}
else
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment