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
49076366
Commit
49076366
authored
Jul 19, 2024
by
wanglei
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
...
parent
86371d0f
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
97 additions
and
30 deletions
+97
-30
build.gradle
app/build.gradle
+1
-1
MainActivity.kt
.../com/base/filerecoveryrecyclebin/activity/MainActivity.kt
+29
-2
PhotoManagerActivity.kt
...yrecyclebin/activity/photomanager/PhotoManagerActivity.kt
+9
-8
HomeFragment.kt
.../com/base/filerecoveryrecyclebin/fragment/HomeFragment.kt
+13
-0
ConfigHelper.kt
...java/com/base/filerecoveryrecyclebin/help/ConfigHelper.kt
+2
-2
bg_eb423b_2_5.xml
app/src/main/res/drawable/bg_eb423b_2_5.xml
+6
-0
fragment_home_3.xml
app/src/main/res/layout/fragment_home_3.xml
+36
-16
libs.versions.toml
gradle/libs.versions.toml
+1
-1
No files found.
app/build.gradle
View file @
49076366
...
...
@@ -95,7 +95,7 @@ dependencies {
//max
implementation
'com.applovin:applovin-sdk:+'
implementation
'com.applovin.mediation:google-ad
-manager-ad
apter:+'
implementation
'com.applovin.mediation:google-adapter:+'
implementation
'com.applovin.mediation:facebook-adapter:+'
implementation
'com.applovin.mediation:mintegral-adapter:+'
implementation
'com.applovin.mediation:bytedance-adapter:+'
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/activity/MainActivity.kt
View file @
49076366
...
...
@@ -3,6 +3,7 @@ package com.base.filerecoveryrecyclebin.activity
import
android.content.Intent
import
android.graphics.Color
import
android.graphics.Typeface
import
android.os.Environment
import
androidx.activity.addCallback
import
androidx.core.view.updatePadding
import
androidx.fragment.app.Fragment
...
...
@@ -10,19 +11,24 @@ import androidx.lifecycle.lifecycleScope
import
androidx.viewpager2.adapter.FragmentStateAdapter
import
androidx.viewpager2.widget.ViewPager2
import
com.base.filerecoveryrecyclebin.ads.admob.AdmobBannerUtils
import
com.base.filerecoveryrecyclebin.bean.MediaBean
import
com.base.filerecoveryrecyclebin.databinding.ActivityMainBinding
import
com.base.filerecoveryrecyclebin.fragment.HomeFragment
import
com.base.filerecoveryrecyclebin.fragment.RecycleBinFragment
import
com.base.filerecoveryrecyclebin.help.BaseActivity
import
com.base.filerecoveryrecyclebin.help.FileHelp
import
com.base.filerecoveryrecyclebin.help.MediaStoreHelp.getImageMedia
import
com.base.filerecoveryrecyclebin.help.PermissionHelp.checkStorePermission
import
com.base.filerecoveryrecyclebin.service.StayNotificationService
import
com.base.filerecoveryrecyclebin.utils.BarUtils
import
com.base.filerecoveryrecyclebin.utils.FileHexEx
import
com.base.filerecoveryrecyclebin.view.DialogViews.showExitDialog
import
com.base.filerecoveryrecyclebin.view.PermissionDialog.showPermissionBottomSheet
import
com.base.filerecoveryrecyclebin.view.RateStarPop.showRateStarPopDialog
import
kotlinx.coroutines.Dispatchers
import
kotlinx.coroutines.delay
import
kotlinx.coroutines.launch
import
java.io.File
class
MainActivity
:
BaseActivity
<
ActivityMainBinding
>()
{
private
val
TAG
=
"MainActivity"
...
...
@@ -115,7 +121,8 @@ class MainActivity : BaseActivity<ActivityMainBinding>() {
}
}
}
fun
setPage
(
p
:
Int
){
fun
setPage
(
p
:
Int
)
{
binding
.
viewpager2
.
currentItem
=
p
}
...
...
@@ -126,11 +133,31 @@ class MainActivity : BaseActivity<ActivityMainBinding>() {
}
}
var
photoSizeAction
:
((
size
:
Long
)
->
Unit
)?
=
null
fun
initPhotoSize
()
=
lifecycleScope
.
launch
(
Dispatchers
.
IO
)
{
val
dcimSize
=
FileHelp
.
getDirFiles
(
Environment
.
getExternalStoragePublicDirectory
(
Environment
.
DIRECTORY_DCIM
))
.
filter
{
FileHexEx
.
isImage
(
it
)
}
.
sumOf
{
it
.
length
()
}
val
list
=
arrayListOf
<
MediaBean
>()
getImageMedia
(
list
)
val
photoSize
=
list
.
map
{
File
(
it
.
path
)
}.
sumOf
{
it
.
length
()
}
launch
(
Dispatchers
.
Main
)
{
val
size
=
dcimSize
+
photoSize
photoSizeAction
?.
invoke
(
size
)
}
}
override
fun
onResume
()
{
super
.
onResume
()
if
(
checkStorePermission
())
{
initStayServiceObserver
()
initPhotoSize
()
}
lifecycleScope
.
launch
(
Dispatchers
.
Main
)
{
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/activity/photomanager/PhotoManagerActivity.kt
View file @
49076366
...
...
@@ -39,7 +39,8 @@ class PhotoManagerActivity : BaseActivity<ActivityPhotoManagerBinding>() {
initDataSize
()
}
else
{
showGerPermission
(
null
,
deny
=
{
finishToMain
()
},
allow
=
{
showGerPermission
(
"This feature requires access to your storage to scan your files and clean up screenshots. We will not transmit your data to any third-party service. Please grant permission so that we can provide you with better service."
,
deny
=
{
finishToMain
()
},
allow
=
{
requestStorePermission
(
launcher
)
{
if
(
it
)
{
initDataSize
()
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/fragment/HomeFragment.kt
View file @
49076366
package
com.base.filerecoveryrecyclebin.fragment
import
android.animation.ValueAnimator
import
android.annotation.SuppressLint
import
android.content.Intent
import
android.view.View
import
com.base.filerecoveryrecyclebin.activity.MainActivity
import
com.base.filerecoveryrecyclebin.activity.SettingActivity
import
com.base.filerecoveryrecyclebin.activity.junkclean.ScanJunkActivity
import
com.base.filerecoveryrecyclebin.activity.photomanager.PhotoManagerActivity
...
...
@@ -15,6 +18,7 @@ import com.base.filerecoveryrecyclebin.bean.ConstObject.SCAN_PHOTOS
import
com.base.filerecoveryrecyclebin.bean.ConstObject.SCAN_VIDEOS
import
com.base.filerecoveryrecyclebin.databinding.FragmentHome3Binding
import
com.base.filerecoveryrecyclebin.help.BaseFragment
import
com.base.filerecoveryrecyclebin.help.KotlinExt.toFormatSize
class
HomeFragment
:
BaseFragment
<
FragmentHome3Binding
>()
{
...
...
@@ -22,6 +26,7 @@ class HomeFragment : BaseFragment<FragmentHome3Binding>() {
FragmentHome3Binding
.
inflate
(
layoutInflater
)
}
@SuppressLint
(
"SetTextI18n"
)
override
fun
setView
()
{
binding
.
tvTitle
.
text
=
"Dumpster"
binding
.
lottie
.
repeatCount
=
ValueAnimator
.
INFINITE
...
...
@@ -65,6 +70,14 @@ class HomeFragment : BaseFragment<FragmentHome3Binding>() {
binding
.
ivVip
.
setOnClickListener
{
startActivity
(
Intent
(
requireContext
(),
VipActivity
::
class
.
java
))
}
(
requireActivity
()
as
MainActivity
).
photoSizeAction
=
{
if
(
it
==
0L
)
{
binding
.
tvPhotoSize
.
visibility
=
View
.
INVISIBLE
binding
.
tvPhotoSize
.
text
=
it
.
toFormatSize
(
0
)
}
else
{
binding
.
tvPhotoSize
.
visibility
=
View
.
GONE
}
}
}
...
...
app/src/main/java/com/base/filerecoveryrecyclebin/help/ConfigHelper.kt
View file @
49076366
...
...
@@ -20,8 +20,8 @@ object ConfigHelper {
const
val
bannerAdmobId
=
"ca-app-pub-3940256099942544/9214589741"
const
val
interAdMaxId
=
"b31e7f6d11ee659e"
const
val
nativeAdMaxId
=
"
96e8fe78b0efc5d1
"
const
val
openAdMaxId
=
"
YOUR_AD_UNIT_ID
"
const
val
nativeAdMaxId
=
"
d1d943cdd3127c90
"
const
val
openAdMaxId
=
"
96e8fe78b0efc5d1
"
const
val
bannerMaxId
=
"ca-app-pub-3940256099942544/9214589741"
//一定展示大图广告
...
...
app/src/main/res/drawable/bg_eb423b_2_5.xml
0 → 100644
View file @
49076366
<?xml version="1.0" encoding="utf-8"?>
<shape
xmlns:android=
"http://schemas.android.com/apk/res/android"
>
<solid
android:color=
"#EB423B"
/>
<corners
android:radius=
"2.5dp"
/>
</shape>
\ No newline at end of file
app/src/main/res/layout/fragment_home_3.xml
View file @
49076366
...
...
@@ -434,6 +434,10 @@
app:cardCornerRadius=
"10dp"
app:cardElevation=
"0dp"
>
<LinearLayout
android:layout_width=
"match_parent"
android:layout_height=
"match_parent"
>
<TextView
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
...
...
@@ -444,6 +448,20 @@
android:textSize=
"16sp"
tools:ignore=
"HardcodedText"
/>
<TextView
android:id=
"@+id/tv_photo_size"
android:layout_width=
"0dp"
android:layout_height=
"wrap_content"
android:layout_marginHorizontal=
"2dp"
android:layout_marginTop=
"20dp"
android:layout_weight=
"1"
android:background=
"@drawable/bg_eb423b_2_5"
android:gravity=
"center"
android:textColor=
"@color/white"
android:textSize=
"9sp"
tools:ignore=
"SmallSp"
tools:text=
"0.1GB"
/>
<ImageView
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
...
...
@@ -451,6 +469,8 @@
android:layout_marginEnd=
"8dp"
android:src=
"@mipmap/h_management"
tools:ignore=
"ContentDescription"
/>
</LinearLayout>
</androidx.cardview.widget.CardView>
...
...
gradle/libs.versions.toml
View file @
49076366
[versions]
agp
=
"8.0.0"
kotlin
=
"1.8.0"
coreKtx
=
"1.8.
1
"
coreKtx
=
"1.8.
0
"
junit
=
"4.13.2"
junitVersion
=
"1.1.5"
espressoCore
=
"3.5.1"
...
...
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