Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Sign in / Register
Toggle navigation
F
File Recovery RecycleBin
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
File Recovery RecycleBin
Commits
d4677a01
Commit
d4677a01
authored
Jul 29, 2024
by
wanglei
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
...
parent
97c90b31
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
443 additions
and
448 deletions
+443
-448
MyApplication.kt
...ain/java/com/base/filerecoveryrecyclebin/MyApplication.kt
+9
-1
SplashActivity.kt
...om/base/filerecoveryrecyclebin/activity/SplashActivity.kt
+24
-3
CleanJunkActivity.kt
...ecoveryrecyclebin/activity/junkclean/CleanJunkActivity.kt
+100
-381
JunkExpandAdapter.kt
.../base/filerecoveryrecyclebin/adapter/JunkExpandAdapter.kt
+198
-0
AdmobMaxHelper.kt
...ava/com/base/filerecoveryrecyclebin/ads/AdmobMaxHelper.kt
+4
-1
AdmobOpenUtils.kt
...m/base/filerecoveryrecyclebin/ads/admob/AdmobOpenUtils.kt
+2
-2
AdMaxOpenUtils.kt
...com/base/filerecoveryrecyclebin/ads/max/AdMaxOpenUtils.kt
+6
-6
ParentBean.kt
...n/java/com/base/filerecoveryrecyclebin/bean/ParentBean.kt
+4
-4
color_delete_selector.xml
app/src/main/res/color/color_delete_selector.xml
+5
-0
bg_delete_selector.xml
app/src/main/res/drawable/bg_delete_selector.xml
+5
-0
bg_e6e7e9_22.xml
app/src/main/res/drawable/bg_e6e7e9_22.xml
+6
-0
bg_ffffff_tlr10.xml
app/src/main/res/drawable/bg_ffffff_tlr10.xml
+8
-0
activity_layout_clean_junk.xml
app/src/main/res/layout/activity_layout_clean_junk.xml
+72
-50
log_clean.png
app/src/main/res/mipmap-xxhdpi/log_clean.png
+0
-0
temp_clean.png
app/src/main/res/mipmap-xxhdpi/temp_clean.png
+0
-0
No files found.
app/src/main/java/com/base/filerecoveryrecyclebin/MyApplication.kt
View file @
d4677a01
...
@@ -122,7 +122,15 @@ class MyApplication : BaseApplication() {
...
@@ -122,7 +122,15 @@ class MyApplication : BaseApplication() {
if
(
flag
&&
!
isInterOpenShowing
)
{
if
(
flag
&&
!
isInterOpenShowing
)
{
if
(
AdmobMaxHelper
.
isOpenAdLoaded
())
{
if
(
AdmobMaxHelper
.
isOpenAdLoaded
())
{
AdmobMaxHelper
.
admobMaxShowOpenAd
(
activity
,
{},
{})
var
loaded
:
Boolean
=
true
AdmobMaxHelper
.
admobMaxShowOpenAd
(
activity
,
{
loaded
=
it
},
{
val
sp
=
AppPreferences
.
getInstance
().
getString
(
"splashShowInter"
,
"0"
).
toInt
()
if
(
sp
==
1
&&
!
loaded
)
{
AdmobMaxHelper
.
admobMaxShowInterstitialAd
(
activity
)
}
})
}
else
{
}
else
{
topActivity
?.
startActivity
(
topActivity
?.
startActivity
(
Intent
(
Intent
(
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/activity/SplashActivity.kt
View file @
d4677a01
...
@@ -37,9 +37,11 @@ import com.base.filerecoveryrecyclebin.fcm.NotificationUtil
...
@@ -37,9 +37,11 @@ import com.base.filerecoveryrecyclebin.fcm.NotificationUtil
import
com.base.filerecoveryrecyclebin.help.BaseActivity
import
com.base.filerecoveryrecyclebin.help.BaseActivity
import
com.base.filerecoveryrecyclebin.help.ConfigHelper
import
com.base.filerecoveryrecyclebin.help.ConfigHelper
import
com.base.filerecoveryrecyclebin.service.StayNotificationService.Companion.startStayNotification
import
com.base.filerecoveryrecyclebin.service.StayNotificationService.Companion.startStayNotification
import
com.base.filerecoveryrecyclebin.utils.AppPreferences
import
com.base.filerecoveryrecyclebin.utils.BarUtils
import
com.base.filerecoveryrecyclebin.utils.BarUtils
import
com.base.filerecoveryrecyclebin.utils.LogEx
import
com.base.filerecoveryrecyclebin.utils.LogEx
import
kotlinx.coroutines.Job
import
kotlinx.coroutines.Job
import
kotlinx.coroutines.cancel
import
kotlinx.coroutines.delay
import
kotlinx.coroutines.delay
import
kotlinx.coroutines.flow.MutableSharedFlow
import
kotlinx.coroutines.flow.MutableSharedFlow
import
kotlinx.coroutines.flow.SharedFlow
import
kotlinx.coroutines.flow.SharedFlow
...
@@ -113,13 +115,21 @@ class SplashActivity : BaseActivity<ActivitySplashBinding>() {
...
@@ -113,13 +115,21 @@ class SplashActivity : BaseActivity<ActivitySplashBinding>() {
if
(
it
>=
100
)
{
if
(
it
>=
100
)
{
job
?.
cancel
()
job
?.
cancel
()
jumpNext
()
jumpNext
()
this
.
cancel
()
}
}
}
}
}
}
}
}
var
jumped
:
Boolean
=
false
private
fun
jumpNext
()
{
private
fun
jumpNext
()
{
if
(
jumped
)
{
return
}
jumped
=
true
LogEx
.
logDebug
(
TAG
,
"jumpNext actionId=$actionId"
)
when
(
actionId
)
{
when
(
actionId
)
{
ID_JUNK_CLEAN_PUSH
->
{
ID_JUNK_CLEAN_PUSH
->
{
startActivity
(
Intent
(
this
,
ScanJunkActivity
::
class
.
java
))
startActivity
(
Intent
(
this
,
ScanJunkActivity
::
class
.
java
))
...
@@ -225,11 +235,22 @@ class SplashActivity : BaseActivity<ActivitySplashBinding>() {
...
@@ -225,11 +235,22 @@ class SplashActivity : BaseActivity<ActivitySplashBinding>() {
private
fun
outTimeAd
()
{
private
fun
outTimeAd
()
{
LogEx
.
logDebug
(
TAG
,
"outTimeAd"
)
LogEx
.
logDebug
(
TAG
,
"outTimeAd"
)
AdmobMaxHelper
.
admobMaxShowOpenAd
(
this
,
showBeforeAction
=
{
var
loaded
:
Boolean
=
true
AdmobMaxHelper
.
admobMaxShowOpenAd
(
this
,
showBeforeAction
=
{
flag
->
loaded
=
flag
job
?.
cancel
()
job
?.
cancel
()
},
onHidden
=
{
},
onHidden
=
{
val
sp
=
AppPreferences
.
getInstance
().
getString
(
"splashShowInter"
,
"0"
).
toInt
()
if
(
sp
==
1
&&
!
loaded
)
{
AdmobMaxHelper
.
admobMaxShowInterstitialAd
(
this
)
{
binding
.
pb
.
progress
=
100
jumpNext
()
}
}
else
{
binding
.
pb
.
progress
=
100
binding
.
pb
.
progress
=
100
jumpNext
()
jumpNext
()
}
})
})
}
}
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/activity/junkclean/CleanJunkActivity.kt
View file @
d4677a01
This diff is collapsed.
Click to expand it.
app/src/main/java/com/base/filerecoveryrecyclebin/adapter/JunkExpandAdapter.kt
0 → 100644
View file @
d4677a01
package
com.base.filerecoveryrecyclebin.adapter
import
android.animation.ValueAnimator
import
android.annotation.SuppressLint
import
android.content.pm.PackageManager
import
android.graphics.drawable.Drawable
import
android.view.LayoutInflater
import
android.view.ViewGroup
import
android.view.animation.LinearInterpolator
import
androidx.core.view.isVisible
import
com.base.filerecoveryrecyclebin.R
import
com.base.filerecoveryrecyclebin.bean.ChildBean
import
com.base.filerecoveryrecyclebin.bean.ParentBean
import
com.base.filerecoveryrecyclebin.databinding.ItemChildBinding
import
com.base.filerecoveryrecyclebin.databinding.ItemParentBinding
import
com.base.filerecoveryrecyclebin.help.KotlinExt.toFormatSize
import
com.base.filerecoveryrecyclebin.utils.LogEx
import
pokercc.android.expandablerecyclerview.ExpandableAdapter
class
JunkExpandAdapter
(
private
val
chooseAction
:
(
size
:
Long
)
->
Unit
)
:
ExpandableAdapter
<
ExpandableAdapter
.
ViewHolder
>()
{
private
val
TAG
=
"JunkExpandAdapter"
private
val
parentBeanList
by
lazy
{
mutableListOf
(
ParentBean
(
title
=
"Useless installation package"
,
isParentSelected
=
true
,
expanded
=
false
),
ParentBean
(
title
=
"Temp File"
,
isParentSelected
=
true
,
expanded
=
false
),
ParentBean
(
title
=
"Log File"
,
isParentSelected
=
true
,
expanded
=
false
)
)
}
var
animators
=
mutableMapOf
<
Int
,
ValueAnimator
>()
inner
class
ChildViewHolder
(
val
binding
:
ItemChildBinding
)
:
ViewHolder
(
binding
.
root
)
inner
class
ParentViewHolder
(
val
binding
:
ItemParentBinding
)
:
ViewHolder
(
binding
.
root
)
override
fun
getChildCount
(
groupPosition
:
Int
):
Int
{
return
parentBeanList
[
groupPosition
].
childItem
.
size
}
override
fun
getGroupCount
():
Int
{
return
parentBeanList
.
size
}
override
fun
onCreateChildViewHolder
(
viewGroup
:
ViewGroup
,
viewType
:
Int
):
ViewHolder
{
val
inflater
=
LayoutInflater
.
from
(
viewGroup
.
context
)
val
binding
=
ItemChildBinding
.
inflate
(
inflater
,
viewGroup
,
false
)
return
ChildViewHolder
(
binding
)
}
override
fun
onCreateGroupViewHolder
(
viewGroup
:
ViewGroup
,
viewType
:
Int
):
ViewHolder
{
val
inflater
=
LayoutInflater
.
from
(
viewGroup
.
context
)
val
binding
=
ItemParentBinding
.
inflate
(
inflater
,
viewGroup
,
false
)
return
ParentViewHolder
(
binding
)
}
@SuppressLint
(
"NotifyDataSetChanged"
)
override
fun
onBindGroupViewHolder
(
holder
:
ViewHolder
,
groupPosition
:
Int
,
expand
:
Boolean
,
payloads
:
List
<
Any
>)
{
val
viewHolder
=
holder
as
?
ParentViewHolder
?:
return
val
parentBean
=
parentBeanList
[
groupPosition
]
viewHolder
.
binding
.
idTypeName
.
text
=
parentBean
.
title
parentBean
.
expanded
=
expand
if
(
parentBean
.
expanded
)
{
viewHolder
.
binding
.
idXiala
.
setImageResource
(
R
.
mipmap
.
zhankai
)
}
else
{
viewHolder
.
binding
.
idXiala
.
setImageResource
(
R
.
mipmap
.
shouqi
)
}
viewHolder
.
binding
.
idTypeSize
.
text
=
parentBean
.
parentSize
.
toFormatSize
(
1
)
viewHolder
.
binding
.
idXiala
.
isVisible
=
parentBean
.
childItem
.
isNotEmpty
()
viewHolder
.
binding
.
idImgChoose
.
isSelected
=
parentBean
.
isParentSelected
bindParentAnimation
(
parentBean
,
groupPosition
,
viewHolder
)
viewHolder
.
binding
.
idImgChoose
.
setOnClickListener
{
viewHolder
.
binding
.
idImgChoose
.
isSelected
=
!
viewHolder
.
binding
.
idImgChoose
.
isSelected
parentBean
.
isParentSelected
=
viewHolder
.
binding
.
idImgChoose
.
isSelected
parentBean
.
childItem
.
forEach
{
it
.
isChildSelected
=
parentBean
.
isParentSelected
}
notifyDataSetChanged
()
chooseSizeChange
()
}
}
override
fun
onGroupViewHolderExpandChange
(
holder
:
ViewHolder
,
groupPosition
:
Int
,
animDuration
:
Long
,
expand
:
Boolean
)
{}
private
fun
chooseSizeChange
()
{
val
selectSize
=
parentBeanList
.
sumOf
{
it
.
childItem
.
filter
{
it
.
isChildSelected
}.
sumOf
{
it
.
childSize
}
}
chooseAction
.
invoke
(
selectSize
)
}
fun
getChoosePath
():
List
<
ChildBean
>
{
return
parentBeanList
.
flatMap
{
it
.
childItem
}.
filter
{
it
.
isChildSelected
}
}
private
fun
bindParentAnimation
(
parentBean
:
ParentBean
,
groupPosition
:
Int
,
viewHolder
:
ParentViewHolder
)
{
if
(
parentBean
.
isfinish
)
{
viewHolder
.
binding
.
idImgLoad
.
isVisible
=
false
viewHolder
.
binding
.
idImgChoose
.
isVisible
=
true
animators
[
groupPosition
]
?.
cancel
()
}
else
{
LogEx
.
logDebug
(
TAG
,
"play parent ValueAnimator"
)
animators
[
groupPosition
]
?:
ValueAnimator
.
ofFloat
(
0f
,
360f
).
apply
{
duration
=
1000
repeatMode
=
ValueAnimator
.
RESTART
repeatCount
=
ValueAnimator
.
INFINITE
interpolator
=
LinearInterpolator
()
addUpdateListener
{
viewHolder
.
binding
.
idImgLoad
.
rotation
=
it
.
animatedValue
as
Float
}
start
()
animators
[
groupPosition
]
=
this
}
viewHolder
.
binding
.
idImgLoad
.
isVisible
=
true
viewHolder
.
binding
.
idImgChoose
.
isVisible
=
false
}
}
@SuppressLint
(
"NotifyDataSetChanged"
)
override
fun
onBindChildViewHolder
(
holder
:
ViewHolder
,
groupPosition
:
Int
,
childPosition
:
Int
,
payloads
:
List
<
Any
>)
{
val
viewHolder
=
holder
as
?
ChildViewHolder
?:
return
val
childBean
=
parentBeanList
[
groupPosition
].
childItem
[
childPosition
]
val
parentBean
=
parentBeanList
[
groupPosition
]
val
context
=
holder
.
itemView
.
context
viewHolder
.
binding
.
idTvAppName
.
text
=
childBean
.
childname
viewHolder
.
binding
.
idImgSelect
.
isSelected
=
childBean
.
isChildSelected
viewHolder
.
binding
.
idTvSize
.
text
=
childBean
.
childSize
.
toFormatSize
()
when
(
groupPosition
)
{
0
->
{
try
{
val
apkFilePath
=
childBean
.
chilepath
// 替换成您的APK文件路径
val
packageInfo
=
context
.
packageManager
.
getPackageArchiveInfo
(
apkFilePath
,
PackageManager
.
GET_ACTIVITIES
)
if
(
packageInfo
!=
null
)
{
val
applicationInfo
=
packageInfo
.
applicationInfo
val
appIcon
:
Drawable
=
context
.
packageManager
.
getApplicationIcon
(
applicationInfo
)
viewHolder
.
binding
.
idImgIcon
.
setImageDrawable
(
appIcon
)
}
else
{
holder
.
binding
.
idImgIcon
.
setImageResource
(
R
.
mipmap
.
apk
)
}
}
catch
(
e
:
Exception
)
{
holder
.
binding
.
idImgIcon
.
setImageResource
(
R
.
mipmap
.
apk
)
}
}
1
->
{
holder
.
binding
.
idImgIcon
.
setImageResource
(
R
.
mipmap
.
temp_clean
)
}
2
->
{
holder
.
binding
.
idImgIcon
.
setImageResource
(
R
.
mipmap
.
log_clean
)
}
}
viewHolder
.
itemView
.
setOnClickListener
{
viewHolder
.
binding
.
idImgSelect
.
isSelected
=
!
viewHolder
.
binding
.
idImgSelect
.
isSelected
childBean
.
isChildSelected
=
viewHolder
.
binding
.
idImgSelect
.
isSelected
parentBean
.
isParentSelected
=
parentBean
.
childItem
.
all
{
it
.
isChildSelected
}
notifyDataSetChanged
()
chooseSizeChange
()
}
}
@SuppressLint
(
"NotifyDataSetChanged"
)
fun
addChildData
(
position
:
Int
,
childBeanList
:
List
<
ChildBean
>)
{
val
parentBean
=
parentBeanList
[
position
]
parentBean
.
isfinish
=
true
parentBean
.
isParentSelected
=
true
parentBean
.
childItem
.
addAll
(
childBeanList
)
parentBean
.
parentSize
=
childBeanList
.
sumOf
{
it
.
childSize
}
LogEx
.
logDebug
(
TAG
,
"addChildData parentBean=$parentBean"
)
notifyDataSetChanged
()
chooseSizeChange
()
}
}
\ No newline at end of file
app/src/main/java/com/base/filerecoveryrecyclebin/ads/AdmobMaxHelper.kt
View file @
d4677a01
...
@@ -80,7 +80,10 @@ object AdmobMaxHelper {
...
@@ -80,7 +80,10 @@ object AdmobMaxHelper {
}
}
}
}
fun
admobMaxShowOpenAd
(
activity
:
Activity
,
showBeforeAction
:
()
->
Unit
,
onHidden
:
(()
->
Unit
)?
=
null
)
{
fun
admobMaxShowOpenAd
(
activity
:
Activity
,
showBeforeAction
:
(
flag
:
Boolean
)
->
Unit
,
onHidden
:
(()
->
Unit
)?
=
null
,
)
{
if
(
isBlack
)
{
if
(
isBlack
)
{
onHidden
?.
invoke
()
onHidden
?.
invoke
()
return
return
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/ads/admob/AdmobOpenUtils.kt
View file @
d4677a01
...
@@ -64,7 +64,7 @@ object AdmobOpenUtils {
...
@@ -64,7 +64,7 @@ object AdmobOpenUtils {
}
}
fun
showAppOpenAd
(
activity
:
Activity
,
showBefore
:
(()
->
Unit
)?
=
null
,
onHidden
:
((
where
:
Int
)
->
Unit
)?
=
null
)
{
fun
showAppOpenAd
(
activity
:
Activity
,
showBefore
:
((
flag
:
Boolean
)
->
Unit
)?
=
null
,
onHidden
:
((
where
:
Int
)
->
Unit
)?
=
null
)
{
if
(
activity
.
isFinishing
||
activity
.
isDestroyed
)
{
if
(
activity
.
isFinishing
||
activity
.
isDestroyed
)
{
return
return
...
@@ -114,7 +114,7 @@ object AdmobOpenUtils {
...
@@ -114,7 +114,7 @@ object AdmobOpenUtils {
}
}
override
fun
onAdShowedFullScreenContent
()
{
override
fun
onAdShowedFullScreenContent
()
{
showBefore
?.
invoke
()
showBefore
?.
invoke
(
true
)
showAd
(
thisMOpenAd
?.
responseInfo
,
"openAd"
,
activity
)
showAd
(
thisMOpenAd
?.
responseInfo
,
"openAd"
,
activity
)
}
}
}
}
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/ads/max/AdMaxOpenUtils.kt
View file @
d4677a01
...
@@ -21,7 +21,7 @@ object AdMaxOpenUtils {
...
@@ -21,7 +21,7 @@ object AdMaxOpenUtils {
private
var
appOpenAd
:
MaxAppOpenAd
?
=
null
private
var
appOpenAd
:
MaxAppOpenAd
?
=
null
private
var
openLoadTime
=
Long
.
MAX_VALUE
private
var
openLoadTime
=
Long
.
MAX_VALUE
private
var
onHidden
:
(()
->
Unit
)?
=
null
private
var
onHidden
:
(()
->
Unit
)?
=
null
private
var
loadingListener
:
(()
->
Unit
)?
=
null
private
var
loadingListener
:
((
flag
:
Boolean
)
->
Unit
)?
=
null
private
var
activityString
=
""
private
var
activityString
=
""
private
fun
setListener
(
activity
:
Activity
)
{
private
fun
setListener
(
activity
:
Activity
)
{
...
@@ -33,7 +33,7 @@ object AdMaxOpenUtils {
...
@@ -33,7 +33,7 @@ object AdMaxOpenUtils {
override
fun
onAdLoaded
(
p0
:
MaxAd
)
{
override
fun
onAdLoaded
(
p0
:
MaxAd
)
{
LogEx
.
logDebug
(
TAG
,
"广告拉取成功"
)
LogEx
.
logDebug
(
TAG
,
"广告拉取成功"
)
openLoadTime
=
System
.
currentTimeMillis
()
openLoadTime
=
System
.
currentTimeMillis
()
loadingListener
?.
invoke
()
loadingListener
?.
invoke
(
true
)
loadingListener
=
null
loadingListener
=
null
AdMaxEvent
.
pullAd
(
p0
,
"openAd"
)
AdMaxEvent
.
pullAd
(
p0
,
"openAd"
)
}
}
...
@@ -42,7 +42,7 @@ object AdMaxOpenUtils {
...
@@ -42,7 +42,7 @@ object AdMaxOpenUtils {
LogEx
.
logDebug
(
TAG
,
"广告拉取失败了,onAdLoadFailed:"
+
p0
)
LogEx
.
logDebug
(
TAG
,
"广告拉取失败了,onAdLoadFailed:"
+
p0
)
LogEx
.
logDebug
(
TAG
,
"广告拉取失败了,onAdLoadFailed:"
+
p1
.
message
.
toString
())
LogEx
.
logDebug
(
TAG
,
"广告拉取失败了,onAdLoadFailed:"
+
p1
.
message
.
toString
())
LogEx
.
logDebug
(
TAG
,
"广告拉取失败了,onAdLoadFailed:"
+
p1
.
code
)
LogEx
.
logDebug
(
TAG
,
"广告拉取失败了,onAdLoadFailed:"
+
p1
.
code
)
loadingListener
?.
invoke
()
loadingListener
?.
invoke
(
false
)
loadingListener
=
null
loadingListener
=
null
AdDisplayUtils
.
getInstance
().
incrementAdRequestFailCount
()
AdDisplayUtils
.
getInstance
().
incrementAdRequestFailCount
()
val
reqId
=
UUID
.
randomUUID
().
toString
()
val
reqId
=
UUID
.
randomUUID
().
toString
()
...
@@ -93,7 +93,7 @@ object AdMaxOpenUtils {
...
@@ -93,7 +93,7 @@ object AdMaxOpenUtils {
fun
showAppOpenAd
(
fun
showAppOpenAd
(
activity
:
Activity
,
activity
:
Activity
,
loadCallBack
:
(()
->
Unit
)?
=
null
,
loadCallBack
:
((
loaded
:
Boolean
)
->
Unit
)?
=
null
,
onHidden
:
(()
->
Unit
)?
=
null
onHidden
:
(()
->
Unit
)?
=
null
)
{
)
{
...
@@ -144,8 +144,8 @@ object AdMaxOpenUtils {
...
@@ -144,8 +144,8 @@ object AdMaxOpenUtils {
LogEx
.
logDebug
(
TAG
,
"展示时候,发现广告需要拉取"
)
LogEx
.
logDebug
(
TAG
,
"展示时候,发现广告需要拉取"
)
val
loaded
=
loadAppOpenAd
(
activity
)
val
loaded
=
loadAppOpenAd
(
activity
)
if
(
loaded
)
{
if
(
loaded
)
{
loadingListener
=
{
loadingListener
=
{
loadResult
->
loadCallBack
?.
invoke
()
loadCallBack
?.
invoke
(
loadResult
)
LogEx
.
logDebug
(
TAG
,
"loadingListener callback"
)
LogEx
.
logDebug
(
TAG
,
"loadingListener callback"
)
if
(
appOpenAd
?.
isReady
==
true
)
{
if
(
appOpenAd
?.
isReady
==
true
)
{
AdMaxOpenUtils
.
onHidden
=
onHidden
AdMaxOpenUtils
.
onHidden
=
onHidden
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/bean/ParentBean.kt
View file @
d4677a01
...
@@ -2,8 +2,8 @@ package com.base.filerecoveryrecyclebin.bean
...
@@ -2,8 +2,8 @@ package com.base.filerecoveryrecyclebin.bean
data class
ParentBean
(
data class
ParentBean
(
val
title
:
String
,
val
title
:
String
,
val
childItem
:
List
<
ChildBean
>
,
val
childItem
:
ArrayList
<
ChildBean
>
=
arrayListOf
()
,
var
parentSize
:
Long
,
var
parentSize
:
Long
=
0
,
var
isParentSelected
:
Boolean
,
var
isParentSelected
:
Boolean
,
var
expanded
:
Boolean
=
true
,
var
expanded
:
Boolean
=
true
,
var
isfinish
:
Boolean
=
false
var
isfinish
:
Boolean
=
false
...
@@ -12,9 +12,9 @@ data class ParentBean(
...
@@ -12,9 +12,9 @@ data class ParentBean(
data class
ChildBean
(
data class
ChildBean
(
val
image
:
Int
?
=
null
,
val
image
:
Int
?
=
null
,
val
childname
:
String
,
val
childname
:
String
,
val
chilepath
:
String
=
""
,
val
chilepath
:
String
=
""
,
val
childSize
:
Long
=
0L
,
val
childSize
:
Long
=
0L
,
var
isChildSelected
:
Boolean
=
true
,
var
isChildSelected
:
Boolean
=
true
,
var
pathList
:
List
<
String
>?
=
null
,
var
pathList
:
List
<
String
>?
=
null
,
var
packageName
:
String
?=
""
var
packageName
:
String
?
=
""
)
)
\ No newline at end of file
app/src/main/res/color/color_delete_selector.xml
0 → 100644
View file @
d4677a01
<?xml version="1.0" encoding="utf-8"?>
<selector
xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<item
android:color=
"#999A9C"
android:state_enabled=
"false"
/>
<item
android:color=
"@color/white"
android:state_enabled=
"true"
/>
</selector>
\ No newline at end of file
app/src/main/res/drawable/bg_delete_selector.xml
0 → 100644
View file @
d4677a01
<?xml version="1.0" encoding="utf-8"?>
<selector
xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<item
android:state_enabled=
"true"
android:drawable=
"@drawable/bg_577dfd_22"
/>
<item
android:state_enabled=
"false"
android:drawable=
"@drawable/bg_e6e7e9_22"
/>
</selector>
\ No newline at end of file
app/src/main/res/drawable/bg_e6e7e9_22.xml
0 → 100644
View file @
d4677a01
<?xml version="1.0" encoding="utf-8"?>
<shape
xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<solid
android:color=
"#e6e7e9"
/>
<corners
android:radius=
"22dp"
/>
</shape>
\ No newline at end of file
app/src/main/res/drawable/bg_ffffff_tlr10.xml
0 → 100644
View file @
d4677a01
<?xml version="1.0" encoding="utf-8"?>
<shape
xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<solid
android:color=
"@color/white"
/>
<corners
android:topLeftRadius=
"10dp"
android:topRightRadius=
"10dp"
/>
</shape>
\ No newline at end of file
app/src/main/res/layout/activity_layout_clean_junk.xml
View file @
d4677a01
...
@@ -15,29 +15,31 @@
...
@@ -15,29 +15,31 @@
android:orientation=
"vertical"
android:orientation=
"vertical"
app:layout_constraintTop_toTopOf=
"parent"
>
app:layout_constraintTop_toTopOf=
"parent"
>
<View
<FrameLayout
android:layout_width=
"match_parent"
android:layout_height=
"40dp"
/>
<RelativeLayout
android:id=
"@+id/id_top_rl"
android:layout_width=
"match_parent"
android:layout_width=
"match_parent"
android:layout_height=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_marginTop=
"12dp"
app:layout_constraintTop_toTopOf=
"parent"
>
app:layout_constraintTop_toTopOf=
"parent"
>
<
androidx.appcompat.widget.AppCompatImageView
<
FrameLayout
android:id=
"@+id/
id_junks_back
"
android:id=
"@+id/
fl_fanhui
"
android:layout_width=
"wrap_content"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_height=
"wrap_content"
android:paddingHorizontal=
"20dp"
android:padding=
"15dp"
>
android:src=
"@mipmap/fanhui"
/>
<ImageView
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:src=
"@mipmap/fanhui"
tools:ignore=
"ContentDescription"
/>
</FrameLayout>
<TextView
<TextView
android:id=
"@+id/id_tv_title_back"
android:id=
"@+id/id_tv_title_back"
android:layout_width=
"wrap_content"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_
centerInParent=
"true
"
android:layout_
gravity=
"center
"
android:gravity=
"center"
android:gravity=
"center"
android:text=
"Clean Junk"
android:text=
"Clean Junk"
android:textColor=
"@color/white"
android:textColor=
"@color/white"
...
@@ -45,50 +47,70 @@
...
@@ -45,50 +47,70 @@
android:textStyle=
"bold"
android:textStyle=
"bold"
tools:ignore=
"HardcodedText"
/>
tools:ignore=
"HardcodedText"
/>
</
Relativ
eLayout>
</
Fram
eLayout>
<androidx.appcompat.widget.LinearLayoutCompat
<FrameLayout
android:layout_width=
"match_parent"
android:layout_height=
"wrap_content"
>
<LinearLayout
android:layout_width=
"match_parent"
android:layout_width=
"match_parent"
android:layout_height=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_marginTop=
"60dp"
android:orientation=
"vertical"
tools:ignore=
"UselessParent"
>
<LinearLayout
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_gravity=
"center_horizontal"
android:layout_marginTop=
"40dp"
android:layout_marginBottom=
"10dp"
android:layout_marginBottom=
"10dp"
android:gravity=
"center_horizontal"
>
android:gravity=
"center_horizontal"
>
<TextView
<TextView
android:id=
"@+id/id_ke_cl
"
android:id=
"@+id/tv_size
"
android:layout_width=
"wrap_content"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_gravity=
"bottom"
android:layout_gravity=
"bottom"
android:layout_marginEnd=
"7dp"
android:layout_marginEnd=
"7dp"
android:includeFontPadding=
"false"
android:includeFontPadding=
"false"
android:text=
"0"
android:textColor=
"@color/white"
android:textColor=
"@color/white"
android:textSize=
"43
sp"
android:textSize=
"45
sp"
android:textStyle=
"bold"
android:textStyle=
"bold"
tools:text=
"0
"
/>
tools:ignore=
"HardcodedText
"
/>
<TextView
<TextView
android:id=
"@+id/id_size
_unit"
android:id=
"@+id/tv
_unit"
android:layout_width=
"wrap_content"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_gravity=
"top"
android:layout_gravity=
"top"
android:layout_marginTop=
"10
dp"
android:layout_marginTop=
"8
dp"
android:includeFontPadding=
"false"
android:includeFontPadding=
"false"
android:text=
"KB"
android:textColor=
"@color/white"
android:textColor=
"@color/white"
android:textSize=
"12sp"
android:textSize=
"12sp"
tools:text=
"KB"
/>
tools:ignore=
"HardcodedText"
/>
</androidx.appcompat.widget.LinearLayoutCompat>
</LinearLayout>
<TextView
<TextView
android:layout_width=
"wrap_content"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_height=
"wrap_content"
android:layout_gravity=
"center_horizontal"
android:layout_gravity=
"center_horizontal"
android:layout_marginBottom=
"4
5dp"
android:layout_marginBottom=
"3
5dp"
android:text=
"Cleanable"
android:text=
"Cleanable"
android:textColor=
"@color/white"
android:textColor=
"@color/white"
android:textSize=
"14sp"
android:textSize=
"14sp"
tools:ignore=
"HardcodedText"
/>
tools:ignore=
"HardcodedText"
/>
</LinearLayout>
</LinearLayout>
</FrameLayout>
</LinearLayout>
<FrameLayout
<FrameLayout
android:layout_width=
"match_parent"
android:layout_width=
"match_parent"
android:layout_height=
"0dp"
android:layout_height=
"0dp"
...
@@ -104,14 +126,14 @@
...
@@ -104,14 +126,14 @@
android:orientation=
"vertical"
>
android:orientation=
"vertical"
>
<pokercc.android.expandablerecyclerview.ExpandableRecyclerView
<pokercc.android.expandablerecyclerview.ExpandableRecyclerView
android:id=
"@+id/
id_ex_rl
"
android:id=
"@+id/
ex_rv
"
android:layout_width=
"match_parent"
android:layout_width=
"match_parent"
android:layout_height=
"0dp"
android:layout_height=
"0dp"
android:layout_weight=
"1"
android:layout_weight=
"1"
android:visibility=
"visible"
/>
android:visibility=
"visible"
/>
<TextView
<TextView
android:id=
"@+id/
id_cl
_btn"
android:id=
"@+id/
tv
_btn"
android:layout_width=
"match_parent"
android:layout_width=
"match_parent"
android:layout_height=
"48dp"
android:layout_height=
"48dp"
android:layout_marginHorizontal=
"40dp"
android:layout_marginHorizontal=
"40dp"
...
...
app/src/main/res/mipmap-xxhdpi/log_clean.png
0 → 100644
View file @
d4677a01
3.93 KB
app/src/main/res/mipmap-xxhdpi/temp_clean.png
0 → 100644
View file @
d4677a01
4.37 KB
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