v1.1(2)
This commit is contained in:
commit
1ff3d16036
15
.gitignore
vendored
Normal file
15
.gitignore
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
*.iml
|
||||
.gradle
|
||||
/local.properties
|
||||
/.idea/caches
|
||||
/.idea/libraries
|
||||
/.idea/modules.xml
|
||||
/.idea/workspace.xml
|
||||
/.idea/navEditor.xml
|
||||
/.idea/assetWizardSettings.xml
|
||||
.DS_Store
|
||||
/build
|
||||
/captures
|
||||
.externalNativeBuild
|
||||
.cxx
|
||||
local.properties
|
||||
1
app/.gitignore
vendored
Normal file
1
app/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
/build
|
||||
BIN
app/PhoneWallpaper.jks
Normal file
BIN
app/PhoneWallpaper.jks
Normal file
Binary file not shown.
147
app/build.gradle.kts
Normal file
147
app/build.gradle.kts
Normal file
@ -0,0 +1,147 @@
|
||||
import java.util.Date
|
||||
import java.text.SimpleDateFormat
|
||||
|
||||
plugins {
|
||||
id("com.android.application")
|
||||
id("org.jetbrains.kotlin.android")
|
||||
id("io.objectbox")
|
||||
kotlin("kapt")
|
||||
id("com.google.gms.google-services")
|
||||
id("com.google.firebase.crashlytics")
|
||||
}
|
||||
val timestamp = SimpleDateFormat("MM_dd_HH_mm").format(Date())
|
||||
android {
|
||||
namespace = "com.phone.wall.paper"
|
||||
compileSdk = 35
|
||||
|
||||
defaultConfig {
|
||||
//com.phone.wall.paper
|
||||
applicationId = "com.phone.wall.paper"
|
||||
minSdk = 24
|
||||
targetSdk = 35
|
||||
versionCode = 2
|
||||
versionName = "1.1"
|
||||
|
||||
setProperty("archivesBaseName", "Phone Wallpaper_V" + versionName + "(${versionCode})_$timestamp")
|
||||
testInstrumentationRunner = "androidx.live.runner.AndroidJUnitRunner"
|
||||
}
|
||||
|
||||
buildTypes {
|
||||
release {
|
||||
isMinifyEnabled = true
|
||||
proguardFiles(
|
||||
getDefaultProguardFile("proguard-android-optimize.txt"),
|
||||
"proguard-rules.pro"
|
||||
)
|
||||
}
|
||||
}
|
||||
compileOptions {
|
||||
sourceCompatibility = JavaVersion.VERSION_11
|
||||
targetCompatibility = JavaVersion.VERSION_11
|
||||
}
|
||||
buildFeatures{
|
||||
viewBinding = true
|
||||
}
|
||||
kotlinOptions {
|
||||
jvmTarget = "11"
|
||||
}
|
||||
}
|
||||
|
||||
dependencies {
|
||||
|
||||
// implementation("androidx.appcompat:appcompat:1.6.1")
|
||||
implementation("com.google.android.material:material:1.11.0")
|
||||
implementation("androidx.constraintlayout:constraintlayout:2.1.4")
|
||||
testImplementation("junit:junit:4.13.2")
|
||||
implementation ("com.github.bumptech.glide:glide:4.16.0")
|
||||
implementation ("jp.wasabeef:glide-transformations:4.3.0") // Glide Transformations
|
||||
// implementation("com.squareup.okhttp3:okhttp:4.12.0")
|
||||
|
||||
implementation(files("libs/TopOnLibrary_06_27_16_00-release.aar"))
|
||||
implementation(files("libs/UpLoadLibrary_07_03_11_54-release.aar"))
|
||||
|
||||
|
||||
implementation(platform("com.google.firebase:firebase-bom:33.7.0"))
|
||||
implementation("com.google.firebase:firebase-crashlytics")
|
||||
implementation("com.google.firebase:firebase-analytics")
|
||||
implementation("com.google.firebase:firebase-config")
|
||||
|
||||
//-----------------------------------------------TopOn(Mintegral、Pangle、UnitAds、Digital Turbine(Fyber)、Chartboost&Helium、Ironsource、Liftoff(Vungle)、Inmobi、Start.io、Bigo)
|
||||
//TU (Necessary)
|
||||
implementation("com.thinkup.sdk:core-tpn:6.4.90")
|
||||
implementation("com.thinkup.sdk:nativead-tpn:6.4.90")
|
||||
implementation("com.thinkup.sdk:banner-tpn:6.4.90")
|
||||
implementation("com.thinkup.sdk:interstitial-tpn:6.4.90")
|
||||
implementation("com.thinkup.sdk:rewardedvideo-tpn:6.4.90")
|
||||
implementation("com.thinkup.sdk:splash-tpn:6.4.90")
|
||||
|
||||
//Androidx (Necessary)
|
||||
implementation("androidx.appcompat:appcompat:1.6.1")
|
||||
implementation("androidx.browser:browser:1.4.0")
|
||||
|
||||
//StartApp
|
||||
implementation("com.thinkup.sdk:adapter-tpn-startapp:6.4.90")
|
||||
implementation("com.startapp:inapp-sdk:5.0.2")
|
||||
|
||||
//Vungle
|
||||
implementation("com.thinkup.sdk:adapter-tpn-vungle:6.4.90")
|
||||
implementation("com.vungle:vungle-ads:7.5.0")
|
||||
implementation("com.google.android.gms:play-services-basement:18.1.0")
|
||||
implementation("com.google.android.gms:play-services-ads-identifier:18.0.1")
|
||||
|
||||
//UnityAds
|
||||
implementation("com.thinkup.sdk:adapter-tpn-unityads:6.4.90")
|
||||
implementation("com.unity3d.ads:unity-ads:4.14.0")
|
||||
|
||||
//Ironsource
|
||||
implementation("com.thinkup.sdk:adapter-tpn-ironsource:6.4.90")
|
||||
implementation("com.ironsource.sdk:mediationsdk:8.7.0")
|
||||
implementation("com.google.android.gms:play-services-appset:16.0.2")
|
||||
implementation("com.google.android.gms:play-services-ads-identifier:18.0.1")
|
||||
implementation("com.google.android.gms:play-services-basement:18.1.0")
|
||||
|
||||
//Bigo
|
||||
implementation("com.thinkup.sdk:adapter-tpn-bigo:6.4.90")
|
||||
implementation("com.bigossp:bigo-ads:5.3.0")
|
||||
|
||||
//Pangle
|
||||
implementation("com.thinkup.sdk:adapter-tpn-pangle:6.4.90.1")
|
||||
implementation("com.pangle.global:pag-sdk:7.2.0.6")
|
||||
implementation("com.google.android.gms:play-services-ads-identifier:18.2.0")
|
||||
|
||||
//Inmobi
|
||||
implementation("com.thinkup.sdk:adapter-tpn-inmobi:6.4.90")
|
||||
implementation("com.inmobi.monetization:inmobi-ads-kotlin:10.8.2")
|
||||
|
||||
//Mintegral
|
||||
implementation("com.thinkup.sdk:adapter-tpn-mintegral:6.4.90")
|
||||
implementation("com.mbridge.msdk.oversea:mbridge_android_sdk:16.9.71")
|
||||
implementation("androidx.recyclerview:recyclerview:1.1.0")
|
||||
|
||||
//Chartboost
|
||||
implementation("com.thinkup.sdk:adapter-tpn-chartboost:6.4.90")
|
||||
implementation("com.chartboost:chartboost-sdk:9.8.3")
|
||||
implementation("com.chartboost:chartboost-mediation-sdk:4.9.2")
|
||||
implementation("com.chartboost:chartboost-mediation-adapter-chartboost:4.9.8.1.0")
|
||||
implementation("com.jakewharton.retrofit:retrofit2-kotlinx-serialization-converter:1.0.0")
|
||||
implementation("com.squareup.okhttp3:logging-interceptor:4.10.0")
|
||||
implementation("com.squareup.okhttp3:okhttp:4.10.0")
|
||||
implementation("com.squareup.retrofit2:converter-scalars:2.9.0")
|
||||
implementation("com.squareup.retrofit2:retrofit:2.9.0")
|
||||
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-android:1.7.1")
|
||||
implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.5.1")
|
||||
|
||||
//Fyber
|
||||
implementation("com.thinkup.sdk:adapter-tpn-fyber:6.4.90")
|
||||
implementation("com.fyber:marketplace-sdk:8.3.7")
|
||||
implementation("com.google.android.gms:play-services-ads-identifier:18.0.1")
|
||||
|
||||
//Tramini
|
||||
implementation("com.thinkup.sdk:tramini-plugin-tpn:6.4.90")
|
||||
|
||||
// Debugger UI Tools
|
||||
implementation("com.anythink.sdk:debugger-ui:1.1.0")
|
||||
|
||||
//----------------------------------------------TopOn
|
||||
|
||||
}
|
||||
29
app/google-services.json
Normal file
29
app/google-services.json
Normal file
@ -0,0 +1,29 @@
|
||||
{
|
||||
"project_info": {
|
||||
"project_number": "1056121338240",
|
||||
"project_id": "phone-wallpaper-6ae91",
|
||||
"storage_bucket": "phone-wallpaper-6ae91.firebasestorage.app"
|
||||
},
|
||||
"client": [
|
||||
{
|
||||
"client_info": {
|
||||
"mobilesdk_app_id": "1:1056121338240:android:3acb016ee2762ea70d6965",
|
||||
"android_client_info": {
|
||||
"package_name": "com.phone.wall.paper"
|
||||
}
|
||||
},
|
||||
"oauth_client": [],
|
||||
"api_key": [
|
||||
{
|
||||
"current_key": "AIzaSyAwDdY65l-IQAfsUVd-Oxcxh2HbOxX9X78"
|
||||
}
|
||||
],
|
||||
"services": {
|
||||
"appinvite_service": {
|
||||
"other_platform_oauth_client": []
|
||||
}
|
||||
}
|
||||
}
|
||||
],
|
||||
"configuration_version": "1"
|
||||
}
|
||||
BIN
app/libs/TopOnLibrary_06_27_16_00-release.aar
Normal file
BIN
app/libs/TopOnLibrary_06_27_16_00-release.aar
Normal file
Binary file not shown.
BIN
app/libs/UpLoadLibrary_07_03_11_54-release.aar
Normal file
BIN
app/libs/UpLoadLibrary_07_03_11_54-release.aar
Normal file
Binary file not shown.
116
app/objectbox-models/default.json
Normal file
116
app/objectbox-models/default.json
Normal file
@ -0,0 +1,116 @@
|
||||
{
|
||||
"_note1": "KEEP THIS FILE! Check it into a version control system (VCS) like git.",
|
||||
"_note2": "ObjectBox manages crucial IDs for your object model. See docs for details.",
|
||||
"_note3": "If you have VCS merge conflicts, you must resolve them according to ObjectBox docs.",
|
||||
"entities": [
|
||||
{
|
||||
"id": "4:1687638741055622277",
|
||||
"lastPropertyId": "13:2636840041837200420",
|
||||
"name": "DataBean",
|
||||
"properties": [
|
||||
{
|
||||
"id": "1:2096627673800973736",
|
||||
"name": "id",
|
||||
"type": 6,
|
||||
"flags": 1
|
||||
},
|
||||
{
|
||||
"id": "2:3095680478210013390",
|
||||
"name": "categoryName",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "3:7067101084620638058",
|
||||
"name": "imId",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "4:5456025498196270127",
|
||||
"name": "description",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "5:4644058684951595880",
|
||||
"name": "fullUrl",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "6:4981957177607383606",
|
||||
"name": "previewUrl1080",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "7:473964888617906865",
|
||||
"name": "previewUrl400",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "8:366128665796120270",
|
||||
"name": "previewUrl200",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "9:8084935278550814214",
|
||||
"name": "authorName",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "10:3020651830056341176",
|
||||
"name": "authorHeader",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "11:5129862938597637845",
|
||||
"name": "authorHtml",
|
||||
"type": 9
|
||||
},
|
||||
{
|
||||
"id": "12:1611303835697966760",
|
||||
"name": "isLike",
|
||||
"type": 1
|
||||
},
|
||||
{
|
||||
"id": "13:2636840041837200420",
|
||||
"name": "isDownload",
|
||||
"type": 1
|
||||
}
|
||||
],
|
||||
"relations": []
|
||||
}
|
||||
],
|
||||
"lastEntityId": "4:1687638741055622277",
|
||||
"lastIndexId": "0:0",
|
||||
"lastRelationId": "0:0",
|
||||
"lastSequenceId": "0:0",
|
||||
"modelVersion": 5,
|
||||
"modelVersionParserMinimum": 5,
|
||||
"retiredEntityUids": [
|
||||
8119453540460508569,
|
||||
8776066878034520742,
|
||||
817335537070466014
|
||||
],
|
||||
"retiredIndexUids": [],
|
||||
"retiredPropertyUids": [
|
||||
8848640050018073106,
|
||||
4870222079156330783,
|
||||
4966768060561274983,
|
||||
8892036187720267027,
|
||||
1670319685727744805,
|
||||
3855211567189961055,
|
||||
7567671966987007993,
|
||||
2590164264280025677,
|
||||
8912833100894718986,
|
||||
7138929457594592554,
|
||||
3957870060050722570,
|
||||
2943285943884558608,
|
||||
7262008615134929676,
|
||||
7105947400861196483,
|
||||
1954934496493857304,
|
||||
8582031355111471002,
|
||||
8410380097928190493,
|
||||
3380197792593924336,
|
||||
5750724995960958985
|
||||
],
|
||||
"retiredRelationUids": [],
|
||||
"version": 1
|
||||
}
|
||||
40
app/proguard-rules.pro
vendored
Normal file
40
app/proguard-rules.pro
vendored
Normal file
@ -0,0 +1,40 @@
|
||||
# Add project specific ProGuard rules here.
|
||||
# You can control the set of applied configuration files using the
|
||||
# proguardFiles setting in build.gradle.
|
||||
#
|
||||
# For more details, see
|
||||
# http://developer.android.com/guide/developing/tools/proguard.html
|
||||
|
||||
# If your project uses WebView with JS, uncomment the following
|
||||
# and specify the fully qualified class name to the JavaScript interface
|
||||
# class:
|
||||
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
|
||||
# public *;
|
||||
#}
|
||||
|
||||
# Uncomment this to preserve the line number information for
|
||||
# debugging stack traces.
|
||||
#-keepattributes SourceFile,LineNumberTable
|
||||
|
||||
# If you keep the line number information, uncomment this to
|
||||
# hide the original source file name.
|
||||
#-renamesourcefileattribute SourceFile
|
||||
-keep class com.phone.wall.paper.data.** { *; }
|
||||
-keep class com.google.gson.** { *; }
|
||||
-keepattributes Signature
|
||||
-keepattributes AnnotationDefault,RuntimeVisibleAnnotations
|
||||
|
||||
|
||||
# 保留Processor类,这些类用于在编译时生成ObjectBox需要的代码
|
||||
-keep @io.objectbox.annotation.processor.Processor class * {
|
||||
*;
|
||||
}
|
||||
|
||||
# 保留ObjectBox的关键方法和构造函数
|
||||
-keepclassmembers class * extends io.objectbox.Box {
|
||||
<init>(...);
|
||||
<methods>;
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -0,0 +1,26 @@
|
||||
package com.free.life.wallpaper;
|
||||
|
||||
import android.content.Context;
|
||||
|
||||
import androidx.test.platform.app.InstrumentationRegistry;
|
||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
/**
|
||||
* Instrumented live, which will execute on an Android device.
|
||||
*
|
||||
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
||||
*/
|
||||
@RunWith(AndroidJUnit4.class)
|
||||
public class ExampleInstrumentedTest {
|
||||
@Test
|
||||
public void useAppContext() {
|
||||
// Context of the app under live.
|
||||
Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
|
||||
assertEquals("com.hd.kwallpapers.wallpapers.live", appContext.getPackageName());
|
||||
}
|
||||
}
|
||||
44
app/src/main/AndroidManifest.xml
Normal file
44
app/src/main/AndroidManifest.xml
Normal file
@ -0,0 +1,44 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:tools="http://schemas.android.com/tools">
|
||||
|
||||
<uses-permission android:name="android.permission.INTERNET" />
|
||||
<uses-permission android:name="android.permission.SET_WALLPAPER" />
|
||||
<uses-permission
|
||||
android:name="android.permission.WRITE_EXTERNAL_STORAGE"
|
||||
android:maxSdkVersion="32" />
|
||||
|
||||
<application
|
||||
android:name="com.phone.wall.paper.WallpaperApp"
|
||||
android:allowBackup="true"
|
||||
android:dataExtractionRules="@xml/data_extraction_rules"
|
||||
android:fullBackupContent="@xml/backup_rules"
|
||||
android:icon="@mipmap/icon"
|
||||
android:label="@string/app_name"
|
||||
android:roundIcon="@mipmap/icon"
|
||||
android:networkSecurityConfig="@xml/net"
|
||||
android:supportsRtl="true"
|
||||
android:theme="@style/Theme.Wallpaper"
|
||||
tools:targetApi="31">
|
||||
<activity
|
||||
android:name="com.phone.wall.paper.view.AllList"
|
||||
android:exported="false" />
|
||||
<activity
|
||||
android:name="com.phone.wall.paper.view.Welcome"
|
||||
android:exported="true"
|
||||
android:theme="@style/Theme.WelWallpaper">
|
||||
<intent-filter>
|
||||
<action android:name="android.intent.action.MAIN" />
|
||||
|
||||
<category android:name="android.intent.category.LAUNCHER" />
|
||||
</intent-filter>
|
||||
</activity>
|
||||
<activity
|
||||
android:name="com.phone.wall.paper.view.SetWall"
|
||||
android:exported="false" />
|
||||
<activity
|
||||
android:name="com.phone.wall.paper.view.Main"
|
||||
android:exported="false" />
|
||||
</application>
|
||||
|
||||
</manifest>
|
||||
20703
app/src/main/assets/Animals.json
Normal file
20703
app/src/main/assets/Animals.json
Normal file
File diff suppressed because it is too large
Load Diff
20703
app/src/main/assets/Experimental.json
Normal file
20703
app/src/main/assets/Experimental.json
Normal file
File diff suppressed because it is too large
Load Diff
20703
app/src/main/assets/Featured.json
Normal file
20703
app/src/main/assets/Featured.json
Normal file
File diff suppressed because it is too large
Load Diff
20703
app/src/main/assets/Film.json
Normal file
20703
app/src/main/assets/Film.json
Normal file
File diff suppressed because it is too large
Load Diff
20702
app/src/main/assets/Nature.json
Normal file
20702
app/src/main/assets/Nature.json
Normal file
File diff suppressed because it is too large
Load Diff
20702
app/src/main/assets/Patterns.json
Normal file
20702
app/src/main/assets/Patterns.json
Normal file
File diff suppressed because it is too large
Load Diff
20702
app/src/main/assets/Street.json
Normal file
20702
app/src/main/assets/Street.json
Normal file
File diff suppressed because it is too large
Load Diff
20702
app/src/main/assets/Travel.json
Normal file
20702
app/src/main/assets/Travel.json
Normal file
File diff suppressed because it is too large
Load Diff
BIN
app/src/main/assets/custfont.ttf
Normal file
BIN
app/src/main/assets/custfont.ttf
Normal file
Binary file not shown.
87
app/src/main/java/com/phone/wall/paper/WallpaperApp.java
Normal file
87
app/src/main/java/com/phone/wall/paper/WallpaperApp.java
Normal file
@ -0,0 +1,87 @@
|
||||
package com.phone.wall.paper;
|
||||
|
||||
import android.app.Application;
|
||||
import android.content.Context;
|
||||
import android.graphics.Typeface;
|
||||
import android.util.Log;
|
||||
|
||||
import com.ad.toponlibrary.AdManager;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
import com.phone.wall.paper.tools.JsonData;
|
||||
import com.phone.wall.paper.tools.RoomManager;
|
||||
import com.up.uploadlibrary.UpLoadManager;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.ExecutorService;
|
||||
import java.util.concurrent.Executors;
|
||||
|
||||
public class WallpaperApp extends Application {
|
||||
public static Context mAppContext;
|
||||
|
||||
public static String TAG = "-------MyApp---------";
|
||||
public static Typeface defaultFont;
|
||||
|
||||
|
||||
private String animasName = "Animals.json";
|
||||
private String exName = "Experimental.json";
|
||||
private String filmName = "Film.json";
|
||||
private String natureName = "Nature.json";
|
||||
private String pattName = "Patterns.json";
|
||||
private String streetName = "Street.json";
|
||||
private String travelName = "Travel.json";
|
||||
private String wallpaperName = "Featured.json";
|
||||
private ExecutorService executor;
|
||||
private static List<String> CategoryNames = new ArrayList<>();
|
||||
private int i = 0;
|
||||
|
||||
@Override
|
||||
public void onCreate() {
|
||||
super.onCreate();
|
||||
mAppContext = this;
|
||||
defaultFont = Typeface.createFromAsset(getAssets(), "custfont.ttf");
|
||||
|
||||
AdManager.INSTANCE.init(TAG,this,"h68786a3e636fd","a5739b4755d45478c83d95ecad9ae9485",
|
||||
"9788519403e27aa6420a9b9ad49bc0fc76166bea",
|
||||
"n68786a73d8ea1",
|
||||
"n68786a67e64b5",
|
||||
"n68786a591a90d",false);
|
||||
UpLoadManager.INSTANCE.init(this,TAG);
|
||||
|
||||
RoomManager.init(this);
|
||||
executor = Executors.newFixedThreadPool(8);
|
||||
String[] names = {wallpaperName, animasName, exName, filmName, natureName, pattName, streetName, travelName};
|
||||
|
||||
try {
|
||||
for (String name : names) {
|
||||
InputStream open = getAssets().open(name);
|
||||
String covertStr = Utils.getCovertStr(open);
|
||||
if (!covertStr.isEmpty()) {
|
||||
String realName = name.substring(0, name.indexOf("."));
|
||||
CategoryNames.add(realName);
|
||||
executor.execute(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
i++;
|
||||
Log.d(WallpaperApp.TAG, "------------111");
|
||||
JsonData.INSTANCE.getData(covertStr, realName);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
} catch (IOException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
public static List<String> getCategoryNames() {
|
||||
return CategoryNames;
|
||||
}
|
||||
|
||||
}
|
||||
232
app/src/main/java/com/phone/wall/paper/adapter/AllAda.java
Normal file
232
app/src/main/java/com/phone/wall/paper/adapter/AllAda.java
Normal file
@ -0,0 +1,232 @@
|
||||
package com.phone.wall.paper.adapter;
|
||||
|
||||
import android.content.Context;
|
||||
import android.graphics.Bitmap;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.RelativeLayout;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.recyclerview.widget.DiffUtil;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.bumptech.glide.Glide;
|
||||
import com.bumptech.glide.load.DataSource;
|
||||
import com.bumptech.glide.load.DecodeFormat;
|
||||
import com.bumptech.glide.load.MultiTransformation;
|
||||
import com.bumptech.glide.load.engine.DiskCacheStrategy;
|
||||
import com.bumptech.glide.load.engine.GlideException;
|
||||
import com.bumptech.glide.load.resource.bitmap.CenterCrop;
|
||||
import com.bumptech.glide.request.RequestListener;
|
||||
import com.bumptech.glide.request.RequestOptions;
|
||||
import com.bumptech.glide.request.target.Target;
|
||||
import com.phone.wall.paper.R;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.listener.OnClick;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
|
||||
import java.lang.ref.WeakReference;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import jp.wasabeef.glide.transformations.RoundedCornersTransformation;
|
||||
|
||||
public class AllAda extends RecyclerView.Adapter<AllAda.MyViewHolder> {
|
||||
|
||||
|
||||
private List<DataBean> dataBeanInfo = new ArrayList<>();
|
||||
|
||||
private OnClick onClick;
|
||||
private WeakReference<Context> weakReference;
|
||||
private int itemHeight;
|
||||
|
||||
|
||||
public void setInfoWallpaperListener(OnClick onClick) {
|
||||
this.onClick = onClick;
|
||||
}
|
||||
|
||||
public AllAda(Context myCon, int itemHeight) {
|
||||
weakReference = new WeakReference<>(myCon);
|
||||
this.itemHeight = itemHeight;
|
||||
}
|
||||
|
||||
public void setDataInfo(List<DataBean> dataBeanInfo) {
|
||||
this.dataBeanInfo = dataBeanInfo;
|
||||
notifyDataSetChanged();
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
|
||||
Context context = weakReference.get();
|
||||
if (context != null) {
|
||||
View itemView = LayoutInflater.from(context).inflate(R.layout.ada_all, parent, false);
|
||||
ImageView imageView = itemView.findViewById(R.id.wallpaper);
|
||||
ViewGroup.LayoutParams layoutParams = imageView.getLayoutParams();
|
||||
layoutParams.height = itemHeight;
|
||||
imageView.setLayoutParams(layoutParams);
|
||||
return new MyViewHolder(itemView);
|
||||
}
|
||||
return null;
|
||||
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
|
||||
DataBean info = dataBeanInfo.get(position);
|
||||
ImageView imageView = holder.getImageView();
|
||||
String previewUrl400 = info.getPreviewUrl400();
|
||||
String previewUrl200 = info.getPreviewUrl200();
|
||||
RelativeLayout item = holder.getLayout();
|
||||
View space = holder.getSpace();
|
||||
String imId = info.getImId();
|
||||
int curheight;
|
||||
|
||||
int adapterPosition = holder.getAdapterPosition();
|
||||
if (adapterPosition == dataBeanInfo.size() - 1) {
|
||||
space.setVisibility(View.VISIBLE);
|
||||
} else {
|
||||
space.setVisibility(View.GONE);
|
||||
}
|
||||
MultiTransformation<Bitmap> multiTransformation = new MultiTransformation<>(
|
||||
new CenterCrop(),
|
||||
new RoundedCornersTransformation(Utils.dp2Px(12), 0) // 圆角效果
|
||||
);
|
||||
RequestOptions options = new RequestOptions()
|
||||
.format(DecodeFormat.PREFER_RGB_565);
|
||||
Context context = weakReference.get();
|
||||
if (context != null) {
|
||||
Glide.with(context)
|
||||
.asDrawable()
|
||||
.skipMemoryCache(true)
|
||||
.apply(options)
|
||||
.diskCacheStrategy(DiskCacheStrategy.ALL)
|
||||
.load(previewUrl400)
|
||||
.listener(new RequestListener<Drawable>() {
|
||||
@Override
|
||||
public boolean onLoadFailed(@Nullable GlideException e, @Nullable Object model, @NonNull Target<Drawable> target, boolean isFirstResource) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onResourceReady(@NonNull Drawable resource, @NonNull Object model, Target<Drawable> target, @NonNull DataSource dataSource, boolean isFirstResource) {
|
||||
return false;
|
||||
}
|
||||
})
|
||||
.placeholder(R.mipmap.im_placeholder)
|
||||
.transform(multiTransformation)
|
||||
.into(imageView);
|
||||
}
|
||||
|
||||
|
||||
item.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
if (onClick != null) {
|
||||
onClick.onItemClickAction(info);
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getItemCount() {
|
||||
return dataBeanInfo.size();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onViewRecycled(@NonNull MyViewHolder holder) {
|
||||
super.onViewRecycled(holder);
|
||||
// Context context = weakReference.get();
|
||||
// if (context != null) {
|
||||
// Glide.with(context).clear(holder.getImageView());
|
||||
// Log.d(MyWallpaper.TAG, "----------onViewRecycled");
|
||||
// }
|
||||
|
||||
}
|
||||
|
||||
|
||||
private static DiffUtil.ItemCallback<DataBean> diff = new DiffUtil.ItemCallback<DataBean>() {
|
||||
|
||||
|
||||
@Override
|
||||
public boolean areItemsTheSame(@NonNull DataBean oldItem, @NonNull DataBean newItem) {
|
||||
return oldItem.getImId().equals(newItem.getImId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean areContentsTheSame(@NonNull DataBean oldItem, @NonNull DataBean newItem) {
|
||||
return oldItem.getImId().equals(newItem.getImId());
|
||||
}
|
||||
};
|
||||
|
||||
private static class MyCallback extends DiffUtil.Callback {
|
||||
private List<DataBean> mOldList;
|
||||
private List<DataBean> mNewList;
|
||||
|
||||
public MyCallback(List<DataBean> oldList, List<DataBean> newList) {
|
||||
mOldList = oldList;
|
||||
mNewList = newList;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getOldListSize() {
|
||||
return mOldList.size();
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getNewListSize() {
|
||||
return mNewList.size();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean areItemsTheSame(int oldItemPosition, int newItemPosition) {
|
||||
return mOldList.get(oldItemPosition).getImId().equals(mNewList.get(newItemPosition).getImId());
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean areContentsTheSame(int oldItemPosition, int newItemPosition) {
|
||||
return mOldList.get(oldItemPosition).getImId().equals(mNewList.get(newItemPosition).getImId());
|
||||
}
|
||||
}
|
||||
|
||||
static class MyViewHolder extends RecyclerView.ViewHolder {
|
||||
|
||||
private ImageView imageView;
|
||||
private RelativeLayout layout;
|
||||
|
||||
private View space;
|
||||
|
||||
public MyViewHolder(@NonNull View itemView) {
|
||||
super(itemView);
|
||||
imageView = itemView.findViewById(R.id.wallpaper);
|
||||
layout = itemView.findViewById(R.id.layout);
|
||||
space = itemView.findViewById(R.id.view_space);
|
||||
}
|
||||
|
||||
// public ImageView getImFavorite() {
|
||||
// return imFavorite;
|
||||
// }
|
||||
|
||||
|
||||
public View getSpace() {
|
||||
return space;
|
||||
}
|
||||
|
||||
public RelativeLayout getLayout() {
|
||||
return layout;
|
||||
}
|
||||
|
||||
public ImageView getImageView() {
|
||||
return imageView;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
142
app/src/main/java/com/phone/wall/paper/adapter/FavoriteAda.java
Normal file
142
app/src/main/java/com/phone/wall/paper/adapter/FavoriteAda.java
Normal file
@ -0,0 +1,142 @@
|
||||
package com.phone.wall.paper.adapter;
|
||||
|
||||
import android.content.Context;
|
||||
import android.graphics.Bitmap;
|
||||
import android.util.Log;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.RelativeLayout;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.bumptech.glide.Glide;
|
||||
import com.bumptech.glide.load.MultiTransformation;
|
||||
import com.bumptech.glide.load.resource.bitmap.CenterCrop;
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
import com.phone.wall.paper.R;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.tools.RoomManager;
|
||||
import com.phone.wall.paper.listener.OnClick;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import jp.wasabeef.glide.transformations.RoundedCornersTransformation;
|
||||
|
||||
public class FavoriteAda extends RecyclerView.Adapter<FavoriteAda.LikeVh> {
|
||||
|
||||
|
||||
private List<DataBean> dataBeanInfo = new ArrayList<>();
|
||||
private Context myContext;
|
||||
private OnClick onClick;
|
||||
|
||||
public void setInfoWallpaperListener(OnClick onClick) {
|
||||
this.onClick = onClick;
|
||||
}
|
||||
|
||||
public FavoriteAda(Context myCon) {
|
||||
myContext = myCon;
|
||||
}
|
||||
|
||||
public void setDataInfo(List<DataBean> dataBeanInfo) {
|
||||
this.dataBeanInfo = dataBeanInfo;
|
||||
notifyDataSetChanged();
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public LikeVh onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
|
||||
View itemView = LayoutInflater.from(myContext).inflate(R.layout.ada_favorite, parent, false);
|
||||
return new LikeVh(itemView);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBindViewHolder(@NonNull LikeVh holder, int position) {
|
||||
DataBean info = dataBeanInfo.get(position);
|
||||
ImageView imageView = holder.getImageView();
|
||||
ImageView imFavorite = holder.getImFavorite();
|
||||
String previewUrl400 = info.getPreviewUrl400();
|
||||
String imId = info.getImId();
|
||||
View space = holder.getSpace();
|
||||
|
||||
int adapterPosition = holder.getAdapterPosition();
|
||||
if (adapterPosition == dataBeanInfo.size() - 1) {
|
||||
space.setVisibility(View.VISIBLE);
|
||||
} else {
|
||||
space.setVisibility(View.GONE);
|
||||
}
|
||||
|
||||
MultiTransformation<Bitmap> multiTransformation = new MultiTransformation<>(
|
||||
new CenterCrop(),
|
||||
new RoundedCornersTransformation(Utils.dp2Px(12), 0) // 圆角效果
|
||||
);
|
||||
Glide.with(myContext)
|
||||
.load(previewUrl400)
|
||||
.placeholder(R.mipmap.im_placeholder)
|
||||
.transform(multiTransformation)
|
||||
.into(imageView);
|
||||
|
||||
imFavorite.setSelected(true);
|
||||
imFavorite.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
imFavorite.setSelected(false);
|
||||
info.setLike(false);
|
||||
RoomManager.updateLike(info);
|
||||
int adapterPosition = holder.getAdapterPosition();
|
||||
notifyItemRemoved(adapterPosition);
|
||||
Log.d(WallpaperApp.TAG,"----------notifyItemRemoved-adapterPosition="+adapterPosition);
|
||||
}
|
||||
});
|
||||
holder.getLayout().setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
if (onClick != null) {
|
||||
onClick.onItemClickAction(info);
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getItemCount() {
|
||||
return dataBeanInfo.size();
|
||||
}
|
||||
|
||||
public class LikeVh extends RecyclerView.ViewHolder{
|
||||
|
||||
private ImageView imageView;
|
||||
private RelativeLayout layout;
|
||||
private ImageView imFavorite;
|
||||
private View space;
|
||||
public LikeVh(@NonNull View itemView) {
|
||||
super(itemView);
|
||||
imageView = itemView.findViewById(R.id.wallpaper);
|
||||
layout = itemView.findViewById(R.id.layout);
|
||||
imFavorite = itemView.findViewById(R.id.image_favorite);
|
||||
space = itemView.findViewById(R.id.view_space);
|
||||
}
|
||||
|
||||
public View getSpace() {
|
||||
return space;
|
||||
}
|
||||
|
||||
public ImageView getImFavorite() {
|
||||
return imFavorite;
|
||||
}
|
||||
|
||||
public RelativeLayout getLayout() {
|
||||
return layout;
|
||||
}
|
||||
|
||||
public ImageView getImageView() {
|
||||
return imageView;
|
||||
}
|
||||
}
|
||||
}
|
||||
129
app/src/main/java/com/phone/wall/paper/adapter/MainAda.java
Normal file
129
app/src/main/java/com/phone/wall/paper/adapter/MainAda.java
Normal file
@ -0,0 +1,129 @@
|
||||
package com.phone.wall.paper.adapter;
|
||||
|
||||
import android.content.Context;
|
||||
import android.graphics.Bitmap;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.util.Log;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
import com.bumptech.glide.Glide;
|
||||
import com.bumptech.glide.load.DataSource;
|
||||
import com.bumptech.glide.load.MultiTransformation;
|
||||
import com.bumptech.glide.load.engine.DiskCacheStrategy;
|
||||
import com.bumptech.glide.load.engine.GlideException;
|
||||
import com.bumptech.glide.load.resource.bitmap.CenterCrop;
|
||||
import com.bumptech.glide.request.RequestListener;
|
||||
import com.bumptech.glide.request.target.Target;
|
||||
import com.phone.wall.paper.R;
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.databinding.AdaMainBinding;
|
||||
import com.phone.wall.paper.listener.OnClick;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
import com.phone.wall.paper.tools.RoomManager;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Random;
|
||||
|
||||
import jp.wasabeef.glide.transformations.RoundedCornersTransformation;
|
||||
|
||||
public class MainAda extends RecyclerView.Adapter<MainAda.HomeParentHolder> {
|
||||
private List<String> data = new ArrayList<>();
|
||||
private Context mContext;
|
||||
private OnClick listener;
|
||||
int max = 9;
|
||||
int min = 0;
|
||||
int index = 0;
|
||||
private MultiTransformation<Bitmap> multiTransformation = new MultiTransformation<>(
|
||||
new CenterCrop(),
|
||||
new RoundedCornersTransformation(Utils.dp2Px(12), 0) // 圆角效果
|
||||
);
|
||||
|
||||
public void setData(List<String> data) {
|
||||
this.data = data;
|
||||
Random random = new Random();
|
||||
index = random.nextInt(max - min + 1) + min;
|
||||
Log.d("---------","-------index="+index);
|
||||
notifyDataSetChanged();
|
||||
}
|
||||
|
||||
public void setInfoWallpaperListener(OnClick onClick) {
|
||||
this.listener = onClick;
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public HomeParentHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
|
||||
mContext = parent.getContext();
|
||||
AdaMainBinding inflate = AdaMainBinding.inflate(LayoutInflater.from(mContext), parent, false);
|
||||
return new HomeParentHolder(inflate);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBindViewHolder(@NonNull HomeParentHolder holder, int position) {
|
||||
String name = data.get(position);
|
||||
List<DataBean> dataBean1 = RoomManager.queryHome(name);
|
||||
String previewUrl400 = dataBean1.get(index).getPreviewUrl1080();
|
||||
holder.itemBing.tvClassName.setText(name);
|
||||
|
||||
int adapterPosition = holder.getAdapterPosition();
|
||||
if(adapterPosition == data.size()-1){
|
||||
holder.itemBing.viewSpace.setVisibility(View.VISIBLE);
|
||||
}else {
|
||||
holder.itemBing.viewSpace.setVisibility(View.GONE);
|
||||
}
|
||||
|
||||
Glide.with(mContext)
|
||||
.asDrawable()
|
||||
.skipMemoryCache(true)
|
||||
.diskCacheStrategy(DiskCacheStrategy.ALL)
|
||||
.load(previewUrl400)
|
||||
.listener(new RequestListener<Drawable>() {
|
||||
@Override
|
||||
public boolean onLoadFailed(@Nullable GlideException e, @Nullable Object model, @NonNull Target<Drawable> target, boolean isFirstResource) {
|
||||
Log.d(WallpaperApp.TAG, "------------e="+e.getMessage()+"---previewUrl400="+previewUrl400);
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onResourceReady(@NonNull Drawable resource, @NonNull Object model, Target<Drawable> target, @NonNull DataSource dataSource, boolean isFirstResource) {
|
||||
return false;
|
||||
}
|
||||
})
|
||||
.placeholder(R.mipmap.im_placeholder)
|
||||
.into(holder.itemBing.preview);
|
||||
|
||||
|
||||
holder.itemBing.preview.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
listener.onClickMore(name);
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Override
|
||||
public int getItemCount() {
|
||||
return data.size();
|
||||
}
|
||||
|
||||
static class HomeParentHolder extends RecyclerView.ViewHolder {
|
||||
|
||||
private AdaMainBinding itemBing;
|
||||
|
||||
public HomeParentHolder(@NonNull AdaMainBinding itemView) {
|
||||
super(itemView.getRoot());
|
||||
itemBing = itemView;
|
||||
}
|
||||
}
|
||||
}
|
||||
159
app/src/main/java/com/phone/wall/paper/data/DataBean.java
Normal file
159
app/src/main/java/com/phone/wall/paper/data/DataBean.java
Normal file
@ -0,0 +1,159 @@
|
||||
package com.phone.wall.paper.data;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
|
||||
import java.io.Serializable;
|
||||
|
||||
import io.objectbox.annotation.Entity;
|
||||
import io.objectbox.annotation.Id;
|
||||
|
||||
|
||||
@Entity
|
||||
public class DataBean implements Serializable {
|
||||
|
||||
@Id
|
||||
private long id;
|
||||
|
||||
private String categoryName;
|
||||
|
||||
|
||||
private String imId;
|
||||
|
||||
private String description;
|
||||
|
||||
private String fullUrl;
|
||||
|
||||
private String previewUrl1080;
|
||||
private String previewUrl400;
|
||||
private String previewUrl200;
|
||||
|
||||
private String authorName;
|
||||
|
||||
private String authorHeader;
|
||||
|
||||
private String authorHtml;
|
||||
|
||||
private boolean isLike;
|
||||
|
||||
private boolean isDownload;
|
||||
|
||||
|
||||
public boolean isLike() {
|
||||
return isLike;
|
||||
}
|
||||
|
||||
public void setLike(boolean like) {
|
||||
isLike = like;
|
||||
}
|
||||
|
||||
public boolean isDownload() {
|
||||
return isDownload;
|
||||
}
|
||||
|
||||
public void setDownload(boolean download) {
|
||||
isDownload = download;
|
||||
}
|
||||
|
||||
public long getId() {
|
||||
return id;
|
||||
}
|
||||
|
||||
public void setId(long id) {
|
||||
this.id = id;
|
||||
}
|
||||
|
||||
|
||||
|
||||
public String getImId() {
|
||||
return imId;
|
||||
}
|
||||
|
||||
public void setImId(String imId) {
|
||||
this.imId = imId;
|
||||
}
|
||||
|
||||
|
||||
public String getCategoryName() {
|
||||
return categoryName;
|
||||
}
|
||||
|
||||
public void setCategoryName(String categoryName) {
|
||||
this.categoryName = categoryName;
|
||||
}
|
||||
|
||||
public String getDescription() {
|
||||
return description;
|
||||
}
|
||||
|
||||
public void setDescription(String description) {
|
||||
this.description = description;
|
||||
}
|
||||
|
||||
public String getFullUrl() {
|
||||
return fullUrl;
|
||||
}
|
||||
|
||||
public void setFullUrl(String fullUrl) {
|
||||
this.fullUrl = fullUrl;
|
||||
}
|
||||
|
||||
public String getPreviewUrl1080() {
|
||||
return previewUrl1080;
|
||||
}
|
||||
|
||||
public void setPreviewUrl1080(String previewUrl1080) {
|
||||
this.previewUrl1080 = previewUrl1080;
|
||||
}
|
||||
|
||||
public String getPreviewUrl400() {
|
||||
return previewUrl400;
|
||||
}
|
||||
|
||||
public void setPreviewUrl400(String previewUrl400) {
|
||||
this.previewUrl400 = previewUrl400;
|
||||
}
|
||||
|
||||
public String getPreviewUrl200() {
|
||||
return previewUrl200;
|
||||
}
|
||||
|
||||
public void setPreviewUrl200(String previewUrl200) {
|
||||
this.previewUrl200 = previewUrl200;
|
||||
}
|
||||
|
||||
public String getAuthorName() {
|
||||
return authorName;
|
||||
}
|
||||
|
||||
public void setAuthorName(String authorName) {
|
||||
this.authorName = authorName;
|
||||
}
|
||||
|
||||
public String getAuthorHeader() {
|
||||
return authorHeader;
|
||||
}
|
||||
|
||||
public void setAuthorHeader(String authorHeader) {
|
||||
this.authorHeader = authorHeader;
|
||||
}
|
||||
|
||||
public String getAuthorHtml() {
|
||||
return authorHtml;
|
||||
}
|
||||
|
||||
public void setAuthorHtml(String authorHtml) {
|
||||
this.authorHtml = authorHtml;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(@Nullable Object obj) {
|
||||
DataBean obj1 = (DataBean) obj;
|
||||
if (obj1 != null) {
|
||||
if (obj1.getImId().equals(imId)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
}
|
||||
10
app/src/main/java/com/phone/wall/paper/listener/OnClick.java
Normal file
10
app/src/main/java/com/phone/wall/paper/listener/OnClick.java
Normal file
@ -0,0 +1,10 @@
|
||||
package com.phone.wall.paper.listener;
|
||||
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
|
||||
public interface OnClick {
|
||||
|
||||
void onItemClickAction(DataBean info);
|
||||
|
||||
default void onClickMore(String name){}
|
||||
}
|
||||
@ -0,0 +1,9 @@
|
||||
package com.phone.wall.paper.listener;
|
||||
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public interface OnLikeList {
|
||||
void onLikeList(List<DataBean> dataBeanList);
|
||||
}
|
||||
@ -0,0 +1,6 @@
|
||||
package com.phone.wall.paper.listener;
|
||||
|
||||
public interface OnType {
|
||||
|
||||
void onSelectType(int type);
|
||||
}
|
||||
@ -0,0 +1,8 @@
|
||||
package com.phone.wall.paper.listener;
|
||||
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
|
||||
public interface OnUpdateFavorite {
|
||||
void onAdd(DataBean dataBean);
|
||||
void onRemove(DataBean dataBean);
|
||||
}
|
||||
34
app/src/main/java/com/phone/wall/paper/tools/CustTv.java
Normal file
34
app/src/main/java/com/phone/wall/paper/tools/CustTv.java
Normal file
@ -0,0 +1,34 @@
|
||||
package com.phone.wall.paper.tools;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.res.TypedArray;
|
||||
import android.util.AttributeSet;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
import com.phone.wall.paper.R;
|
||||
|
||||
|
||||
public class CustTv extends androidx.appcompat.widget.AppCompatTextView {
|
||||
|
||||
|
||||
public CustTv(Context context, @Nullable AttributeSet attrs) {
|
||||
super(context, attrs);
|
||||
initAttrs(context,attrs);
|
||||
}
|
||||
|
||||
|
||||
private void initAttrs(Context context, AttributeSet attrs){
|
||||
TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.CustomeTv);
|
||||
boolean aBoolean = typedArray.getBoolean(R.styleable.CustomeTv_apply_font,false);
|
||||
if(aBoolean){
|
||||
setTypeface(WallpaperApp.defaultFont);
|
||||
}
|
||||
|
||||
typedArray.recycle();
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
231
app/src/main/java/com/phone/wall/paper/tools/JsonData.kt
Normal file
231
app/src/main/java/com/phone/wall/paper/tools/JsonData.kt
Normal file
@ -0,0 +1,231 @@
|
||||
package com.phone.wall.paper.tools
|
||||
|
||||
import android.Manifest
|
||||
import android.app.Activity
|
||||
import android.content.ContentValues
|
||||
import android.content.Context
|
||||
import android.content.pm.PackageManager
|
||||
import android.net.Uri
|
||||
import android.os.Build
|
||||
import android.provider.MediaStore
|
||||
import android.util.Log
|
||||
import androidx.core.app.ActivityCompat
|
||||
import com.phone.wall.paper.WallpaperApp
|
||||
import com.phone.wall.paper.data.DataBean
|
||||
import okhttp3.Call
|
||||
import okhttp3.Callback
|
||||
import okhttp3.OkHttpClient
|
||||
import okhttp3.Request
|
||||
import okhttp3.Response
|
||||
import org.json.JSONArray
|
||||
import org.json.JSONObject
|
||||
import java.io.ByteArrayOutputStream
|
||||
import java.io.File
|
||||
import java.io.FileInputStream
|
||||
import java.io.FileOutputStream
|
||||
import java.io.IOException
|
||||
import java.io.InputStream
|
||||
|
||||
object JsonData {
|
||||
|
||||
|
||||
fun getData(jsonStr: String, category: String): MutableList<DataBean> {
|
||||
val jsonArray = JSONArray(jsonStr)
|
||||
var data = mutableListOf<DataBean>()
|
||||
|
||||
var get: JSONObject
|
||||
var text_description: String
|
||||
|
||||
var links: JSONObject
|
||||
var download: String
|
||||
|
||||
var urls: JSONObject
|
||||
var regular: String
|
||||
var small: String
|
||||
var thumb: String
|
||||
|
||||
|
||||
var users: JSONObject
|
||||
var name: String
|
||||
var header_large: String
|
||||
var user_html: String
|
||||
val host = "https://unsplash.com/photos/"
|
||||
|
||||
var bean: DataBean
|
||||
var indexOf: Int
|
||||
var substring: String
|
||||
|
||||
|
||||
for (i in 0 until 300) {
|
||||
get = jsonArray.getJSONObject(i)
|
||||
text_description = get.getString("alt_description")
|
||||
links = get.getJSONObject("links")
|
||||
download = links.getString("download")
|
||||
// val downloadLocation = links.getString("download_location")
|
||||
// val html = links.getString("html")
|
||||
|
||||
|
||||
urls = get.getJSONObject("urls")
|
||||
// val full = urls.getString("full")
|
||||
// val raw = urls.getString("raw")
|
||||
regular = urls.getString("regular")
|
||||
small = urls.getString("small")
|
||||
thumb = urls.getString("thumb")
|
||||
|
||||
|
||||
users = get.getJSONObject("user")
|
||||
// val portfolio_url = users.getString("portfolio_url")
|
||||
name = users.getString("name")
|
||||
header_large = users.getString("header_large")
|
||||
// val header_medium = users.getString("header_medium")
|
||||
// val header_small = users.getString("header_small")
|
||||
user_html = users.getString("authorHtml")
|
||||
|
||||
|
||||
indexOf = download.indexOf("/download")
|
||||
substring = download.substring(host.length, indexOf)
|
||||
// Log.d(MyApp.TAG, "i=$i----------substring=$substring")
|
||||
|
||||
bean = DataBean().apply {
|
||||
imId = substring
|
||||
categoryName = category
|
||||
description = text_description
|
||||
fullUrl = download
|
||||
previewUrl1080 = regular
|
||||
previewUrl400 = small
|
||||
previewUrl200 = thumb
|
||||
authorName = name
|
||||
authorHeader = header_large
|
||||
authorHtml = user_html
|
||||
}
|
||||
|
||||
|
||||
RoomManager.addData(bean)
|
||||
data.add(bean)
|
||||
}
|
||||
|
||||
|
||||
return data
|
||||
}
|
||||
|
||||
|
||||
fun downloadFile(
|
||||
url: String,
|
||||
savePath: String,
|
||||
result: (Boolean, input: InputStream?) -> Unit
|
||||
): Call {
|
||||
var client = OkHttpClient()
|
||||
var request = Request.Builder().url(url).build()
|
||||
var call = client.newCall(request)
|
||||
call.enqueue(object : Callback {
|
||||
override fun onFailure(call: Call, e: IOException) {
|
||||
result.invoke(false, null)
|
||||
}
|
||||
|
||||
override fun onResponse(call: Call, response: Response) {
|
||||
response.body?.run {
|
||||
val byteStream = byteStream()
|
||||
val writeFile = writeFile(byteStream, savePath)
|
||||
result.invoke(writeFile, byteStream)
|
||||
} ?: run {
|
||||
result.invoke(false, null)
|
||||
}
|
||||
}
|
||||
})
|
||||
return call
|
||||
}
|
||||
|
||||
fun writeFile(input: InputStream, filePath: String): Boolean {
|
||||
try {
|
||||
val byte = ByteArray(4096)
|
||||
val output = ByteArrayOutputStream()
|
||||
var l: Int
|
||||
while (input.read(byte).also { l = it } != -1) {
|
||||
output.write(byte, 0, l)
|
||||
}
|
||||
val fileDe = File(filePath)
|
||||
if (!fileDe.exists()) {
|
||||
fileDe.createNewFile()
|
||||
}
|
||||
val fileOutputStream = FileOutputStream(filePath)
|
||||
fileOutputStream.write(output.toByteArray())
|
||||
output.close()
|
||||
fileOutputStream.close()
|
||||
return true
|
||||
} catch (ex: Exception) {
|
||||
Log.d("-----------", "---------ex=" + ex.message)
|
||||
return false
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
fun saveToGallery(context: Context, photoFile: File): Uri? {
|
||||
val displayName = "${System.currentTimeMillis()}.jpg"
|
||||
val contentValues = ContentValues().apply {
|
||||
put(MediaStore.Images.Media.DISPLAY_NAME, displayName)
|
||||
put(MediaStore.Images.Media.MIME_TYPE, "image/jpeg")
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
|
||||
put(MediaStore.Images.Media.IS_PENDING, 1)
|
||||
}
|
||||
}
|
||||
|
||||
val contentResolver = context.contentResolver
|
||||
val collectionUri = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
|
||||
MediaStore.Images.Media.getContentUri(MediaStore.VOLUME_EXTERNAL_PRIMARY)
|
||||
} else {
|
||||
MediaStore.Images.Media.EXTERNAL_CONTENT_URI
|
||||
}
|
||||
|
||||
val imageUri = contentResolver.insert(collectionUri, contentValues)
|
||||
|
||||
imageUri?.let { uri ->
|
||||
try {
|
||||
contentResolver.openOutputStream(uri)?.use { outputStream ->
|
||||
val inputStream = FileInputStream(photoFile)
|
||||
inputStream.copyTo(outputStream)
|
||||
inputStream.close()
|
||||
outputStream.close()
|
||||
}
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
|
||||
contentValues.clear()
|
||||
contentValues.put(MediaStore.Images.Media.IS_PENDING, 0)
|
||||
contentResolver.update(uri, contentValues, null, null)
|
||||
} else {
|
||||
|
||||
}
|
||||
return uri
|
||||
} catch (e: IOException) {
|
||||
Log.d(WallpaperApp.TAG, "-----------------e=${e.printStackTrace()}")
|
||||
return null
|
||||
}
|
||||
} ?: run {
|
||||
Log.d(WallpaperApp.TAG, "----------------false")
|
||||
return null
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
fun requestPermission(context: Activity, requestCode: Int): Boolean {
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
|
||||
return true
|
||||
}
|
||||
return if (context.checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
|
||||
ActivityCompat.requestPermissions(
|
||||
context,
|
||||
arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE),
|
||||
requestCode
|
||||
)
|
||||
false
|
||||
} else {
|
||||
true
|
||||
}
|
||||
}
|
||||
|
||||
fun getSaveFilePath(context: Context, imId: String): String {
|
||||
return "${context.cacheDir}/${imId}.jpg"
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
56
app/src/main/java/com/phone/wall/paper/tools/ListSpace.java
Normal file
56
app/src/main/java/com/phone/wall/paper/tools/ListSpace.java
Normal file
@ -0,0 +1,56 @@
|
||||
package com.phone.wall.paper.tools;
|
||||
|
||||
import android.graphics.Rect;
|
||||
import android.view.View;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.recyclerview.widget.GridLayoutManager;
|
||||
import androidx.recyclerview.widget.RecyclerView;
|
||||
|
||||
public class ListSpace extends RecyclerView.ItemDecoration {
|
||||
private int ex_space = 0;
|
||||
private int v_space = 0;
|
||||
private int h_space = 0;
|
||||
|
||||
@Override
|
||||
public void getItemOffsets(@NonNull Rect outRect, @NonNull View view, @NonNull RecyclerView parent, @NonNull RecyclerView.State state) {
|
||||
|
||||
int position = parent.getChildAdapterPosition(view);
|
||||
int spanSize = 1;
|
||||
int spanIndex = 0;
|
||||
int spanCount = 1;
|
||||
|
||||
RecyclerView.LayoutManager layoutManager = parent.getLayoutManager();
|
||||
|
||||
if (layoutManager instanceof GridLayoutManager) {
|
||||
GridLayoutManager layoutManager1 = (GridLayoutManager) layoutManager;
|
||||
GridLayoutManager.LayoutParams layoutParams = (GridLayoutManager.LayoutParams) view.getLayoutParams();
|
||||
spanCount = layoutManager1.getSpanCount();
|
||||
spanSize = layoutManager1.getSpanSizeLookup().getSpanSize(position);
|
||||
spanIndex = layoutParams.getSpanIndex();
|
||||
|
||||
}
|
||||
|
||||
|
||||
if (spanSize == spanCount) {
|
||||
outRect.left = v_space + ex_space;
|
||||
outRect.right = v_space + ex_space;
|
||||
outRect.bottom = h_space;
|
||||
} else {
|
||||
int itemAllSpacing = (v_space * (spanCount + 1) + ex_space * 2) / spanCount;
|
||||
int left = v_space * (spanIndex + 1) - itemAllSpacing * spanIndex + ex_space;
|
||||
int right = itemAllSpacing - left;
|
||||
outRect.left = left;
|
||||
outRect.right = right;
|
||||
outRect.bottom = h_space;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public ListSpace(int v_space, int h_space, int ex_space) {
|
||||
this.ex_space = ex_space;
|
||||
this.h_space = h_space;
|
||||
this.v_space = v_space;
|
||||
|
||||
}
|
||||
}
|
||||
154
app/src/main/java/com/phone/wall/paper/tools/RoomManager.java
Normal file
154
app/src/main/java/com/phone/wall/paper/tools/RoomManager.java
Normal file
@ -0,0 +1,154 @@
|
||||
package com.phone.wall.paper.tools;
|
||||
|
||||
import android.content.Context;
|
||||
import android.util.Log;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.data.DataBean_;
|
||||
import com.phone.wall.paper.data.MyObjectBox;
|
||||
import com.phone.wall.paper.listener.OnLikeList;
|
||||
import com.phone.wall.paper.listener.OnUpdateFavorite;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import io.objectbox.Box;
|
||||
import io.objectbox.BoxStore;
|
||||
import io.objectbox.android.AndroidScheduler;
|
||||
import io.objectbox.query.Query;
|
||||
import io.objectbox.query.QueryBuilder;
|
||||
import io.objectbox.reactive.DataObserver;
|
||||
import io.objectbox.reactive.DataSubscription;
|
||||
import io.objectbox.reactive.DataSubscriptionList;
|
||||
|
||||
public class RoomManager {
|
||||
|
||||
private static BoxStore boxStore;
|
||||
|
||||
private static Box<DataBean> LikeBox;
|
||||
private static List<OnUpdateFavorite> list = new ArrayList<>();
|
||||
public static void init(Context context) {
|
||||
boxStore = MyObjectBox.builder().androidContext(context).build();
|
||||
}
|
||||
|
||||
public static Box<DataBean> getObjectBoxLike() {
|
||||
if (LikeBox == null) {
|
||||
LikeBox = boxStore.boxFor(DataBean.class);
|
||||
}
|
||||
|
||||
return LikeBox;
|
||||
}
|
||||
|
||||
public static void addData(DataBean dataBean) {
|
||||
Box<DataBean> objectBoxLike = getObjectBoxLike();
|
||||
String imId = dataBean.getImId();
|
||||
DataBean first = objectBoxLike.query()
|
||||
.equal(DataBean_.imId, imId, QueryBuilder.StringOrder.CASE_SENSITIVE)
|
||||
.build()
|
||||
.findFirst();
|
||||
if (first == null) {
|
||||
// Log.d(WallpaperApp.TAG, "-----------addData " + imId);
|
||||
objectBoxLike.put(dataBean);
|
||||
}else {
|
||||
// Log.d(WallpaperApp.TAG, "-----------忽略添加 ");
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public static DataSubscription setLikeDataListener(OnLikeList listener) {
|
||||
Query<DataBean> build = getObjectBoxLike().query()
|
||||
.equal(DataBean_.isLike, true)
|
||||
.build();
|
||||
return build.subscribe(new DataSubscriptionList())
|
||||
.on(AndroidScheduler.mainThread())
|
||||
.observer(new DataObserver<List<DataBean>>() {
|
||||
@Override
|
||||
public void onData(@NonNull List<DataBean> data) {
|
||||
Log.d(WallpaperApp.TAG, "------data=" + data.size());
|
||||
listener.onLikeList(data);
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
|
||||
public static void updateLike(DataBean boxLike) {
|
||||
Box<DataBean> objectBoxLike = getObjectBoxLike();
|
||||
String imId = boxLike.getImId();
|
||||
|
||||
objectBoxLike.put(boxLike);
|
||||
for (OnUpdateFavorite listener : list) {
|
||||
listener.onAdd(boxLike);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
public static void insertOrUpdateDownload(DataBean boxLike) {
|
||||
Box<DataBean> objectBoxLike = getObjectBoxLike();
|
||||
String imId = boxLike.getImId();
|
||||
DataBean first = objectBoxLike.query()
|
||||
.equal(DataBean_.imId, imId, QueryBuilder.StringOrder.CASE_SENSITIVE)
|
||||
.build()
|
||||
.findFirst();
|
||||
if (first == null) {
|
||||
Log.d(WallpaperApp.TAG, "-----------添加11 Download=" + imId);
|
||||
boxLike.setDownload(true);
|
||||
objectBoxLike.put(boxLike);
|
||||
} else {
|
||||
first.setDownload(true);
|
||||
objectBoxLike.put(first);
|
||||
Log.d(WallpaperApp.TAG, "-----------已经存在添加22 Download=" + imId);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
public static List<DataBean> search(String name) {
|
||||
Box<DataBean> objectBoxLike = getObjectBoxLike();
|
||||
List<DataBean> data = objectBoxLike.query()
|
||||
.contains(DataBean_.description, name, QueryBuilder.StringOrder.CASE_SENSITIVE)
|
||||
.build()
|
||||
.find();
|
||||
return data;
|
||||
}
|
||||
public static List<DataBean> queryHome(String name) {
|
||||
Box<DataBean> objectBoxLike = getObjectBoxLike();
|
||||
List<DataBean> data = objectBoxLike.query()
|
||||
.equal(DataBean_.categoryName, name, QueryBuilder.StringOrder.CASE_SENSITIVE)
|
||||
.build()
|
||||
.find(15, 10);
|
||||
return data;
|
||||
|
||||
}
|
||||
public static List<DataBean> queryCategoryAll(String name) {
|
||||
Box<DataBean> objectBoxLike = getObjectBoxLike();
|
||||
List<DataBean> data = objectBoxLike.query()
|
||||
.equal(DataBean_.categoryName, name, QueryBuilder.StringOrder.CASE_SENSITIVE)
|
||||
.build()
|
||||
.find(0, 200);
|
||||
return data;
|
||||
|
||||
}
|
||||
public static boolean queryIsLike(String imId) {
|
||||
Box<DataBean> objectBoxLike = getObjectBoxLike();
|
||||
DataBean first = objectBoxLike.query()
|
||||
.equal(DataBean_.imId, imId, QueryBuilder.StringOrder.CASE_SENSITIVE)
|
||||
.build()
|
||||
.findFirst();
|
||||
if (first != null && first.isLike()) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
144
app/src/main/java/com/phone/wall/paper/tools/Utils.java
Normal file
144
app/src/main/java/com/phone/wall/paper/tools/Utils.java
Normal file
@ -0,0 +1,144 @@
|
||||
package com.phone.wall.paper.tools;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.app.ActivityManager;
|
||||
import android.content.Context;
|
||||
import android.graphics.Bitmap;
|
||||
import android.graphics.Canvas;
|
||||
import android.graphics.drawable.BitmapDrawable;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.os.Debug;
|
||||
import android.util.DisplayMetrics;
|
||||
import android.util.Log;
|
||||
import android.view.View;
|
||||
import android.view.Window;
|
||||
import android.view.WindowManager;
|
||||
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.File;
|
||||
import java.io.FileOutputStream;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.io.InputStreamReader;
|
||||
import java.io.Reader;
|
||||
import java.io.StringWriter;
|
||||
import java.nio.charset.StandardCharsets;
|
||||
|
||||
public class Utils {
|
||||
public static final String key_info = "key_info";
|
||||
|
||||
public static final String key_index = "key_index";
|
||||
|
||||
public static String getCovertStr(InputStream stream) {
|
||||
String covertStr = "";
|
||||
try {
|
||||
StringWriter writer = new StringWriter();
|
||||
char[] buffer = new char[stream.available()];
|
||||
Reader reader = new BufferedReader(new InputStreamReader(stream, StandardCharsets.UTF_8));
|
||||
int a = 0;
|
||||
while ((a = reader.read(buffer)) != -1) {
|
||||
writer.write(buffer, 0, a);
|
||||
}
|
||||
covertStr = writer.toString();
|
||||
} catch (IOException e) {
|
||||
return covertStr;
|
||||
}
|
||||
return covertStr;
|
||||
}
|
||||
|
||||
public static int dp2Px(int dp) {
|
||||
float scale = WallpaperApp.mAppContext.getResources().getDisplayMetrics().density;
|
||||
return (int) (dp * scale + 0.5f);
|
||||
}
|
||||
|
||||
public static void initFull(Activity activity, boolean light) {
|
||||
Window window = activity.getWindow();
|
||||
View decorView = window.getDecorView();
|
||||
View rootView = decorView.getRootView();
|
||||
if (light) {
|
||||
|
||||
} else {
|
||||
|
||||
decorView.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
|
||||
}
|
||||
window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
private static Bitmap getBitmap(Drawable drawable) {
|
||||
if (drawable instanceof BitmapDrawable) {
|
||||
return ((BitmapDrawable) drawable).getBitmap();
|
||||
}
|
||||
|
||||
// 创建一个空白的 Bitmap
|
||||
Bitmap bitmap = Bitmap.createBitmap(
|
||||
drawable.getIntrinsicWidth(),
|
||||
drawable.getIntrinsicHeight(),
|
||||
Bitmap.Config.ARGB_8888);
|
||||
|
||||
// 在 Canvas 上绘制 Drawable
|
||||
Canvas canvas = new Canvas(bitmap);
|
||||
drawable.setBounds(0, 0, canvas.getWidth(), canvas.getHeight());
|
||||
drawable.draw(canvas);
|
||||
|
||||
return bitmap;
|
||||
}
|
||||
|
||||
|
||||
public static String saveDrawableToFile( Drawable drawable,String saveFilePath) {
|
||||
// 将 Drawable 转换为 Bitmap
|
||||
Bitmap bitmap = getBitmap(drawable);
|
||||
|
||||
|
||||
// 创建要保存的文件
|
||||
File file = new File(saveFilePath);
|
||||
FileOutputStream fos = null;
|
||||
|
||||
try {
|
||||
fos = new FileOutputStream(file);
|
||||
|
||||
// 将 Bitmap 写入文件 (使用 PNG 格式,可改为 JPEG)
|
||||
bitmap.compress(Bitmap.CompressFormat.PNG, 100, fos);
|
||||
fos.flush();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
} finally {
|
||||
if (fos != null) {
|
||||
try {
|
||||
fos.close();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return file.getAbsolutePath();
|
||||
}
|
||||
|
||||
public static void printUsedMemory(Context context) {
|
||||
ActivityManager activityManager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
|
||||
Debug.MemoryInfo[] memoryInfoArray = activityManager.getProcessMemoryInfo(new int[]{android.os.Process.myPid()});
|
||||
for (Debug.MemoryInfo memoryInfo : memoryInfoArray) {
|
||||
int totalPss = memoryInfo.getTotalPss();
|
||||
int totalPrivateDirty = memoryInfo.getTotalPrivateDirty();
|
||||
int totalSharedDirty = memoryInfo.getTotalSharedDirty();
|
||||
|
||||
Log.d("MemoryInfo", "Total PSS: " + totalPss + " KB");
|
||||
Log.d("MemoryInfo", "Total Private Dirty: " + totalPrivateDirty + " KB");
|
||||
Log.d("MemoryInfo", "Total Shared Dirty: " + totalSharedDirty + " KB");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public static int[] getScreenWidthHeight(Context context) {
|
||||
DisplayMetrics metrics = context.getResources().getDisplayMetrics();
|
||||
int width = metrics.widthPixels;
|
||||
int height = metrics.heightPixels;
|
||||
return new int[]{width, height};
|
||||
}
|
||||
}
|
||||
72
app/src/main/java/com/phone/wall/paper/view/AllList.java
Normal file
72
app/src/main/java/com/phone/wall/paper/view/AllList.java
Normal file
@ -0,0 +1,72 @@
|
||||
package com.phone.wall.paper.view;
|
||||
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.view.View;
|
||||
|
||||
import androidx.appcompat.app.AppCompatActivity;
|
||||
import androidx.recyclerview.widget.GridLayoutManager;
|
||||
|
||||
import com.ad.toponlibrary.AdManager;
|
||||
import com.ad.toponlibrary.onActionListener;
|
||||
import com.phone.wall.paper.adapter.AllAda;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.databinding.UiAllListBinding;
|
||||
import com.phone.wall.paper.listener.OnClick;
|
||||
import com.phone.wall.paper.tools.ListSpace;
|
||||
import com.phone.wall.paper.tools.RoomManager;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public class AllList extends AppCompatActivity implements OnClick {
|
||||
private UiAllListBinding vb;
|
||||
|
||||
private String categoryName;
|
||||
public static final String key_index = "index";
|
||||
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
vb = UiAllListBinding.inflate(getLayoutInflater());
|
||||
setContentView(vb.getRoot());
|
||||
Utils.initFull(this, false);
|
||||
categoryName = getIntent().getStringExtra(key_index);
|
||||
vb.name.setText(categoryName);
|
||||
initList();
|
||||
AdManager.loadAllAd();
|
||||
vb.imageviewBack.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
AdManager.showTopOn(AllList.this, new onActionListener() {
|
||||
@Override
|
||||
public void onAction() {
|
||||
finish();
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private void initList() {
|
||||
List<DataBean> data = RoomManager.queryCategoryAll(categoryName);
|
||||
ListSpace listSpace = new ListSpace(10, 10, 0);
|
||||
// StaggeredGridLayoutManager gridLayoutManager = new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL);
|
||||
GridLayoutManager gridLayoutManager = new GridLayoutManager(this, 2);
|
||||
vb.list.addItemDecoration(listSpace);
|
||||
vb.list.setLayoutManager(gridLayoutManager);
|
||||
int height = Utils.dp2Px(180);
|
||||
AllAda allAda = new AllAda(this, height);
|
||||
allAda.setDataInfo(data);
|
||||
allAda.setInfoWallpaperListener(this);
|
||||
vb.list.setAdapter(allAda);
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onItemClickAction(DataBean info) {
|
||||
Intent intent = new Intent(this, SetWall.class);
|
||||
intent.putExtra(Utils.key_info, info);
|
||||
startActivity(intent);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,99 @@
|
||||
package com.phone.wall.paper.view;
|
||||
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.util.Log;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
|
||||
import androidx.fragment.app.Fragment;
|
||||
import androidx.recyclerview.widget.GridLayoutManager;
|
||||
|
||||
import com.phone.wall.paper.R;
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
import com.phone.wall.paper.adapter.FavoriteAda;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.databinding.FragFavoriteBinding;
|
||||
import com.phone.wall.paper.listener.OnClick;
|
||||
import com.phone.wall.paper.listener.OnLikeList;
|
||||
import com.phone.wall.paper.tools.ListSpace;
|
||||
import com.phone.wall.paper.tools.RoomManager;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import io.objectbox.reactive.DataSubscription;
|
||||
|
||||
|
||||
public class FragFavorite extends Fragment implements OnClick {
|
||||
|
||||
private FragFavoriteBinding vb;
|
||||
private DataSubscription dataSubscription;
|
||||
|
||||
public FragFavorite() {
|
||||
|
||||
}
|
||||
|
||||
public static FragFavorite newInstance() {
|
||||
FragFavorite fragment = new FragFavorite();
|
||||
return fragment;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public View onCreateView(LayoutInflater inflater, ViewGroup container,
|
||||
Bundle savedInstanceState) {
|
||||
vb = FragFavoriteBinding.inflate(getLayoutInflater());
|
||||
vb.tvTitle.setText(getString(R.string.no_like_data));
|
||||
initList();
|
||||
return vb.getRoot();
|
||||
}
|
||||
|
||||
private void initList() {
|
||||
FavoriteAda favoriteAda = new FavoriteAda(requireContext());
|
||||
dataSubscription = RoomManager.setLikeDataListener(new OnLikeList() {
|
||||
@Override
|
||||
public void onLikeList(List<DataBean> dataBeanList) {
|
||||
Log.d(WallpaperApp.TAG, "------size = " + dataBeanList.size());
|
||||
if(dataBeanList.size()==0){
|
||||
vb.layoutNoData.setVisibility(View.VISIBLE);
|
||||
vb.listRecycler.setVisibility(View.GONE);
|
||||
}else {
|
||||
vb.layoutNoData.setVisibility(View.GONE);
|
||||
vb.listRecycler.setVisibility(View.VISIBLE);
|
||||
favoriteAda.setDataInfo(dataBeanList);
|
||||
}
|
||||
}
|
||||
});
|
||||
ListSpace listSpace = new ListSpace(10, 10, 15);
|
||||
GridLayoutManager gridLayoutManager = new GridLayoutManager(requireContext(), 2);
|
||||
vb.listRecycler.setLayoutManager(gridLayoutManager);
|
||||
vb.listRecycler.addItemDecoration(listSpace);
|
||||
favoriteAda.setInfoWallpaperListener(this);
|
||||
vb.listRecycler.setAdapter(favoriteAda);
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onItemClickAction(DataBean info) {
|
||||
Intent intent = new Intent(requireContext(), SetWall.class);
|
||||
intent.putExtra(Utils.key_info, info);
|
||||
startActivity(intent);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onDestroyView() {
|
||||
super.onDestroyView();
|
||||
if (dataSubscription != null) {
|
||||
dataSubscription.cancel();
|
||||
}
|
||||
Log.d(WallpaperApp.TAG,"------favoriteFragment-onDestroyView");
|
||||
}
|
||||
}
|
||||
82
app/src/main/java/com/phone/wall/paper/view/FragMain.java
Normal file
82
app/src/main/java/com/phone/wall/paper/view/FragMain.java
Normal file
@ -0,0 +1,82 @@
|
||||
package com.phone.wall.paper.view;
|
||||
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.util.Log;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
|
||||
import androidx.fragment.app.Fragment;
|
||||
import androidx.recyclerview.widget.LinearLayoutManager;
|
||||
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
import com.phone.wall.paper.adapter.MainAda;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.databinding.FragMainBinding;
|
||||
import com.phone.wall.paper.listener.OnClick;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
|
||||
public class FragMain extends Fragment implements OnClick {
|
||||
private FragMainBinding vb;
|
||||
public FragMain() {
|
||||
}
|
||||
public static FragMain newInstance(int type) {
|
||||
Bundle bundle = new Bundle();
|
||||
bundle.putInt(Utils.key_index, type);
|
||||
FragMain fragment = new FragMain();
|
||||
fragment.setArguments(bundle);
|
||||
return fragment;
|
||||
}
|
||||
@Override
|
||||
public View onCreateView(LayoutInflater inflater, ViewGroup container,
|
||||
Bundle savedInstanceState) {
|
||||
vb = FragMainBinding.inflate(getLayoutInflater());
|
||||
|
||||
initTabVp();
|
||||
return vb.getRoot();
|
||||
}
|
||||
|
||||
|
||||
|
||||
private void initTabVp() {
|
||||
|
||||
List<String> data = new ArrayList<>();
|
||||
while (data.size() < 8) {
|
||||
Log.d("---------","-------data="+data.size());
|
||||
data = WallpaperApp.getCategoryNames();
|
||||
}
|
||||
vb.loadingPb.setVisibility(View.GONE);
|
||||
initList(data);
|
||||
|
||||
}
|
||||
|
||||
|
||||
private void initList(List<String> data) {
|
||||
MainAda adHomeParent = new MainAda();
|
||||
adHomeParent.setData(data);
|
||||
adHomeParent.setInfoWallpaperListener(this);
|
||||
LinearLayoutManager linearLayoutManager = new LinearLayoutManager(requireContext());
|
||||
vb.classRecycler.setLayoutManager(linearLayoutManager);
|
||||
vb.classRecycler.setAdapter(adHomeParent);
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onItemClickAction(DataBean info) {
|
||||
Intent intent = new Intent(requireContext(), SetWall.class);
|
||||
intent.putExtra(Utils.key_info, info);
|
||||
startActivity(intent);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClickMore(String name) {
|
||||
Intent intent = new Intent(requireContext(), AllList.class);
|
||||
intent.putExtra(AllList.key_index, name);
|
||||
startActivity(intent);
|
||||
}
|
||||
}
|
||||
156
app/src/main/java/com/phone/wall/paper/view/FragSearch.java
Normal file
156
app/src/main/java/com/phone/wall/paper/view/FragSearch.java
Normal file
@ -0,0 +1,156 @@
|
||||
package com.phone.wall.paper.view;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.util.Log;
|
||||
import android.view.KeyEvent;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.view.inputmethod.EditorInfo;
|
||||
import android.view.inputmethod.InputMethodManager;
|
||||
import android.widget.TextView;
|
||||
import android.widget.Toast;
|
||||
|
||||
import androidx.fragment.app.Fragment;
|
||||
import androidx.recyclerview.widget.GridLayoutManager;
|
||||
|
||||
import com.ad.toponlibrary.AdManager;
|
||||
import com.ad.toponlibrary.onActionListener;
|
||||
import com.phone.wall.paper.R;
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
import com.phone.wall.paper.adapter.AllAda;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.databinding.FragSearchBinding;
|
||||
import com.phone.wall.paper.listener.OnClick;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
import com.phone.wall.paper.tools.RoomManager;
|
||||
import com.phone.wall.paper.tools.ListSpace;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
|
||||
public class FragSearch extends Fragment implements OnClick {
|
||||
|
||||
|
||||
|
||||
private AllAda adapterWallapper;
|
||||
|
||||
private FragSearchBinding vb;
|
||||
|
||||
|
||||
public FragSearch() {
|
||||
|
||||
}
|
||||
|
||||
public static FragSearch newInstance() {
|
||||
Bundle bundle = new Bundle();
|
||||
FragSearch fragment = new FragSearch();
|
||||
fragment.setArguments(bundle);
|
||||
return fragment;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public View onCreateView(LayoutInflater inflater, ViewGroup container,
|
||||
Bundle savedInstanceState) {
|
||||
vb = FragSearchBinding.inflate(getLayoutInflater());
|
||||
initList();
|
||||
return vb.getRoot();
|
||||
}
|
||||
|
||||
|
||||
private void initList() {
|
||||
int height = Utils.dp2Px(180);
|
||||
adapterWallapper = new AllAda(requireContext(),height);
|
||||
adapterWallapper.setInfoWallpaperListener(this);
|
||||
ListSpace recyclerListSpace = new ListSpace(10, 10, 15);
|
||||
GridLayoutManager gridLayoutManager = new GridLayoutManager(requireContext(), 2);
|
||||
vb.resultRecycler.setLayoutManager(gridLayoutManager);
|
||||
vb.resultRecycler.addItemDecoration(recyclerListSpace);
|
||||
vb.resultRecycler.setAdapter(adapterWallapper);
|
||||
|
||||
|
||||
vb.et.setOnEditorActionListener(new TextView.OnEditorActionListener() {
|
||||
@Override
|
||||
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
|
||||
if (actionId == EditorInfo.IME_ACTION_SEARCH) {
|
||||
startSearch();
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
});
|
||||
vb.btnSearch.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
startSearch();
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
private void closeKeyboard() {
|
||||
InputMethodManager imm = (InputMethodManager) requireContext().getSystemService(Context.INPUT_METHOD_SERVICE);
|
||||
imm.hideSoftInputFromWindow(vb.et.getWindowToken(), 0);
|
||||
}
|
||||
private void startSearch() {
|
||||
AdManager.showTopOn(requireActivity(), new onActionListener() {
|
||||
@Override
|
||||
public void onAction() {
|
||||
closeKeyboard();
|
||||
vb.searchPb.setVisibility(View.VISIBLE);
|
||||
String string = vb.et.getText().toString();
|
||||
if (!string.isEmpty()) {
|
||||
List<DataBean> search = RoomManager.search(string);
|
||||
if (search.size() > 0) {
|
||||
showEmpty(false);
|
||||
adapterWallapper.setDataInfo(search);
|
||||
|
||||
vb.searchPb.setVisibility(View.GONE);
|
||||
} else {
|
||||
vb.searchPb.setVisibility(View.GONE);
|
||||
showEmpty(true);
|
||||
}
|
||||
|
||||
Log.d(WallpaperApp.TAG, "--------------size=" + search.size());
|
||||
for (DataBean dataBean : search) {
|
||||
Log.d(WallpaperApp.TAG, "--------------data=" + dataBean.getDescription());
|
||||
}
|
||||
} else {
|
||||
vb.searchPb.setVisibility(View.GONE);
|
||||
Toast.makeText(requireContext(), getString(R.string.please_input_keyword), Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
private void showEmpty(boolean showEmpty) {
|
||||
if (showEmpty) {
|
||||
vb.emptyLayout.setVisibility(View.VISIBLE);
|
||||
vb.resultRecycler.setVisibility(View.GONE);
|
||||
} else {
|
||||
vb.emptyLayout.setVisibility(View.GONE);
|
||||
vb.resultRecycler.setVisibility(View.VISIBLE);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void onItemClickAction(DataBean info) {
|
||||
Intent intent = new Intent(requireContext(), SetWall.class);
|
||||
intent.putExtra(Utils.key_info, info);
|
||||
startActivity(intent);
|
||||
}
|
||||
}
|
||||
94
app/src/main/java/com/phone/wall/paper/view/Main.java
Normal file
94
app/src/main/java/com/phone/wall/paper/view/Main.java
Normal file
@ -0,0 +1,94 @@
|
||||
package com.phone.wall.paper.view;
|
||||
|
||||
import android.os.Bundle;
|
||||
import android.view.View;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.appcompat.app.AppCompatActivity;
|
||||
import androidx.core.content.ContextCompat;
|
||||
import androidx.fragment.app.Fragment;
|
||||
import androidx.viewpager2.adapter.FragmentStateAdapter;
|
||||
|
||||
import com.google.android.material.tabs.TabLayout;
|
||||
import com.phone.wall.paper.R;
|
||||
import com.phone.wall.paper.databinding.ItemTabBinding;
|
||||
import com.phone.wall.paper.databinding.UiMainBinding;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class Main extends AppCompatActivity {
|
||||
|
||||
|
||||
private UiMainBinding vb;
|
||||
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
vb = UiMainBinding.inflate(getLayoutInflater());
|
||||
Utils.initFull(this,false);
|
||||
setContentView(vb.getRoot());
|
||||
|
||||
|
||||
List<Fragment> list = new ArrayList<>();
|
||||
list.add(FragMain.newInstance(0));
|
||||
list.add(FragSearch.newInstance());
|
||||
list.add(FragFavorite.newInstance());
|
||||
|
||||
int[] ints = {R.drawable.status_home,R.drawable.selector_search, R.drawable.status__like};
|
||||
vb.viewpager2.setAdapter(new FragmentStateAdapter(this) {
|
||||
@NonNull
|
||||
@Override
|
||||
public Fragment createFragment(int position) {
|
||||
return list.get(position);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getItemCount() {
|
||||
return list.size();
|
||||
}
|
||||
});
|
||||
vb.viewpager2.setUserInputEnabled(false);
|
||||
|
||||
for(int i = 0;i<list.size();i++){
|
||||
TabLayout.Tab tab = vb.tab.newTab();
|
||||
ItemTabBinding tabVb = ItemTabBinding.inflate(getLayoutInflater());
|
||||
tabVb.imageIcon.setImageDrawable(ContextCompat.getDrawable(this,ints[i]));
|
||||
tab.setCustomView(tabVb.getRoot());
|
||||
if(i ==0){
|
||||
tabVb.imageIndicator.setVisibility(View.VISIBLE);
|
||||
}else {
|
||||
tabVb.imageIndicator.setVisibility(View.GONE);
|
||||
}
|
||||
vb.tab.addTab(tab);
|
||||
}
|
||||
vb.tab.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
|
||||
@Override
|
||||
public void onTabSelected(TabLayout.Tab tab) {
|
||||
int position = tab.getPosition();
|
||||
vb.viewpager2.setCurrentItem(position);
|
||||
View customView = tab.getCustomView();
|
||||
View imageIndicator = customView.findViewById(R.id.image_indicator);
|
||||
imageIndicator.setVisibility(View.VISIBLE);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onTabUnselected(TabLayout.Tab tab) {
|
||||
View customView = tab.getCustomView();
|
||||
View imageIndicator = customView.findViewById(R.id.image_indicator);
|
||||
imageIndicator.setVisibility(View.INVISIBLE);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onTabReselected(TabLayout.Tab tab) {
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
@ -0,0 +1,89 @@
|
||||
package com.phone.wall.paper.view;
|
||||
|
||||
import android.app.Dialog;
|
||||
import android.graphics.Color;
|
||||
import android.graphics.drawable.ColorDrawable;
|
||||
import android.os.Bundle;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.view.ViewGroup;
|
||||
import android.view.Window;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.fragment.app.DialogFragment;
|
||||
|
||||
import com.phone.wall.paper.databinding.SelectWallpaperTypeBinding;
|
||||
import com.phone.wall.paper.listener.OnType;
|
||||
|
||||
public class SelectWallpaperType extends DialogFragment {
|
||||
|
||||
private SelectWallpaperTypeBinding vb;
|
||||
private OnType listener;
|
||||
|
||||
public static final int type_home =0;
|
||||
public static final int type_lock =1;
|
||||
public static final int type_both =2;
|
||||
|
||||
public void setListener(OnType listener) {
|
||||
this.listener = listener;
|
||||
}
|
||||
|
||||
@Nullable
|
||||
@Override
|
||||
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
|
||||
|
||||
vb = SelectWallpaperTypeBinding.inflate(getLayoutInflater());
|
||||
|
||||
init();
|
||||
return vb.getRoot();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStart() {
|
||||
super.onStart();
|
||||
Dialog dialog = getDialog();
|
||||
if (dialog != null) {
|
||||
dialog.setCanceledOnTouchOutside(true);
|
||||
Window window = dialog.getWindow();
|
||||
if (window != null) {
|
||||
window.setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
|
||||
window.setLayout(ViewGroup.LayoutParams.MATCH_PARENT,ViewGroup.LayoutParams.WRAP_CONTENT);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void init(){
|
||||
vb.layoutHome.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
if(listener!= null){
|
||||
listener.onSelectType(type_home);
|
||||
dismiss();
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
vb.layoutLock.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
if(listener!= null){
|
||||
listener.onSelectType(type_lock);
|
||||
dismiss();
|
||||
|
||||
}
|
||||
}
|
||||
});
|
||||
vb.layoutBoth.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
if(listener!= null){
|
||||
listener.onSelectType(type_both);
|
||||
dismiss();
|
||||
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
436
app/src/main/java/com/phone/wall/paper/view/SetWall.java
Normal file
436
app/src/main/java/com/phone/wall/paper/view/SetWall.java
Normal file
@ -0,0 +1,436 @@
|
||||
package com.phone.wall.paper.view;
|
||||
|
||||
|
||||
import android.app.WallpaperManager;
|
||||
import android.content.pm.PackageManager;
|
||||
import android.graphics.drawable.Drawable;
|
||||
import android.net.Uri;
|
||||
import android.os.Build;
|
||||
import android.os.Bundle;
|
||||
import android.util.Log;
|
||||
import android.view.View;
|
||||
import android.widget.Toast;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.appcompat.app.AppCompatActivity;
|
||||
|
||||
import com.ad.toponlibrary.AdManager;
|
||||
import com.ad.toponlibrary.onActionListener;
|
||||
import com.bumptech.glide.Glide;
|
||||
import com.bumptech.glide.load.DataSource;
|
||||
import com.bumptech.glide.load.DecodeFormat;
|
||||
import com.bumptech.glide.load.engine.GlideException;
|
||||
import com.bumptech.glide.load.resource.drawable.DrawableTransitionOptions;
|
||||
import com.bumptech.glide.request.RequestListener;
|
||||
import com.bumptech.glide.request.RequestOptions;
|
||||
import com.bumptech.glide.request.target.Target;
|
||||
import com.phone.wall.paper.R;
|
||||
import com.phone.wall.paper.WallpaperApp;
|
||||
import com.phone.wall.paper.data.DataBean;
|
||||
import com.phone.wall.paper.databinding.UiSetWallBinding;
|
||||
import com.phone.wall.paper.listener.OnType;
|
||||
import com.phone.wall.paper.tools.JsonData;
|
||||
import com.phone.wall.paper.tools.RoomManager;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.FileInputStream;
|
||||
import java.io.InputStream;
|
||||
import java.lang.ref.WeakReference;
|
||||
|
||||
import kotlin.Unit;
|
||||
import kotlin.jvm.functions.Function2;
|
||||
import okhttp3.Call;
|
||||
|
||||
public class SetWall extends AppCompatActivity implements OnType {
|
||||
|
||||
private WeakReference<SetWall> weakReference;
|
||||
private DataBean dataBean;
|
||||
private WallpaperManager wallpaperManager;
|
||||
|
||||
|
||||
private UiSetWallBinding vb;
|
||||
|
||||
|
||||
private int permissionCode = 1;
|
||||
private String mSavePath;
|
||||
private String imId;
|
||||
private String fullUrl;
|
||||
|
||||
private SelectWallpaperType selectWallpaperType;
|
||||
|
||||
private File downloadFile;
|
||||
private Call call;
|
||||
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
vb = UiSetWallBinding.inflate(getLayoutInflater());
|
||||
Utils.initFull(this, true);
|
||||
setContentView(vb.getRoot());
|
||||
weakReference = new WeakReference<>(this);
|
||||
dataBean = (DataBean) getIntent().getSerializableExtra(Utils.key_info);
|
||||
AdManager.loadAllAd();
|
||||
if (dataBean == null) {
|
||||
return;
|
||||
}
|
||||
imId = dataBean.getImId();
|
||||
mSavePath = JsonData.INSTANCE.getSaveFilePath(this, imId);
|
||||
wallpaperManager = WallpaperManager.getInstance(this);
|
||||
initClick();
|
||||
loadDetail();
|
||||
vb.tvContent.setText(dataBean.getDescription());
|
||||
|
||||
AdManager.showTopOn(this, new onActionListener() {
|
||||
@Override
|
||||
public void onAction() {
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private void loadDetail() {
|
||||
String previewUrl400 = dataBean.getPreviewUrl400();
|
||||
String previewUrl1080 = dataBean.getPreviewUrl1080();
|
||||
|
||||
fullUrl = dataBean.getFullUrl();
|
||||
|
||||
File file = new File(mSavePath);
|
||||
RequestOptions options = new RequestOptions()
|
||||
.format(DecodeFormat.PREFER_RGB_565);
|
||||
|
||||
|
||||
int[] screenWidthHeight = Utils.getScreenWidthHeight(this);
|
||||
Log.d(WallpaperApp.TAG, "--------width=" + screenWidthHeight[0] + "----height=" + screenWidthHeight[1]);
|
||||
if (file.exists()) {
|
||||
Glide.with(this)
|
||||
.load(file)
|
||||
.apply(options)
|
||||
.placeholder(R.mipmap.im_placeholder)
|
||||
// .override(screenWidthHeight[0], screenWidthHeight[1])
|
||||
.transition(DrawableTransitionOptions.withCrossFade(500))
|
||||
.into(vb.imageviewPreview);
|
||||
} else {
|
||||
Glide.with(this)
|
||||
.asDrawable()
|
||||
.load(previewUrl1080)
|
||||
.apply(options)
|
||||
.skipMemoryCache(true)
|
||||
|
||||
.placeholder(R.mipmap.im_placeholder)
|
||||
.thumbnail(
|
||||
Glide.with(SetWall.this)
|
||||
.asDrawable()
|
||||
.load(previewUrl400)
|
||||
.apply(options)
|
||||
.placeholder(R.mipmap.im_placeholder)
|
||||
|
||||
.centerCrop()
|
||||
)
|
||||
.transition(DrawableTransitionOptions.withCrossFade(500)) // 500ms 淡入效果
|
||||
.listener(new RequestListener<Drawable>() {
|
||||
@Override
|
||||
public boolean onLoadFailed(@Nullable GlideException e, @Nullable Object model, @NonNull Target<Drawable> target, boolean isFirstResource) {
|
||||
Log.d(WallpaperApp.TAG, "-----------onLoadFailed e" + e.getMessage());
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onResourceReady(@NonNull Drawable resource, @NonNull Object model, Target<Drawable> target, @NonNull DataSource dataSource, boolean isFirstResource) {
|
||||
// fullDrawable = resource;
|
||||
return false;
|
||||
}
|
||||
})
|
||||
.centerCrop()
|
||||
.into(vb.imageviewPreview);
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
boolean b = RoomManager.queryIsLike(imId);
|
||||
vb.imageFavorite.setSelected(b);
|
||||
|
||||
}
|
||||
|
||||
private void initClick() {
|
||||
vb.imageviewBack.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
finish();
|
||||
}
|
||||
});
|
||||
|
||||
vb.buttonSet.setOnClickListener(v -> {
|
||||
|
||||
AdManager.showTopOn(SetWall.this, new onActionListener() {
|
||||
@Override
|
||||
public void onAction() {
|
||||
if (selectWallpaperType == null) {
|
||||
selectWallpaperType = new SelectWallpaperType();
|
||||
selectWallpaperType.setListener(SetWall.this);
|
||||
}
|
||||
if (!selectWallpaperType.isAdded()) {
|
||||
selectWallpaperType.show(getSupportFragmentManager(), "");
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
|
||||
|
||||
});
|
||||
vb.imageFavorite.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
boolean selected = vb.imageFavorite.isSelected();
|
||||
vb.imageFavorite.setSelected(!selected);
|
||||
boolean selectedNew = vb.imageFavorite.isSelected();
|
||||
dataBean.setLike(selectedNew);
|
||||
RoomManager.updateLike(dataBean);
|
||||
|
||||
}
|
||||
});
|
||||
vb.layoutDownload.setOnClickListener(new View.OnClickListener() {
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
boolean permission = JsonData.INSTANCE.requestPermission(SetWall.this, permissionCode);
|
||||
if (!permission) {
|
||||
return;
|
||||
}
|
||||
AdManager.showTopOn(SetWall.this, new onActionListener() {
|
||||
@Override
|
||||
public void onAction() {
|
||||
startSaveToAlbum();
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private void startSaveToAlbum() {
|
||||
showDownloadLoading(true);
|
||||
|
||||
if (downloadFile != null && downloadFile.exists()) {
|
||||
Log.d(WallpaperApp.TAG, "-----------Download 2");
|
||||
startSave(downloadFile);
|
||||
return;
|
||||
}
|
||||
Log.d(WallpaperApp.TAG, "-----------Download 3");
|
||||
doDownload(true, true);
|
||||
|
||||
}
|
||||
|
||||
private void doDownload(boolean showMsg, boolean save) {
|
||||
call = JsonData.INSTANCE.downloadFile(fullUrl, mSavePath, new Function2<Boolean, InputStream, Unit>() {
|
||||
@Override
|
||||
public Unit invoke(Boolean aBoolean, InputStream inputStream) {
|
||||
File file = new File(mSavePath);
|
||||
if (aBoolean && file.exists()) {
|
||||
downloadFile = file;
|
||||
if (save) {
|
||||
startSave(downloadFile);
|
||||
}
|
||||
runOnUiThread(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
SetWall activity = weakReference.get();
|
||||
if (activity != null && !activity.isDestroyed()) {
|
||||
Log.d(WallpaperApp.TAG, "-------weakReference !=null");
|
||||
// Glide.with(activity)
|
||||
// .asDrawable()
|
||||
// .load(downloadFile)
|
||||
// .into(vb.imageviewPreview);
|
||||
} else {
|
||||
Log.d(WallpaperApp.TAG, "-------weakReference null");
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
} else {
|
||||
runOnUiThread(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
showDownloadLoading(false);
|
||||
if (showMsg) {
|
||||
Toast.makeText(SetWall.this, getString(R.string.download_fail), Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
return null;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private void showDownloadLoading(boolean show) {
|
||||
if (show) {
|
||||
vb.pbDownload.setVisibility(View.VISIBLE);
|
||||
vb.imageDownload.setVisibility(View.GONE);
|
||||
} else {
|
||||
vb.pbDownload.setVisibility(View.GONE);
|
||||
vb.imageDownload.setVisibility(View.VISIBLE);
|
||||
}
|
||||
}
|
||||
|
||||
private void showSetWallpaperLoading(boolean show) {
|
||||
Log.d(WallpaperApp.TAG, "-----------showSetWallpaperLoading" + show);
|
||||
if (show) {
|
||||
vb.pbSet.setVisibility(View.VISIBLE);
|
||||
vb.buttonSet.setVisibility(View.GONE);
|
||||
} else {
|
||||
vb.pbSet.setVisibility(View.GONE);
|
||||
vb.buttonSet.setVisibility(View.VISIBLE);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
|
||||
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
|
||||
if (requestCode == permissionCode && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
|
||||
startSaveToAlbum();
|
||||
}
|
||||
}
|
||||
|
||||
private void startSave(File file) {
|
||||
RoomManager.insertOrUpdateDownload(dataBean);
|
||||
Uri uri = JsonData.INSTANCE.saveToGallery(SetWall.this, file);
|
||||
runOnUiThread(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
showDownloadLoading(false);
|
||||
if (uri == null) {
|
||||
Toast.makeText(SetWall.this, getString(R.string.save_fail), Toast.LENGTH_SHORT).show();
|
||||
} else {
|
||||
// deleteCacheFile();
|
||||
Toast.makeText(SetWall.this, getString(R.string.save_success), Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
Log.d(WallpaperApp.TAG, "--------path=" + file.getAbsolutePath() + "---uri=" + uri);
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSelectType(int type) {
|
||||
|
||||
showSetWallpaperLoading(true);
|
||||
if (downloadFile != null && downloadFile.exists()) {
|
||||
new Thread(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
Log.d(WallpaperApp.TAG, "--------downloadFile=" + downloadFile.exists());
|
||||
setWallpaper(downloadFile, type);
|
||||
}
|
||||
}).start();
|
||||
}
|
||||
// else if (fullDrawable != null) {
|
||||
// new Thread(new Runnable() {
|
||||
// @Override
|
||||
// public void run() {
|
||||
// File file = new File(CommonHelper.saveDrawableToFile(fullDrawable, mSavePath));
|
||||
// setWallpaper(file, type);
|
||||
// }
|
||||
// }).start();
|
||||
// }
|
||||
else {
|
||||
call = JsonData.INSTANCE.downloadFile(fullUrl, mSavePath, new Function2<Boolean, InputStream, Unit>() {
|
||||
@Override
|
||||
public Unit invoke(Boolean aBoolean, InputStream inputStream) {
|
||||
Log.d(WallpaperApp.TAG, "--------downloadFile=" + Thread.currentThread().getName());
|
||||
File file = new File(mSavePath);
|
||||
if (aBoolean && file.exists()) {
|
||||
downloadFile = file;
|
||||
setWallpaper(downloadFile, type);
|
||||
} else {
|
||||
runOnUiThread(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
showSetWallpaperLoading(false);
|
||||
Toast.makeText(SetWall.this, getString(R.string.set_fail), Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
});
|
||||
|
||||
}
|
||||
return null;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
private void setWallpaper(File file, int type) {
|
||||
try {
|
||||
FileInputStream fileInputStream = new FileInputStream(file);
|
||||
switch (type) {
|
||||
case SelectWallpaperType.type_home:
|
||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.N) {
|
||||
wallpaperManager.setStream(fileInputStream);
|
||||
} else {
|
||||
wallpaperManager.setStream(
|
||||
fileInputStream,
|
||||
null,
|
||||
true,
|
||||
WallpaperManager.FLAG_SYSTEM
|
||||
);
|
||||
}
|
||||
break;
|
||||
case SelectWallpaperType.type_lock:
|
||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.N) {
|
||||
wallpaperManager.setStream(fileInputStream);
|
||||
} else {
|
||||
wallpaperManager.setStream(
|
||||
fileInputStream,
|
||||
null,
|
||||
true,
|
||||
WallpaperManager.FLAG_LOCK
|
||||
);
|
||||
}
|
||||
break;
|
||||
case SelectWallpaperType.type_both:
|
||||
wallpaperManager.setStream(fileInputStream);
|
||||
break;
|
||||
}
|
||||
deleteCacheFile();
|
||||
runOnUiThread(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
showSetWallpaperLoading(false);
|
||||
Toast.makeText(SetWall.this, getString(R.string.set_success), Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
});
|
||||
} catch (Exception exception) {
|
||||
runOnUiThread(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
showSetWallpaperLoading(false);
|
||||
Toast.makeText(SetWall.this, getString(R.string.set_fail), Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
private void deleteCacheFile() {
|
||||
if (downloadFile != null && downloadFile.exists()) {
|
||||
boolean delete = downloadFile.delete();
|
||||
Log.d(WallpaperApp.TAG, "--------delete=" + delete);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void onDestroy() {
|
||||
super.onDestroy();
|
||||
if (call != null) {
|
||||
call.cancel();
|
||||
}
|
||||
}
|
||||
}
|
||||
72
app/src/main/java/com/phone/wall/paper/view/Welcome.java
Normal file
72
app/src/main/java/com/phone/wall/paper/view/Welcome.java
Normal file
@ -0,0 +1,72 @@
|
||||
package com.phone.wall.paper.view;
|
||||
|
||||
import android.annotation.SuppressLint;
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.os.CountDownTimer;
|
||||
|
||||
import androidx.appcompat.app.AppCompatActivity;
|
||||
|
||||
import com.ad.toponlibrary.AdManager;
|
||||
import com.phone.wall.paper.R;
|
||||
import com.phone.wall.paper.databinding.UiWelcomeBinding;
|
||||
import com.phone.wall.paper.tools.Utils;
|
||||
|
||||
import kotlin.Unit;
|
||||
import kotlin.jvm.functions.Function0;
|
||||
import kotlin.jvm.functions.Function1;
|
||||
|
||||
public class Welcome extends AppCompatActivity {
|
||||
|
||||
private CountDownTimer countDownTimer;
|
||||
private UiWelcomeBinding vb;
|
||||
|
||||
private long totalTime = 12000;
|
||||
|
||||
@SuppressLint("MissingInflatedId")
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
vb = UiWelcomeBinding.inflate(getLayoutInflater());
|
||||
Utils.initFull(this,true);
|
||||
setContentView(vb.getRoot());
|
||||
|
||||
countDownTimer = AdManager.showWelcomeAd(this, totalTime, new Function1<Long, Unit>() {
|
||||
@Override
|
||||
public Unit invoke(Long aLong) {
|
||||
int progressPercentage = (int) ((100 * aLong) / totalTime);
|
||||
|
||||
int countdownPercentage = 100 - progressPercentage;
|
||||
|
||||
vb.progressbar.setProgress(countdownPercentage);
|
||||
String string = getString(R.string.tv_wel_progress, countdownPercentage);
|
||||
vb.tvProgress.setText(string);
|
||||
return null;
|
||||
}
|
||||
}, new Function0<Unit>() {
|
||||
@Override
|
||||
public Unit invoke() {
|
||||
vb.progressbar.setProgress(100);
|
||||
String string = getString(R.string.tv_wel_progress, 100);
|
||||
vb.tvProgress.setText(string);
|
||||
Intent intent = new Intent(Welcome.this, Main.class);
|
||||
startActivity(intent);
|
||||
finish();
|
||||
return null;
|
||||
}
|
||||
});
|
||||
countDownTimer.start();
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
@Override
|
||||
protected void onDestroy() {
|
||||
super.onDestroy();
|
||||
if (countDownTimer != null) {
|
||||
countDownTimer.cancel();
|
||||
countDownTimer = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
30
app/src/main/res/drawable-v24/ic_launcher_foreground.xml
Normal file
30
app/src/main/res/drawable-v24/ic_launcher_foreground.xml
Normal file
@ -0,0 +1,30 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:aapt="http://schemas.android.com/aapt"
|
||||
android:width="108dp"
|
||||
android:height="108dp"
|
||||
android:viewportWidth="108"
|
||||
android:viewportHeight="108">
|
||||
<path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z">
|
||||
<aapt:attr name="android:fillColor">
|
||||
<gradient
|
||||
android:endX="85.84757"
|
||||
android:endY="92.4963"
|
||||
android:startX="42.9492"
|
||||
android:startY="49.59793"
|
||||
android:type="linear">
|
||||
<item
|
||||
android:color="#44000000"
|
||||
android:offset="0.0" />
|
||||
<item
|
||||
android:color="#00000000"
|
||||
android:offset="1.0" />
|
||||
</gradient>
|
||||
</aapt:attr>
|
||||
</path>
|
||||
<path
|
||||
android:fillColor="#FFFFFF"
|
||||
android:fillType="nonZero"
|
||||
android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z"
|
||||
android:strokeWidth="1"
|
||||
android:strokeColor="#00000000" />
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/favorite_false.xml
Normal file
9
app/src/main/res/drawable/favorite_false.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M667.8,117.3C832.9,117.3 938.7,249.7 938.7,427.9c0,138.3 -125.1,290.5 -371.6,461.6a96.8,96.8 0,0 1,-110.2 0C210.4,718.4 85.3,566.1 85.3,427.9 85.3,249.7 191.1,117.3 356.2,117.3c59.6,0 100.1,20.8 155.8,68.1C567.7,138.2 608.2,117.3 667.8,117.3z"
|
||||
android:fillColor="@color/sub_color"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/favorite_true.xml
Normal file
9
app/src/main/res/drawable/favorite_true.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M667.8,117.3C832.9,117.3 938.7,249.7 938.7,427.9c0,138.3 -125.1,290.5 -371.6,461.6a96.8,96.8 0,0 1,-110.2 0C210.4,718.4 85.3,566.1 85.3,427.9 85.3,249.7 191.1,117.3 356.2,117.3c59.6,0 100.1,20.8 155.8,68.1C567.7,138.2 608.2,117.3 667.8,117.3z"
|
||||
android:fillColor="@color/color_84B1ED"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/home_false.xml
Normal file
9
app/src/main/res/drawable/home_false.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M555.5,118l312.9,224.6A117.3,117.3 0,0 1,917.3 437.9V800c0,64.8 -52.5,117.3 -117.3,117.3H640V746.7c0,-70.7 -57.3,-128 -128,-128s-128,57.3 -128,128v170.7H224c-64.8,0 -117.3,-52.5 -117.3,-117.3V437.9a117.3,117.3 0,0 1,48.9 -95.3l312.9,-224.6a74.7,74.7 0,0 1,87.1 0z"
|
||||
android:fillColor="@color/sub_color"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/home_true.xml
Normal file
9
app/src/main/res/drawable/home_true.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M555.5,118l312.9,224.6A117.3,117.3 0,0 1,917.3 437.9V800c0,64.8 -52.5,117.3 -117.3,117.3H640V746.7c0,-70.7 -57.3,-128 -128,-128s-128,57.3 -128,128v170.7H224c-64.8,0 -117.3,-52.5 -117.3,-117.3V437.9a117.3,117.3 0,0 1,48.9 -95.3l312.9,-224.6a74.7,74.7 0,0 1,87.1 0z"
|
||||
android:fillColor="@color/color_84B1ED"/>
|
||||
</vector>
|
||||
12
app/src/main/res/drawable/ic_both.xml
Normal file
12
app/src/main/res/drawable/ic_both.xml
Normal file
@ -0,0 +1,12 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M747.2,283.2L54.5,283.2v692.7h692.7v-692.7zM656.8,373.6v512h-512v-512h512z"
|
||||
android:fillColor="@color/white"/>
|
||||
<path
|
||||
android:pathData="M993.3,12.4v692.7h-287.2v-90.4h196.8v-512h-512v224.4h-90.4V12.4z"
|
||||
android:fillColor="@color/white"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/ic_download.xml
Normal file
9
app/src/main/res/drawable/ic_download.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M878.6,337.2a57.8,57.8 0,0 0,-81.7 0L574.6,559.5V173a57.8,57.8 0,0 0,-115.6 0v386.5L236.8,337.2a57.8,57.8 0,0 0,-81.7 0,57.8 57.8,0 0,0 0,81.8l318.7,318.7a57.6,57.6 0,0 0,40.9 16.9c0.7,0 1.5,-0.1 2.2,-0.1 0.7,0 1.5,0.1 2.2,0.1a57.6,57.6 0,0 0,40.9 -16.9L878.6,419a57.8,57.8 0,0 0,0 -81.8zM861,908.4H165.4a57.8,57.8 0,0 1,0 -115.6h695.6a57.8,57.8 0,0 1,0 115.6z"
|
||||
android:fillColor="@color/white"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/ic_favorite_ffffff.xml
Normal file
9
app/src/main/res/drawable/ic_favorite_ffffff.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M704,128C833.6,128 938.7,234.7 938.7,384c0,298.7 -320,469.3 -426.7,533.3C405.3,853.3 85.3,682.7 85.3,384c0,-149.3 106.7,-256 234.7,-256C399.4,128 469.3,170.7 512,213.3c42.7,-42.7 112.6,-85.3 192,-85.3zM551.9,793.8a1141.4,1141.4 0,0 0,103.3 -72.6C782.3,620.1 853.3,509.6 853.3,384c0,-100.7 -65.6,-170.7 -149.3,-170.7 -45.9,0 -95.6,24.3 -131.7,60.3L512,334l-60.3,-60.3C415.6,237.7 365.9,213.3 320,213.3 237.2,213.3 170.7,284 170.7,384c0,125.6 71.1,236.1 198.2,337.2 31.8,25.3 65.7,48.9 103.3,72.5 12.8,8.1 25.4,15.8 39.9,24.4 14.5,-8.6 27.1,-16.3 39.9,-24.4z"
|
||||
android:fillColor="@color/white"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/ic_favorite_red.xml
Normal file
9
app/src/main/res/drawable/ic_favorite_red.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="24dp"
|
||||
android:height="24dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M667.8,117.3C832.9,117.3 938.7,249.7 938.7,427.9c0,138.3 -125.1,290.5 -371.6,461.6a96.8,96.8 0,0 1,-110.2 0C210.4,718.4 85.3,566.1 85.3,427.9 85.3,249.7 191.1,117.3 356.2,117.3c59.6,0 100.1,20.8 155.8,68.1C567.7,138.2 608.2,117.3 667.8,117.3z"
|
||||
android:fillColor="@color/favorite_true"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/ic_home_wall.xml
Normal file
9
app/src/main/res/drawable/ic_home_wall.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:fillColor="@color/white"
|
||||
android:pathData="M776.7,1010.1h-479.9c-28.3,0 -51.3,-23 -51.3,-51.3v-891.1c0,-28.3 23,-51.3 51.3,-51.3h479.9c28.3,0 51.3,23 51.3,51.3v891.1c0,28.3 -23,51.3 -51.3,51.3v0zM536.6,958.8c19.1,0 34.2,-15.4 34.2,-34.2s-15.4,-34.2 -34.2,-34.2 -34.2,15.4 -34.2,34.2 15.4,34.2 34.2,34.2v0zM776.7,119h-479.9v719.7h479.6v-719.7h0.3z"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/ic_lock_wall.xml
Normal file
9
app/src/main/res/drawable/ic_lock_wall.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:fillColor="@color/white"
|
||||
android:pathData="M426.9,683l170.8,0c25.6,0 42.7,-17.1 42.7,-42.7L640.3,512.3c0,-25.6 -17.1,-42.7 -42.7,-42.7l0,-42.7c0,-47 -38.4,-85.4 -85.4,-85.4s-85.4,38.4 -85.4,85.4l0,42.7c-25.6,0 -42.7,17.1 -42.7,42.7l0,128.1C384.2,666 401.3,683 426.9,683zM461,426.9c0,-29.9 21.3,-51.2 51.2,-51.2s51.2,21.3 51.2,51.2l0,42.7 -102.5,0L461,426.9 461,426.9zM725.7,42.7 L298.8,42.7c-47,0 -85.4,38.4 -85.4,85.4l0,768.4c0,47 38.4,85.4 85.4,85.4l426.9,0c47,0 85.4,-38.4 85.4,-85.4L811.1,128.1C811.1,81.1 772.7,42.7 725.7,42.7zM725.7,811.1 L298.8,811.1 298.8,213.4l426.9,0L725.7,811.1z"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/ic_return_white.xml
Normal file
9
app/src/main/res/drawable/ic_return_white.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M154.5,469.3H981.3a42.7,42.7 0,1 1,0 85.3H154.5l300.7,266.9a42.7,42.7 0,1 1,-57.1 63.4l-384,-341.3a42.7,42.7 0,0 1,0 -63.4l384,-341.3a42.7,42.7 0,1 1,57.1 63.4L154.5,469.3z"
|
||||
android:fillColor="@color/black"/>
|
||||
</vector>
|
||||
12
app/src/main/res/drawable/ic_search_false.xml
Normal file
12
app/src/main/res/drawable/ic_search_false.xml
Normal file
@ -0,0 +1,12 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="256dp"
|
||||
android:height="256dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M222.1,580.4a356.2,356.2 0,0 0,34.1 152.9,357.6 357.6,0 0,0 477.7,-477.7A357.6,357.6 0,0 0,222.1 580.4z"
|
||||
android:fillColor="@color/color_0"/>
|
||||
<path
|
||||
android:pathData="M1009,936.6l-276.1,-276.1a409.5,409.5 0,1 0,-72.3 72.3l276.1,276.1a51.2,51.2 0,0 0,72.3 -72.3zM409.8,716.9a307.1,307.1 0,1 1,307.1 -307.1,307.1 307.1,0 0,1 -307.1,307.1z"
|
||||
android:fillColor="@color/sub_color"/>
|
||||
</vector>
|
||||
12
app/src/main/res/drawable/ic_search_true.xml
Normal file
12
app/src/main/res/drawable/ic_search_true.xml
Normal file
@ -0,0 +1,12 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="256dp"
|
||||
android:height="256dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M222.1,580.4a356.2,356.2 0,0 0,34.1 152.9,357.6 357.6,0 0,0 477.7,-477.7A357.6,357.6 0,0 0,222.1 580.4z"
|
||||
android:fillColor="@color/color_0"/>
|
||||
<path
|
||||
android:pathData="M1009,936.6l-276.1,-276.1a409.5,409.5 0,1 0,-72.3 72.3l276.1,276.1a51.2,51.2 0,0 0,72.3 -72.3zM409.8,716.9a307.1,307.1 0,1 1,307.1 -307.1,307.1 307.1,0 0,1 -307.1,307.1z"
|
||||
android:fillColor="@color/color_84B1ED"/>
|
||||
</vector>
|
||||
12
app/src/main/res/drawable/ic_search_view.xml
Normal file
12
app/src/main/res/drawable/ic_search_view.xml
Normal file
@ -0,0 +1,12 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="256dp"
|
||||
android:height="256dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M222.1,580.4a356.2,356.2 0,0 0,34.1 152.9,357.6 357.6,0 0,0 477.7,-477.7A357.6,357.6 0,0 0,222.1 580.4z"
|
||||
android:fillColor="@color/color_0"/>
|
||||
<path
|
||||
android:pathData="M1009,936.6l-276.1,-276.1a409.5,409.5 0,1 0,-72.3 72.3l276.1,276.1a51.2,51.2 0,0 0,72.3 -72.3zM409.8,716.9a307.1,307.1 0,1 1,307.1 -307.1,307.1 307.1,0 0,1 -307.1,307.1z"
|
||||
android:fillColor="@color/color_96e6f2"/>
|
||||
</vector>
|
||||
12
app/src/main/res/drawable/ic_set_wallpaper.xml
Normal file
12
app/src/main/res/drawable/ic_set_wallpaper.xml
Normal file
@ -0,0 +1,12 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="256dp"
|
||||
android:height="256dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:fillColor="@color/white"
|
||||
android:pathData="M261.9,492.9c20.6,11.9 46,11.9 66.6,0 20.6,-11.9 33.3,-33.9 33.3,-57.6 0,-36.8 -29.8,-66.5 -66.6,-66.5s-66.5,29.8 -66.5,66.5c0,23.8 12.7,45.7 33.2,57.6z"/>
|
||||
<path
|
||||
android:fillColor="@color/white"
|
||||
android:pathData="M804,153.4L221.4,153.4c-78.3,0 -142,63.7 -142,142v436.9c0,78.3 63.7,142 142,142L804,874.3c78.3,0 142,-63.7 142,-142L946,295.4c-0.1,-78.3 -63.7,-142 -142,-142zM144.9,295.4c0,-42.2 34.3,-76.5 76.4,-76.5L804,218.9c42.1,0 76.4,34.3 76.4,76.5v331.1l-95.3,-86.2 -13.6,-9.7c-71.9,-46.1 -164.2,-45.1 -233.9,1.3l-385,232.6c-4.7,-9.9 -7.7,-20.6 -7.7,-32.2L144.9,295.4zM804,808.8L221.4,808.8c-4.1,0 -7.6,-1.7 -11.4,-2.3l362.8,-219.2c49.5,-32.9 113.6,-33.4 162.8,-1.9l143.7,128.5 1.2,-1.3v19.8c-0.1,42.1 -34.4,76.4 -76.5,76.4z"/>
|
||||
</vector>
|
||||
9
app/src/main/res/drawable/ic_stoke_favorite.xml
Normal file
9
app/src/main/res/drawable/ic_stoke_favorite.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M667.8,117.3C832.9,117.3 938.7,249.7 938.7,427.9c0,138.3 -125.1,290.5 -371.6,461.6a96.8,96.8 0,0 1,-110.2 0C210.4,718.4 85.3,566.1 85.3,427.9 85.3,249.7 191.1,117.3 356.2,117.3c59.6,0 100.1,20.8 155.8,68.1C567.7,138.2 608.2,117.3 667.8,117.3zM667.8,180.5c-41.4,0 -70.3,15.2 -117,55 -2.2,1.8 -14.4,12.4 -17.9,15.4a32.3,32.3 0,0 1,-41.8 0c-3.5,-3 -15.8,-13.5 -17.9,-15.4 -46.7,-39.9 -75.5,-55 -117,-55C230.2,180.5 149.3,281.3 149.3,426.7 149.3,537.6 262.9,675.2 493.6,834.8a32.4,32.4 0,0 0,36.7 0C761.1,675.3 874.7,537.6 874.7,426.7c0,-145.4 -80.9,-246.2 -206.9,-246.2z"
|
||||
android:fillColor="@color/white"/>
|
||||
</vector>
|
||||
7
app/src/main/res/drawable/image_describe.xml
Normal file
7
app/src/main/res/drawable/image_describe.xml
Normal file
@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<shape xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:shape="rectangle">
|
||||
<corners android:radius="16dp" />
|
||||
<solid android:color="@color/color_main_view" />
|
||||
|
||||
</shape>
|
||||
12
app/src/main/res/drawable/image_empty.xml
Normal file
12
app/src/main/res/drawable/image_empty.xml
Normal file
@ -0,0 +1,12 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M271.9,728.1v-412.2c0,-30.7 18.9,-53.8 39.9,-53.8h412.2c21,0 39.9,23.6 39.9,54.3v220.2c0,2 0.5,4.1 1,5.6l14.8,-5.6v-220.2c0,-38.9 -25.1,-70.1 -56.3,-70.1h-412.2c-31.2,0 -56.3,31.2 -56.3,70.1v418.3l16.9,-6.7zM271.9,728.1v-412.2c0,-30.7 18.9,-53.8 39.9,-53.8h412.2c21,0 39.9,23.6 39.9,54.3v220.2c0,2 0.5,4.1 1,5.6l14.8,-5.6v-220.2c0,-38.9 -25.1,-70.1 -56.3,-70.1h-412.2c-31.2,0 -56.3,31.2 -56.3,70.1v418.3l16.9,-6.7zM958.5,800.8c-21.5,-16.9 -45.6,-29.7 -71.7,-38.4 -4.1,-1 -8.7,1.5 -9.7,5.6 -1,4.1 1,8.2 4.6,9.7 24.1,8.2 46.6,20.5 67.1,35.8 3.6,2.6 8.7,1.5 11.3,-2 2,-3.1 1.5,-7.7 -1.5,-10.8zM517.6,817.2c-37.9,0 -75.3,10.2 -108,30.2 -45.6,-61.4 -117.2,-97.3 -194,-97.3 -54.3,0 -107.5,18.4 -150,52.2 -3.1,3.1 -3.6,8.2 -0.5,11.3 2.6,3.1 7.2,3.6 10.2,1 39.9,-31.7 89.1,-48.6 140.3,-48.6 74.8,0 143.4,36.4 185.3,96.8 2.6,3.6 7.2,4.6 11.3,2 31.2,-21 68.1,-31.7 105.5,-31.7 35.8,0 69.6,9.7 99.8,27.6 3.6,2 8.2,1 10.8,-2 13.3,-17.9 29.2,-34.3 47.1,-47.6 3.6,-3.1 4.1,-8.2 1,-11.3 -2.6,-3.1 -7.2,-3.6 -10.8,-1.5 -17.4,12.8 -32.8,28.2 -46.1,45.1 -31.7,-16.9 -66.6,-26.1 -101.9,-26.1zM855.6,846.8c-41,-27.6 -96.3,-16.9 -123.9,23.6l-3.1,4.6c-2,3.6 -1,8.7 3.1,11.3 3.6,2 8.7,1 11.3,-3.1 8.2,-14.3 21.5,-25.1 36.9,-31.2 22.5,-8.7 47.6,-5.6 67.6,7.7 3.6,2.6 8.7,1.5 11.3,-2 1.5,-3.1 0.5,-8.2 -3.1,-10.8zM185.3,248.8c2,1.5 2,4.6 0.5,6.1m-45.1,205.3l-18.9,21c-1,1 -2.6,1 -3.6,0 -1,-1 -1,-2.6 0,-3.6l18.9,-21c1,-1 2.6,-1 3.6,0 1,1 1,2.6 0,3.6zM165.4,460.3l-18.9,21c-1,1 -2.6,1 -3.6,0 -1,-1 -1,-2.6 0,-3.6l18.9,-21c1,-1 2.6,-1 3.6,0 0.5,1 1,2.6 0,3.6zM813.1,146.4l-38.4,43c-2,2.6 -6.1,2.6 -8.2,0.5 -2.6,-2 -2.6,-6.1 -0.5,-8.2l38.4,-43c2,-2.6 6.1,-2.6 8.2,-0.5 2.6,2 2.6,5.6 0.5,8.2zM863.7,146.4l-38.4,43c-2,2.6 -6.1,2.6 -8.2,0.5 -2.6,-2 -2.6,-6.1 -0.5,-8.2l38.4,-43c2,-2.6 6.1,-2.6 8.2,-0.5 2.6,2 3.1,5.6 0.5,8.2z"
|
||||
android:fillColor="@color/sub_title_color"/>
|
||||
<path
|
||||
android:pathData="M390.1,451.6c-17.9,0.5 -32.8,-13.8 -33.3,-31.2 -0.5,-17.9 13.8,-32.8 31.2,-33.3h1.5c17.9,0.5 31.7,15.4 31.2,33.3 0.5,16.9 -13.3,30.7 -30.7,31.2zM382.5,419.3c6.1,0 10.8,-4.6 10.8,-10.8 0,-6.1 -4.6,-10.8 -10.8,-10.8 -6.1,0 -10.8,4.6 -10.8,10.8 0,6.1 4.6,10.8 10.8,10.8zM656.4,451.6c-17.9,0.5 -32.8,-13.8 -33.3,-31.2 -0.5,-17.9 13.8,-32.8 31.2,-33.3h1.5c17.9,0.5 31.7,15.4 31.2,33.3 0.5,16.9 -13.3,30.7 -30.7,31.2zM648.2,419.3c6.1,0 10.8,-4.6 10.8,-10.8 0,-6.1 -4.6,-10.8 -10.8,-10.8s-10.8,4.6 -10.8,10.8c0,6.1 5.1,10.8 10.8,10.8zM596,515.1c-2,0 -4.1,-1 -5.6,-2.6 -11.8,-12.3 -23.6,-17.9 -35.3,-17.4 -11.3,0.5 -21,7.7 -26.1,14.3 -2.6,3.6 -7.7,4.1 -11.3,1.5 -0.5,-0.5 -1,-0.5 -1,-1 -14.3,-16.4 -26.6,-15.9 -36.4,-13.8 -8.2,2 -16.4,6.7 -24.6,14.3 -3.1,3.1 -8.2,2.6 -11.3,-0.5 -3.1,-3.1 -2.6,-8.2 0.5,-11.3 10.2,-9.2 21,-15.4 31.7,-17.9 17.4,-4.6 32.8,-0.5 46.6,12.3 6.7,-6.1 17.4,-12.8 31.7,-13.8 16.4,-1 32.3,6.7 47.6,22.5 3.1,3.1 3.1,8.2 0,11.3 -2.6,1 -4.6,2 -6.7,2zM765.4,798.2c-64.5,0 -116.7,-52.2 -116.7,-116.7 0,-64.5 52.2,-116.7 116.7,-116.7 64.5,0 116.7,52.2 116.7,116.7 0,64.5 -52.2,116.7 -116.7,116.7zM707.6,666.6c-8.7,0 -16.4,7.2 -15.9,16.4 0,8.7 7.2,15.9 15.9,15.9h118.3c8.7,0 16.4,-7.2 15.9,-16.4 0,-8.7 -7.2,-15.9 -15.9,-15.9h-118.3z"
|
||||
android:fillColor="@color/sub_title_color"/>
|
||||
</vector>
|
||||
17
app/src/main/res/drawable/img_no_result.xml
Normal file
17
app/src/main/res/drawable/img_no_result.xml
Normal file
@ -0,0 +1,17 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="256dp"
|
||||
android:height="256dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M219.8,71c-12.3,0 -21.8,-9.6 -21.8,-21.8S208.9,27.3 219.8,27.3c12.3,0 21.8,9.6 21.8,21.8 0,12.3 -9.6,21.8 -21.8,21.8zM219.8,34.1c-8.2,0 -15,6.8 -15,15s6.8,15 15,15c8.2,0 15,-6.8 15,-15 0,-8.2 -6.8,-15 -15,-15z"
|
||||
android:strokeAlpha="0.3"
|
||||
android:fillColor="@color/sub_title_color"
|
||||
android:fillAlpha="0.3"/>
|
||||
<path
|
||||
android:pathData="M935.3,1009L112,1009c-4.1,0 -6.8,2.7 -6.8,6.8s2.7,6.8 6.8,6.8h823.3c4.1,0 6.8,-2.7 6.8,-6.8s-2.7,-6.8 -6.8,-6.8zM84.7,1009h-54.6c-4.1,0 -6.8,2.7 -6.8,6.8s2.7,6.8 6.8,6.8h54.6c4.1,0 6.8,-2.7 6.8,-6.8s-4.1,-6.8 -6.8,-6.8zM994,1009h-27.3c-4.1,0 -6.8,2.7 -6.8,6.8s2.7,6.8 6.8,6.8h27.3c4.1,0 6.8,-2.7 6.8,-6.8s-2.7,-6.8 -6.8,-6.8zM244.4,428.7c4.1,0 6.8,-2.7 6.8,-6.8L251.2,210.3h400v109.2L764.6,319.5l4.1,4.1v379.6c0,4.1 2.7,6.8 6.8,6.8s6.8,-2.7 6.8,-6.8L782.3,318.1l-8.2,-8.2c0,-1.4 -2.7,-4.1 -4.1,-4.1l-107.9,-107.9 -1.4,-1.4h-423.3v225.3c0,4.1 2.7,6.8 6.8,6.8zM663.6,305.8v-86l86,86h-86zM244.4,518.8c4.1,0 6.8,-2.7 6.8,-6.8v-64.2c0,-4.1 -2.7,-6.8 -6.8,-6.8s-6.8,2.7 -6.8,6.8v64.2c0,4.1 2.7,6.8 6.8,6.8zM244.4,558.4c4.1,0 6.8,-2.7 6.8,-6.8L251.2,532.5c0,-4.1 -2.7,-6.8 -6.8,-6.8s-6.8,2.7 -6.8,6.8v19.1c0,4.1 2.7,6.8 6.8,6.8zM782.3,740c0,-4.1 -2.7,-6.8 -6.8,-6.8s-6.8,2.7 -6.8,6.8v84.7L251.2,824.7L251.2,570.7c0,-4.1 -2.7,-6.8 -6.8,-6.8s-6.8,2.7 -6.8,6.8v267.6h544.8v-98.3z"
|
||||
android:fillColor="@color/sub_title_color"/>
|
||||
<path
|
||||
android:pathData="M460.1,434.2c-4.1,-1.4 -6.8,1.4 -8.2,5.5 -2.7,15 -12.3,27.3 -24.6,32.8 -24.6,9.6 -58.7,-8.2 -58.7,-9.6 -2.7,-1.4 -6.8,-1.4 -9.6,2.7 -1.4,2.7 -1.4,6.8 2.7,9.6 15,8.2 31.4,13.7 49.2,13.7 6.8,0 15,-1.4 21.8,-4.1 17.7,-8.2 30,-23.2 32.8,-42.3 0,-4.1 -1.4,-8.2 -5.5,-8.2zM584.4,490.2c5.5,2.7 10.9,2.7 17.7,2.7 16.4,-1.4 31.4,-6.8 45.1,-16.4 2.7,-2.7 4.1,-6.8 1.4,-9.6 -2.7,-2.7 -5.5,-4.1 -9.6,-1.4 -19.1,12.3 -35.5,16.4 -49.2,10.9 -21.8,-8.2 -31.4,-39.6 -31.4,-39.6 -1.4,-4.1 -5.5,-5.5 -8.2,-4.1 -4.1,1.4 -5.5,4.1 -4.1,8.2 0,2.7 9.6,38.2 38.2,49.2zM462.8,617.1c1.4,-1.4 36.9,-34.1 81.9,4.1 1.4,1.4 2.7,1.4 4.1,1.4 4.1,0 6.8,-2.7 6.8,-6.8 0,-2.7 -1.4,-4.1 -2.7,-5.5 -56,-45.1 -99.7,-2.7 -101,-2.7 -2.7,2.7 -2.7,6.8 0,9.6s8.2,2.7 10.9,0zM909.3,148.8c12.3,0 21.8,-9.6 21.8,-21.8s-9.6,-21.8 -21.8,-21.8c-12.3,0 -21.8,9.6 -21.8,21.8 1.4,12.3 10.9,21.8 21.8,21.8zM909.3,113.3c8.2,0 15,6.8 15,15s-6.8,15 -15,15c-8.2,0 -15,-6.8 -15,-15 1.4,-8.2 8.2,-15 15,-15zM73.7,296.3l13.7,8.2 -6.8,13.7c-1.4,2.7 0,5.5 2.7,6.8 2.7,1.4 5.5,0 6.8,-2.7l5.5,-12.3 12.3,8.2c1.4,0 1.4,1.4 2.7,1.4 2.7,0 5.5,-2.7 5.5,-5.5 0,-1.4 -1.4,-4.1 -2.7,-4.1l-13.7,-8.2 6.8,-13.7c1.4,-2.7 0,-5.5 -2.7,-6.8 -2.7,-1.4 -5.5,0 -6.8,2.7l-6.8,12.3 -10.9,-9.6c-2.7,-1.4 -5.5,-1.4 -6.8,1.4 -2.7,2.7 -1.4,6.8 1.4,8.2zM957.1,475.1l-19.1,-10.9 8.2,-20.5c1.4,-4.1 0,-6.8 -4.1,-9.6s-6.8,0 -9.6,4.1l-8.2,19.1 -17.7,-9.6c-2.7,-1.4 -6.8,0 -9.6,2.7 -1.4,2.7 0,6.8 2.7,9.6l19.1,10.9 -8.2,20.5c-1.4,4.1 0,6.8 4.1,9.6s6.8,0 9.6,-4.1l8.2,-19.1 17.7,9.6c2.7,1.4 6.8,0 9.6,-2.7s0,-8.2 -2.7,-9.6z"
|
||||
android:fillColor="@color/sub_title_color"/>
|
||||
</vector>
|
||||
7
app/src/main/res/drawable/indicator.xml
Normal file
7
app/src/main/res/drawable/indicator.xml
Normal file
@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<shape xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:shape="oval">
|
||||
<solid android:color="@color/color_84B1ED"/>
|
||||
<size android:height="5dp" android:width="5dp"/>
|
||||
|
||||
</shape>
|
||||
9
app/src/main/res/drawable/main_category_label.xml
Normal file
9
app/src/main/res/drawable/main_category_label.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<shape xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:shape="rectangle">
|
||||
<corners android:bottomLeftRadius="10dp" />
|
||||
<gradient
|
||||
android:endColor="@color/color_83c2f7"
|
||||
android:startColor="@color/color_96e6f2" />
|
||||
|
||||
</shape>
|
||||
6
app/src/main/res/drawable/oval.xml
Normal file
6
app/src/main/res/drawable/oval.xml
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<shape xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:shape="oval">
|
||||
<solid android:color="@color/color_main_view"/>
|
||||
|
||||
</shape>
|
||||
9
app/src/main/res/drawable/return_ffffff.xml
Normal file
9
app/src/main/res/drawable/return_ffffff.xml
Normal file
@ -0,0 +1,9 @@
|
||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:width="64dp"
|
||||
android:height="64dp"
|
||||
android:viewportWidth="1024"
|
||||
android:viewportHeight="1024">
|
||||
<path
|
||||
android:pathData="M154.5,469.3H981.3a42.7,42.7 0,1 1,0 85.3H154.5l300.7,266.9a42.7,42.7 0,1 1,-57.1 63.4l-384,-341.3a42.7,42.7 0,0 1,0 -63.4l384,-341.3a42.7,42.7 0,1 1,57.1 63.4L154.5,469.3z"
|
||||
android:fillColor="@color/white"/>
|
||||
</vector>
|
||||
6
app/src/main/res/drawable/selector_search.xml
Normal file
6
app/src/main/res/drawable/selector_search.xml
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<item android:drawable="@drawable/ic_search_true" android:state_selected="true" />
|
||||
<item android:drawable="@drawable/ic_search_false" />
|
||||
|
||||
</selector>
|
||||
7
app/src/main/res/drawable/shape_main.xml
Normal file
7
app/src/main/res/drawable/shape_main.xml
Normal file
@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<shape xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:shape="rectangle">
|
||||
<solid android:color="@color/color_83c2f7" />
|
||||
<corners android:radius="16dp"/>
|
||||
|
||||
</shape>
|
||||
7
app/src/main/res/drawable/sp_et_stoke.xml
Normal file
7
app/src/main/res/drawable/sp_et_stoke.xml
Normal file
@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<shape xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:shape="rectangle">
|
||||
<corners android:radius="16dp"/>
|
||||
<stroke android:width="2dp" android:color="@color/color_96e6f2"/>
|
||||
|
||||
</shape>
|
||||
6
app/src/main/res/drawable/status__like.xml
Normal file
6
app/src/main/res/drawable/status__like.xml
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<item android:drawable="@drawable/favorite_true" android:state_selected="true" />
|
||||
<item android:drawable="@drawable/favorite_false" />
|
||||
|
||||
</selector>
|
||||
6
app/src/main/res/drawable/status_favorite.xml
Normal file
6
app/src/main/res/drawable/status_favorite.xml
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<item android:drawable="@drawable/ic_favorite_red" android:state_selected="true" />
|
||||
<item android:drawable="@drawable/ic_stoke_favorite" />
|
||||
|
||||
</selector>
|
||||
6
app/src/main/res/drawable/status_home.xml
Normal file
6
app/src/main/res/drawable/status_home.xml
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<item android:drawable="@drawable/home_true" android:state_selected="true" />
|
||||
<item android:drawable="@drawable/home_false" />
|
||||
|
||||
</selector>
|
||||
6
app/src/main/res/drawable/status_set_ui_favorite.xml
Normal file
6
app/src/main/res/drawable/status_set_ui_favorite.xml
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<selector xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<item android:drawable="@drawable/ic_favorite_red" android:state_selected="true" />
|
||||
<item android:drawable="@drawable/ic_favorite_ffffff" />
|
||||
|
||||
</selector>
|
||||
7
app/src/main/res/drawable/tab_background.xml
Normal file
7
app/src/main/res/drawable/tab_background.xml
Normal file
@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<shape xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:shape="rectangle">
|
||||
<corners android:radius="16dp" />
|
||||
<solid android:color="@color/color_main_view" />
|
||||
|
||||
</shape>
|
||||
27
app/src/main/res/drawable/welcome_pb.xml
Normal file
27
app/src/main/res/drawable/welcome_pb.xml
Normal file
@ -0,0 +1,27 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
|
||||
<item android:id="@android:id/background">
|
||||
<shape>
|
||||
<corners android:radius="10dp" />
|
||||
<solid android:color="@color/sub_color" />
|
||||
</shape>
|
||||
</item>
|
||||
<item android:id="@android:id/progress">
|
||||
<clip>
|
||||
<shape>
|
||||
<corners android:radius="10dp" />
|
||||
<gradient
|
||||
android:angle="0"
|
||||
android:endColor="@color/color_96e6f2"
|
||||
android:centerColor="@color/color_96e6f2"
|
||||
android:startColor="@color/color_96e6f2" />
|
||||
</shape>
|
||||
</clip>
|
||||
</item>
|
||||
</layer-list>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
20
app/src/main/res/layout/ada_all.xml
Normal file
20
app/src/main/res/layout/ada_all.xml
Normal file
@ -0,0 +1,20 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:id="@+id/layout"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:orientation="vertical">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/wallpaper"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="100dp" />
|
||||
<View
|
||||
android:id="@+id/view_space"
|
||||
android:layout_width="wrap_content"
|
||||
android:visibility="gone"
|
||||
android:layout_below="@id/wallpaper"
|
||||
android:layout_height="80dp" />
|
||||
|
||||
|
||||
</RelativeLayout>
|
||||
28
app/src/main/res/layout/ada_favorite.xml
Normal file
28
app/src/main/res/layout/ada_favorite.xml
Normal file
@ -0,0 +1,28 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:id="@+id/layout"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:orientation="vertical">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/wallpaper"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="180dp" />
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/image_favorite"
|
||||
android:layout_width="50dp"
|
||||
android:layout_height="50dp"
|
||||
android:layout_alignParentEnd="true"
|
||||
android:layout_alignBottom="@id/wallpaper"
|
||||
android:padding="13dp"
|
||||
android:src="@drawable/status_favorite" />
|
||||
|
||||
<View
|
||||
android:id="@+id/view_space"
|
||||
android:layout_width="wrap_content"
|
||||
android:visibility="gone"
|
||||
android:layout_below="@id/wallpaper"
|
||||
android:layout_height="80dp" />
|
||||
</RelativeLayout>
|
||||
51
app/src/main/res/layout/ada_main.xml
Normal file
51
app/src/main/res/layout/ada_main.xml
Normal file
@ -0,0 +1,51 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
|
||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:orientation="vertical">
|
||||
|
||||
<androidx.cardview.widget.CardView
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="170dp"
|
||||
android:layout_marginStart="15dp"
|
||||
android:layout_marginEnd="15dp"
|
||||
android:layout_marginBottom="10dp"
|
||||
app:cardCornerRadius="10dp"
|
||||
app:cardElevation="0dp">
|
||||
|
||||
<androidx.constraintlayout.widget.ConstraintLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/preview"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:scaleType="centerCrop" />
|
||||
|
||||
<com.phone.wall.paper.tools.CustTv
|
||||
android:id="@+id/tv_class_name"
|
||||
android:layout_width="120dp"
|
||||
android:layout_height="26dp"
|
||||
android:background="@drawable/main_category_label"
|
||||
android:gravity="center"
|
||||
android:text="Experimental"
|
||||
android:textColor="@color/white"
|
||||
android:textSize="16sp"
|
||||
app:apply_font="true"
|
||||
app:layout_constraintEnd_toEndOf="parent"
|
||||
app:layout_constraintTop_toTopOf="parent" />
|
||||
|
||||
|
||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||
</androidx.cardview.widget.CardView>
|
||||
|
||||
<View
|
||||
android:id="@+id/view_space"
|
||||
android:layout_width="wrap_content"
|
||||
android:visibility="gone"
|
||||
android:layout_height="80dp" />
|
||||
|
||||
</LinearLayout>
|
||||
38
app/src/main/res/layout/frag_favorite.xml
Normal file
38
app/src/main/res/layout/frag_favorite.xml
Normal file
@ -0,0 +1,38 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:paddingTop="15dp">
|
||||
|
||||
<androidx.recyclerview.widget.RecyclerView
|
||||
android:id="@+id/list_recycler"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent" />
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/layout_no_data"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_centerInParent="true"
|
||||
android:orientation="vertical"
|
||||
android:visibility="gone">
|
||||
|
||||
<ImageView
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_gravity="center"
|
||||
android:src="@drawable/image_empty" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tv_title"
|
||||
android:layout_width="200dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginTop="15dp"
|
||||
android:gravity="center"
|
||||
android:lineSpacingExtra="4dp"
|
||||
android:text="@string/no_like_data"
|
||||
android:textColor="@color/sub_title_color"
|
||||
android:textSize="14sp" />
|
||||
</LinearLayout>
|
||||
|
||||
</RelativeLayout>
|
||||
24
app/src/main/res/layout/frag_main.xml
Normal file
24
app/src/main/res/layout/frag_main.xml
Normal file
@ -0,0 +1,24 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
xmlns:tools="http://schemas.android.com/tools"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:paddingTop="15dp"
|
||||
tools:context="com.phone.wall.paper.view.FragMain">
|
||||
|
||||
<androidx.recyclerview.widget.RecyclerView
|
||||
android:id="@+id/class_recycler"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content" />
|
||||
|
||||
|
||||
<ProgressBar
|
||||
android:id="@+id/loading_pb"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_centerInParent="true"
|
||||
android:indeterminateTint="@color/white" />
|
||||
|
||||
|
||||
</RelativeLayout>
|
||||
86
app/src/main/res/layout/frag_search.xml
Normal file
86
app/src/main/res/layout/frag_search.xml
Normal file
@ -0,0 +1,86 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:tools="http://schemas.android.com/tools"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:paddingTop="15dp">
|
||||
|
||||
<RelativeLayout
|
||||
android:id="@+id/et_parent"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginStart="15dp"
|
||||
android:layout_marginEnd="5dp"
|
||||
android:layout_toStartOf="@id/btn_search"
|
||||
android:background="@drawable/sp_et_stoke">
|
||||
|
||||
<EditText
|
||||
android:id="@+id/et"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="46dp"
|
||||
android:background="@color/color_0"
|
||||
android:hint="@string/please_input_keyword"
|
||||
android:imeOptions="actionSearch"
|
||||
android:inputType="text"
|
||||
android:maxLines="1"
|
||||
android:paddingStart="11dp"
|
||||
android:paddingEnd="10dp"
|
||||
android:textColorHint="@color/sub_title_color"
|
||||
android:textSize="16sp" />
|
||||
|
||||
</RelativeLayout>
|
||||
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/btn_search"
|
||||
android:layout_width="55dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignTop="@id/et_parent"
|
||||
android:layout_alignBottom="@id/et_parent"
|
||||
android:layout_alignParentEnd="true"
|
||||
android:paddingStart="15dp"
|
||||
android:layout_marginEnd="10dp"
|
||||
android:paddingTop="6dp"
|
||||
android:paddingEnd="15dp"
|
||||
android:paddingBottom="6dp"
|
||||
android:src="@drawable/ic_search_view" />
|
||||
|
||||
<androidx.recyclerview.widget.RecyclerView
|
||||
android:id="@+id/result_recycler"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:layout_below="@id/et_parent"
|
||||
android:layout_marginTop="10dp" />
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/empty_layout"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_centerInParent="true"
|
||||
android:gravity="center"
|
||||
android:orientation="vertical"
|
||||
android:visibility="gone">
|
||||
|
||||
<ImageView
|
||||
android:layout_width="100dp"
|
||||
android:layout_height="100dp"
|
||||
android:src="@drawable/img_no_result" />
|
||||
|
||||
<TextView
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginTop="12dp"
|
||||
android:text="@string/no_search_result"
|
||||
android:textColor="@color/sub_title_color" />
|
||||
</LinearLayout>
|
||||
|
||||
|
||||
<ProgressBar
|
||||
android:id="@+id/search_pb"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_centerInParent="true"
|
||||
android:indeterminateTint="@color/color_96e6f2"
|
||||
android:visibility="gone" />
|
||||
|
||||
</RelativeLayout>
|
||||
21
app/src/main/res/layout/item_tab.xml
Normal file
21
app/src/main/res/layout/item_tab.xml
Normal file
@ -0,0 +1,21 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:gravity="center"
|
||||
android:orientation="vertical">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/image_icon"
|
||||
android:layout_width="25dp"
|
||||
android:layout_height="25dp" />
|
||||
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/image_indicator"
|
||||
android:layout_width="5dp"
|
||||
android:layout_height="5dp"
|
||||
android:layout_marginTop="5dp"
|
||||
android:src="@drawable/indicator" />
|
||||
|
||||
</LinearLayout>
|
||||
91
app/src/main/res/layout/select_wallpaper_type.xml
Normal file
91
app/src/main/res/layout/select_wallpaper_type.xml
Normal file
@ -0,0 +1,91 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content">
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginStart="20dp"
|
||||
android:layout_marginEnd="20dp"
|
||||
android:background="@drawable/shape_main"
|
||||
android:orientation="vertical">
|
||||
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="54dp"
|
||||
android:gravity="center"
|
||||
android:id="@+id/layout_home"
|
||||
android:orientation="horizontal">
|
||||
|
||||
<ImageView
|
||||
android:layout_width="24dp"
|
||||
android:layout_height="24dp"
|
||||
android:src="@drawable/ic_home_wall" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/home"
|
||||
android:layout_width="150dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginStart="21dp"
|
||||
android:text="@string/type_home"
|
||||
android:textColor="@color/white"
|
||||
android:textSize="18sp" />
|
||||
</LinearLayout>
|
||||
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0.5dp"
|
||||
android:background="@color/white"/>
|
||||
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="54dp"
|
||||
android:gravity="center"
|
||||
android:id="@+id/layout_lock"
|
||||
android:orientation="horizontal">
|
||||
|
||||
<ImageView
|
||||
android:layout_width="24dp"
|
||||
android:layout_height="24dp"
|
||||
android:src="@drawable/ic_lock_wall" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/lock"
|
||||
android:layout_width="150dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginStart="22dp"
|
||||
android:text="@string/type_lock"
|
||||
android:textColor="@color/white"
|
||||
android:textSize="18sp" />
|
||||
|
||||
</LinearLayout>
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0.5dp"
|
||||
android:background="@color/white"/>
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="54dp"
|
||||
android:gravity="center"
|
||||
android:id="@+id/layout_both"
|
||||
android:orientation="horizontal">
|
||||
|
||||
<ImageView
|
||||
android:layout_width="24dp"
|
||||
android:layout_height="24dp"
|
||||
android:src="@drawable/ic_both" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/both"
|
||||
android:layout_width="150dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginStart="22dp"
|
||||
android:text="@string/type_both"
|
||||
android:textColor="@color/white"
|
||||
android:textSize="18sp" />
|
||||
</LinearLayout>
|
||||
</LinearLayout>
|
||||
</FrameLayout>
|
||||
43
app/src/main/res/layout/ui_all_list.xml
Normal file
43
app/src/main/res/layout/ui_all_list.xml
Normal file
@ -0,0 +1,43 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
xmlns:tools="http://schemas.android.com/tools"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:paddingTop="10dp"
|
||||
tools:context="com.phone.wall.paper.view.AllList">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/imageview_back"
|
||||
android:layout_width="45dp"
|
||||
android:layout_height="45dp"
|
||||
android:layout_gravity="center"
|
||||
android:layout_marginStart="15dp"
|
||||
android:layout_marginTop="30dp"
|
||||
android:padding="13dp"
|
||||
android:src="@drawable/ic_return_white"
|
||||
app:layout_constraintLeft_toLeftOf="parent"
|
||||
app:layout_constraintTop_toTopOf="parent" />
|
||||
|
||||
<com.phone.wall.paper.tools.CustTv
|
||||
android:id="@+id/name"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignTop="@id/imageview_back"
|
||||
android:layout_alignBottom="@id/imageview_back"
|
||||
android:layout_centerHorizontal="true"
|
||||
android:gravity="center"
|
||||
android:text="@string/app_name"
|
||||
android:textColor="@color/text_color"
|
||||
android:textSize="17sp"
|
||||
app:apply_font="true" />
|
||||
|
||||
<androidx.recyclerview.widget.RecyclerView
|
||||
android:id="@+id/list"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginTop="15dp"
|
||||
android:layout_below="@id/imageview_back" />
|
||||
|
||||
|
||||
</RelativeLayout>
|
||||
29
app/src/main/res/layout/ui_main.xml
Normal file
29
app/src/main/res/layout/ui_main.xml
Normal file
@ -0,0 +1,29 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
xmlns:tools="http://schemas.android.com/tools"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:orientation="vertical"
|
||||
android:paddingTop="30dp"
|
||||
tools:context="com.phone.wall.paper.view.Main">
|
||||
|
||||
<androidx.viewpager2.widget.ViewPager2
|
||||
android:id="@+id/viewpager2"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent" />
|
||||
|
||||
<com.google.android.material.tabs.TabLayout
|
||||
android:id="@+id/tab"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="55dp"
|
||||
android:layout_marginStart="25dp"
|
||||
android:layout_marginEnd="25dp"
|
||||
android:layout_marginBottom="20dp"
|
||||
android:layout_alignParentBottom="true"
|
||||
app:tabIndicator="@null"
|
||||
android:background="@drawable/tab_background"
|
||||
app:tabIndicatorHeight="0dp" />
|
||||
|
||||
|
||||
</RelativeLayout>
|
||||
124
app/src/main/res/layout/ui_set_wall.xml
Normal file
124
app/src/main/res/layout/ui_set_wall.xml
Normal file
@ -0,0 +1,124 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
xmlns:tools="http://schemas.android.com/tools"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
tools:context="com.phone.wall.paper.view.SetWall">
|
||||
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/imageview_preview"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:scaleType="centerCrop" />
|
||||
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/imageview_back"
|
||||
android:layout_width="45dp"
|
||||
android:layout_height="45dp"
|
||||
android:layout_gravity="center"
|
||||
android:layout_marginStart="15dp"
|
||||
android:layout_marginTop="42dp"
|
||||
android:background="@drawable/oval"
|
||||
android:padding="13dp"
|
||||
android:src="@drawable/return_ffffff"
|
||||
app:layout_constraintLeft_toLeftOf="parent"
|
||||
app:layout_constraintTop_toTopOf="parent" />
|
||||
|
||||
|
||||
<com.phone.wall.paper.tools.CustTv
|
||||
android:id="@+id/tv_content"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginBottom="40dp"
|
||||
android:background="@drawable/image_describe"
|
||||
android:gravity="center"
|
||||
android:minHeight="40dp"
|
||||
android:padding="10dp"
|
||||
android:text="@string/app_name"
|
||||
android:textColor="@color/white"
|
||||
android:textSize="13sp"
|
||||
app:apply_font="true"
|
||||
app:layout_constraintBottom_toBottomOf="parent"
|
||||
app:layout_constraintLeft_toLeftOf="parent"
|
||||
app:layout_constraintRight_toRightOf="parent" />
|
||||
|
||||
<RelativeLayout
|
||||
android:id="@+id/layout_set"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginBottom="15dp"
|
||||
android:background="@drawable/oval"
|
||||
app:layout_constraintBottom_toBottomOf="parent"
|
||||
app:layout_constraintBottom_toTopOf="@id/tv_content"
|
||||
app:layout_constraintLeft_toLeftOf="parent"
|
||||
app:layout_constraintRight_toRightOf="parent">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/button_set"
|
||||
android:layout_width="46dp"
|
||||
android:layout_height="46dp"
|
||||
|
||||
android:layout_centerInParent="true"
|
||||
android:padding="13dp"
|
||||
android:src="@drawable/ic_set_wallpaper" />
|
||||
|
||||
<ProgressBar
|
||||
android:id="@+id/pb_set"
|
||||
android:layout_width="46dp"
|
||||
android:layout_height="46dp"
|
||||
android:layout_centerInParent="true"
|
||||
android:indeterminateTint="@color/white"
|
||||
android:padding="13dp"
|
||||
android:visibility="gone" />
|
||||
</RelativeLayout>
|
||||
|
||||
<RelativeLayout
|
||||
android:id="@+id/layout_download"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_marginEnd="26dp"
|
||||
android:background="@drawable/oval"
|
||||
app:layout_constraintBottom_toBottomOf="@id/layout_set"
|
||||
app:layout_constraintRight_toLeftOf="@id/layout_set"
|
||||
app:layout_constraintTop_toTopOf="@id/layout_set">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/image_download"
|
||||
android:layout_width="46dp"
|
||||
android:layout_height="46dp"
|
||||
android:layout_centerInParent="true"
|
||||
android:padding="13dp"
|
||||
android:src="@drawable/ic_download" />
|
||||
|
||||
<ProgressBar
|
||||
android:id="@+id/pb_download"
|
||||
android:layout_width="46dp"
|
||||
android:layout_height="46dp"
|
||||
android:layout_centerInParent="true"
|
||||
android:indeterminateTint="@color/white"
|
||||
android:padding="13dp"
|
||||
android:visibility="gone" />
|
||||
</RelativeLayout>
|
||||
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/image_favorite"
|
||||
android:layout_width="46dp"
|
||||
android:layout_height="46dp"
|
||||
android:layout_alignParentEnd="true"
|
||||
android:layout_centerInParent="true"
|
||||
android:layout_marginStart="26dp"
|
||||
android:background="@drawable/oval"
|
||||
android:padding="13dp"
|
||||
android:paddingTop="10dp"
|
||||
android:paddingBottom="10dp"
|
||||
android:src="@drawable/status_set_ui_favorite"
|
||||
app:layout_constraintBottom_toBottomOf="@id/layout_set"
|
||||
app:layout_constraintLeft_toRightOf="@id/layout_set"
|
||||
app:layout_constraintTop_toTopOf="@id/layout_set" />
|
||||
|
||||
|
||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||
57
app/src/main/res/layout/ui_welcome.xml
Normal file
57
app/src/main/res/layout/ui_welcome.xml
Normal file
@ -0,0 +1,57 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
xmlns:tools="http://schemas.android.com/tools"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
tools:context="com.phone.wall.paper.view.Welcome">
|
||||
|
||||
|
||||
<androidx.constraintlayout.utils.widget.ImageFilterView
|
||||
android:id="@+id/imageview_logo"
|
||||
android:layout_width="94dp"
|
||||
android:layout_height="94dp"
|
||||
android:layout_centerHorizontal="true"
|
||||
android:layout_marginTop="260dp"
|
||||
android:src="@mipmap/icon"
|
||||
app:roundPercent="0.2" />
|
||||
|
||||
<com.phone.wall.paper.tools.CustTv
|
||||
android:id="@+id/textview_appname"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_below="@id/imageview_logo"
|
||||
android:layout_centerHorizontal="true"
|
||||
android:layout_marginTop="19dp"
|
||||
android:text="@string/app_name"
|
||||
android:textColor="@color/text_color"
|
||||
android:textSize="22sp"
|
||||
app:apply_font="true" />
|
||||
|
||||
|
||||
<ProgressBar
|
||||
android:id="@+id/progressbar"
|
||||
style="?android:attr/progressBarStyleHorizontal"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="15dp"
|
||||
android:layout_alignParentBottom="true"
|
||||
android:layout_centerHorizontal="true"
|
||||
android:layout_marginStart="33dp"
|
||||
android:layout_marginEnd="33dp"
|
||||
android:layout_marginBottom="40dp"
|
||||
android:max="100"
|
||||
android:progress="1"
|
||||
android:progressDrawable="@drawable/welcome_pb" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tv_progress"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignTop="@id/progressbar"
|
||||
android:layout_centerHorizontal="true"
|
||||
android:text="1%"
|
||||
android:textColor="@color/text_color"
|
||||
android:textSize="12sp" />
|
||||
|
||||
|
||||
</RelativeLayout>
|
||||
BIN
app/src/main/res/mipmap-xxxhdpi/icon.png
Normal file
BIN
app/src/main/res/mipmap-xxxhdpi/icon.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 205 KiB |
BIN
app/src/main/res/mipmap-xxxhdpi/im_placeholder.png
Normal file
BIN
app/src/main/res/mipmap-xxxhdpi/im_placeholder.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 506 KiB |
6
app/src/main/res/values/attrs.xml
Normal file
6
app/src/main/res/values/attrs.xml
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<resources>
|
||||
<declare-styleable name="CustomeTv">
|
||||
<attr name="apply_font" format="boolean"/>
|
||||
</declare-styleable>
|
||||
</resources>
|
||||
14
app/src/main/res/values/colors.xml
Normal file
14
app/src/main/res/values/colors.xml
Normal file
@ -0,0 +1,14 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<resources>
|
||||
<color name="black">#FF000000</color>
|
||||
<color name="white">#FFFFFFFF</color>
|
||||
<color name="favorite_true">#C03B3B</color>
|
||||
<color name="sub_title_color">#C9C7C7</color>
|
||||
<color name="sub_color">#979696</color>
|
||||
<color name="color_0">#00000000</color>
|
||||
<color name="color_main_view">#3383c2f7</color>
|
||||
<color name="text_color">#1F1E1E</color>
|
||||
<color name="color_96e6f2">#96e6f2</color>
|
||||
<color name="color_83c2f7">#83c2f7</color>
|
||||
<color name="color_84B1ED">#84B1ED</color>
|
||||
</resources>
|
||||
18
app/src/main/res/values/strings.xml
Normal file
18
app/src/main/res/values/strings.xml
Normal file
@ -0,0 +1,18 @@
|
||||
<resources>
|
||||
<string name="app_name">Phone Wallpaper</string>
|
||||
<string name="set_fail">Failed to set wallpaper, please try again</string>
|
||||
<string name="set_success">Set wallpaper successfully</string>
|
||||
<string name="download_fail">Download failed</string>
|
||||
|
||||
<string name="save_success">Save to album successfully</string>
|
||||
<string name="save_fail">Save to album fail</string>
|
||||
|
||||
<string name="type_home">Home screen</string>
|
||||
<string name="type_lock">Lock screen</string>
|
||||
<string name="type_both">Both</string>
|
||||
<string name="no_like_data">You haven not collected any wallpapers yet</string>
|
||||
<string name="please_input_keyword">Please enter a search term</string>
|
||||
<string name="no_search_result">No dataBean found</string>
|
||||
|
||||
<string name="tv_wel_progress">%d%%</string>
|
||||
</resources>
|
||||
15
app/src/main/res/values/themes.xml
Normal file
15
app/src/main/res/values/themes.xml
Normal file
@ -0,0 +1,15 @@
|
||||
<resources xmlns:tools="http://schemas.android.com/tools">
|
||||
<!-- Base application theme. -->
|
||||
<style name="Base.Theme.HDWallpaper" parent="Theme.Material3.DayNight.NoActionBar">
|
||||
<!-- Customize your light theme here. -->
|
||||
<!-- <item name="colorPrimary">@color/my_light_primary</item> -->
|
||||
</style>
|
||||
|
||||
<style name="Theme.Wallpaper" parent="Base.Theme.HDWallpaper" >
|
||||
<!-- <item name="android:statusBarColor">@color/color_main</item>-->
|
||||
<item name="colorOnSecondary">@color/white</item>
|
||||
</style>
|
||||
<style name="Theme.WelWallpaper" parent="Base.Theme.HDWallpaper" >
|
||||
<!-- <item name="android:windowBackground">@drawable/bg_welcome</item>-->
|
||||
</style>
|
||||
</resources>
|
||||
13
app/src/main/res/xml/backup_rules.xml
Normal file
13
app/src/main/res/xml/backup_rules.xml
Normal file
@ -0,0 +1,13 @@
|
||||
<?xml version="1.0" encoding="utf-8"?><!--
|
||||
Sample backup rules file; uncomment and customize as necessary.
|
||||
See https://developer.android.com/guide/topics/dataBean/autobackup
|
||||
for details.
|
||||
Note: This file is ignored for devices older that API 31
|
||||
See https://developer.android.com/about/versions/12/backup-restore
|
||||
-->
|
||||
<full-backup-content>
|
||||
<!--
|
||||
<include domain="sharedpref" path="."/>
|
||||
<exclude domain="sharedpref" path="device.xml"/>
|
||||
-->
|
||||
</full-backup-content>
|
||||
19
app/src/main/res/xml/data_extraction_rules.xml
Normal file
19
app/src/main/res/xml/data_extraction_rules.xml
Normal file
@ -0,0 +1,19 @@
|
||||
<?xml version="1.0" encoding="utf-8"?><!--
|
||||
Sample dataBean extraction rules file; uncomment and customize as necessary.
|
||||
See https://developer.android.com/about/versions/12/backup-restore#xml-changes
|
||||
for details.
|
||||
-->
|
||||
<dataBean-extraction-rules>
|
||||
<cloud-backup>
|
||||
<!-- TODO: Use <include> and <exclude> to control what is backed up.
|
||||
<include .../>
|
||||
<exclude .../>
|
||||
-->
|
||||
</cloud-backup>
|
||||
<!--
|
||||
<device-transfer>
|
||||
<include .../>
|
||||
<exclude .../>
|
||||
</device-transfer>
|
||||
-->
|
||||
</dataBean-extraction-rules>
|
||||
6
app/src/main/res/xml/net.xml
Normal file
6
app/src/main/res/xml/net.xml
Normal file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<network-security-config xmlns:tools="http://schemas.android.com/tools">
|
||||
<domain-config cleartextTrafficPermitted="true">
|
||||
<domain tools:ignore="NetworkSecurityConfig">mobile-server.lux-ad.com</domain>
|
||||
</domain-config>
|
||||
</network-security-config>
|
||||
@ -0,0 +1,17 @@
|
||||
package com.free.life.wallpaper;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
/**
|
||||
* Example local unit live, which will execute on the development machine (host).
|
||||
*
|
||||
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
||||
*/
|
||||
public class ExampleUnitTest {
|
||||
@Test
|
||||
public void addition_isCorrect() {
|
||||
assertEquals(4, 2 + 2);
|
||||
}
|
||||
}
|
||||
14
build.gradle.kts
Normal file
14
build.gradle.kts
Normal file
@ -0,0 +1,14 @@
|
||||
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
||||
plugins {
|
||||
id("com.android.application") version "8.10.1" apply false
|
||||
id("org.jetbrains.kotlin.android") version "2.0.0" apply false
|
||||
kotlin("kapt") version "2.0.0"
|
||||
id("com.google.gms.google-services") version "4.4.2" apply false
|
||||
id ("com.google.firebase.crashlytics") version "3.0.2" apply false
|
||||
}
|
||||
|
||||
buildscript {
|
||||
dependencies {
|
||||
classpath("io.objectbox:objectbox-gradle-plugin:4.1.0")
|
||||
}
|
||||
}
|
||||
21
gradle.properties
Normal file
21
gradle.properties
Normal file
@ -0,0 +1,21 @@
|
||||
# Project-wide Gradle settings.
|
||||
# IDE (e.g. Android Studio) users:
|
||||
# Gradle settings configured through the IDE *will override*
|
||||
# any settings specified in this file.
|
||||
# For more details on how to configure your build environment visit
|
||||
# http://www.gradle.org/docs/current/userguide/build_environment.html
|
||||
# Specifies the JVM arguments used for the daemon process.
|
||||
# The setting is particularly useful for tweaking memory settings.
|
||||
org.gradle.jvmargs=-Xmx4096m -Dfile.encoding=UTF-8
|
||||
# When configured, Gradle will run in incubating parallel mode.
|
||||
# This option should only be used with decoupled projects. More details, visit
|
||||
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
|
||||
# org.gradle.parallel=true
|
||||
# AndroidX package structure to make it clearer which packages are bundled with the
|
||||
# Android operating system, and which are packaged with your app's APK
|
||||
# https://developer.android.com/topic/libraries/support-library/androidx-rn
|
||||
android.useAndroidX=true
|
||||
# Enables namespacing of each library's R class so that its R class includes only the
|
||||
# resources declared in the library itself and none from the library's dependencies,
|
||||
# thereby reducing the size of the R class for that library
|
||||
android.nonTransitiveRClass=true
|
||||
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
Binary file not shown.
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user