Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Y
YGOMobile
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Packages
Packages
List
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issues
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
fallenstardust
YGOMobile
Commits
c101d738
Commit
c101d738
authored
Jul 04, 2025
by
fallenstardust
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
调试根据本地和云备份更新时间进行同步卡组的逻辑
parent
46f7285a
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
86 additions
and
22 deletions
+86
-22
mobile/src/main/java/cn/garymb/ygomobile/deck_square/DeckSquareApiUtil.java
...va/cn/garymb/ygomobile/deck_square/DeckSquareApiUtil.java
+20
-12
mobile/src/main/java/cn/garymb/ygomobile/deck_square/DeckSquareFileUtil.java
...a/cn/garymb/ygomobile/deck_square/DeckSquareFileUtil.java
+23
-9
mobile/src/main/java/cn/garymb/ygomobile/ui/adapters/DeckListAdapter.java
...java/cn/garymb/ygomobile/ui/adapters/DeckListAdapter.java
+16
-0
mobile/src/main/java/cn/garymb/ygomobile/ui/cards/DeckManagerFragment.java
...ava/cn/garymb/ygomobile/ui/cards/DeckManagerFragment.java
+1
-1
mobile/src/main/res/drawable/baseline_more_time_24.xml
mobile/src/main/res/drawable/baseline_more_time_24.xml
+9
-0
mobile/src/main/res/layout/item_deck_list_swipe.xml
mobile/src/main/res/layout/item_deck_list_swipe.xml
+17
-0
No files found.
mobile/src/main/java/cn/garymb/ygomobile/deck_square/DeckSquareApiUtil.java
View file @
c101d738
package
cn.garymb.ygomobile.deck_square
;
package
cn.garymb.ygomobile.deck_square
;
import
android.annotation.SuppressLint
;
import
android.widget.Toast
;
import
android.widget.Toast
;
import
androidx.annotation.Nullable
;
import
com.google.gson.Gson
;
import
com.google.gson.Gson
;
import
java.io.File
;
import
java.io.File
;
import
java.io.IOException
;
import
java.io.IOException
;
import
java.text.SimpleDateFormat
;
import
java.time.LocalDateTime
;
import
java.time.LocalDateTime
;
import
java.time.ZoneOffset
;
import
java.time.ZoneOffset
;
import
java.util.Date
;
import
java.util.HashMap
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Locale
;
import
java.util.Map
;
import
java.util.Map
;
import
java.util.TimeZone
;
import
cn.garymb.ygomobile.AppsSettings
;
import
cn.garymb.ygomobile.AppsSettings
;
import
cn.garymb.ygomobile.Constants
;
import
cn.garymb.ygomobile.Constants
;
...
@@ -461,7 +468,7 @@ public class DeckSquareApiUtil {
...
@@ -461,7 +468,7 @@ public class DeckSquareApiUtil {
// 遍历本地卡组,处理同名卡组的情况
// 遍历本地卡组,处理同名卡组的情况
for
(
MyDeckItem
localDeck
:
localDecks
)
{
for
(
MyDeckItem
localDeck
:
localDecks
)
{
String
localDeckName
=
localDeck
.
getDeckName
().
replace
(
Constants
.
YDK_FILE_EX
,
""
);
String
localDeckName
=
localDeck
.
getDeckName
().
replace
(
Constants
.
YDK_FILE_EX
,
""
);
localDeck
.
setDeckName
(
localDeckName
);
//移除.ydk扩展名后需要修改lockDeck记录的卡组名,以防上传时候把.ydk带进去
boolean
foundOnlineDeck
=
false
;
boolean
foundOnlineDeck
=
false
;
for
(
MyOnlineDeckDetail
onlineDeck
:
onlineDecks
)
{
for
(
MyOnlineDeckDetail
onlineDeck
:
onlineDecks
)
{
String
onlineDeckName
=
onlineDeck
.
getDeckName
().
replace
(
Constants
.
YDK_FILE_EX
,
""
);
String
onlineDeckName
=
onlineDeck
.
getDeckName
().
replace
(
Constants
.
YDK_FILE_EX
,
""
);
...
@@ -483,10 +490,10 @@ public class DeckSquareApiUtil {
...
@@ -483,10 +490,10 @@ public class DeckSquareApiUtil {
if
(
onlineUpdateDate
!=
null
&&
onlineUpdateDate
.
compareTo
(
localUpdateDate
)
>
0
)
{
if
(
onlineUpdateDate
!=
null
&&
onlineUpdateDate
.
compareTo
(
localUpdateDate
)
>
0
)
{
// 在线卡组更新时间更晚,下载在线卡组覆盖本地卡组
// 在线卡组更新时间更晚,下载在线卡组覆盖本地卡组
LogUtil
.
w
(
"seesee下载"
,
localDeckName
+
"//"
+
onlineDeckName
);
LogUtil
.
w
(
"seesee下载"
,
localDeckName
+
"//"
+
onlineDeckName
);
onlineDeck
.
setDeckName
(
onlineDeckName
);
String
localPath
=
localDeck
.
getDeckPath
().
replace
(
localDeckName
+
Constants
.
YDK_FILE_EX
,
""
);
//直接传入localDeck.getDeckPath()会包含卡组名.ydk,会导致和onlinedeck.getDeckName重复拼接文件路径
downloadOnlineDeck
(
onlineDeck
,
local
Deck
.
getDeckPath
(
));
downloadOnlineDeck
(
onlineDeck
,
local
Path
,
Long
.
valueOf
(
onlineDeck
.
getDeckUpdateDate
()
));
}
else
{
}
else
{
LogUtil
.
w
(
"seesee上传"
,
localDeckName
+
"//"
+
onlineDeckName
);
LogUtil
.
w
(
"seesee上传"
,
localDeckName
+
"//"
+
onlineDeckName
);
// 本地卡组更新时间更晚,上传本地卡组覆盖在线卡组
// 本地卡组更新时间更晚,上传本地卡组覆盖在线卡组
uploadLocalDeck
(
localDeck
,
onlineDeck
.
getDeckId
(),
loginToken
);
uploadLocalDeck
(
localDeck
,
onlineDeck
.
getDeckId
(),
loginToken
);
}
}
...
@@ -494,7 +501,7 @@ public class DeckSquareApiUtil {
...
@@ -494,7 +501,7 @@ public class DeckSquareApiUtil {
}
}
}
}
// 本地卡组在在线列表中不存在,直接上传
// 本地卡组在在线列表中不存在,
则需要获取新的deckid来
直接上传
if
(!
foundOnlineDeck
)
{
if
(!
foundOnlineDeck
)
{
DeckFile
deckFile
=
new
DeckFile
(
localDeckName
,
new
File
(
localDeck
.
getDeckPath
()),
DeckType
.
ServerType
.
MY_SQUARE
,
localDeck
.
getDeckId
());
DeckFile
deckFile
=
new
DeckFile
(
localDeckName
,
new
File
(
localDeck
.
getDeckPath
()),
DeckType
.
ServerType
.
MY_SQUARE
,
localDeck
.
getDeckId
());
deckFile
.
setName
(
localDeckName
);
deckFile
.
setName
(
localDeckName
);
...
@@ -506,14 +513,14 @@ public class DeckSquareApiUtil {
...
@@ -506,14 +513,14 @@ public class DeckSquareApiUtil {
// 处理只存在于在线的卡组(即本地没有同名卡组)
// 处理只存在于在线的卡组(即本地没有同名卡组)
for
(
MyOnlineDeckDetail
onlineDeck
:
onlineDecks
)
{
for
(
MyOnlineDeckDetail
onlineDeck
:
onlineDecks
)
{
if
(!
onlineDeckProcessed
.
get
(
onlineDeck
.
getDeckName
()))
{
if
(!
onlineDeckProcessed
.
get
(
onlineDeck
.
getDeckName
()))
{
downloadMissingDeckToLocal
(
onlineDeck
);
downloadMissingDeckToLocal
(
onlineDeck
,
Long
.
valueOf
(
onlineDeck
.
getDeckUploadDate
())
);
}
}
}
}
return
true
;
return
true
;
}
}
private
static
boolean
downloadMissingDeckToLocal
(
MyOnlineDeckDetail
onlineDeck
)
{
private
static
boolean
downloadMissingDeckToLocal
(
MyOnlineDeckDetail
onlineDeck
,
Long
onlineUpdateDate
)
{
try
{
try
{
// 根据卡组ID查询在线卡组详情
// 根据卡组ID查询在线卡组详情
DownloadDeckResponse
deckResponse
=
DeckSquareApiUtil
.
getDeckById
(
onlineDeck
.
getDeckId
());
DownloadDeckResponse
deckResponse
=
DeckSquareApiUtil
.
getDeckById
(
onlineDeck
.
getDeckId
());
...
@@ -542,7 +549,7 @@ public class DeckSquareApiUtil {
...
@@ -542,7 +549,7 @@ public class DeckSquareApiUtil {
String
filePath
=
deckDirectory
+
"/"
+
fileName
;
String
filePath
=
deckDirectory
+
"/"
+
fileName
;
// 保存在线卡组到本地
// 保存在线卡组到本地
boolean
saved
=
DeckSquareFileUtil
.
saveFileToPath
(
deckDirectory
,
fileName
,
deckResponse
.
getData
().
getDeckYdk
());
boolean
saved
=
DeckSquareFileUtil
.
saveFileToPath
(
deckDirectory
,
fileName
,
deckResponse
.
getData
().
getDeckYdk
()
,
onlineUpdateDate
);
if
(!
saved
)
{
if
(!
saved
)
{
LogUtil
.
e
(
TAG
,
"downloadMissingDeckToLocal-Failed to save deck file: "
+
filePath
);
LogUtil
.
e
(
TAG
,
"downloadMissingDeckToLocal-Failed to save deck file: "
+
filePath
);
return
false
;
return
false
;
...
@@ -566,7 +573,7 @@ public class DeckSquareApiUtil {
...
@@ -566,7 +573,7 @@ public class DeckSquareApiUtil {
}
}
}
}
private
static
boolean
downloadOnlineDeck
(
MyOnlineDeckDetail
onlineDeck
,
String
localPath
)
{
private
static
boolean
downloadOnlineDeck
(
MyOnlineDeckDetail
onlineDeck
,
String
localPath
,
Long
onlineUpdateDate
)
{
try
{
try
{
// 根据卡组ID查询在线卡组详情
// 根据卡组ID查询在线卡组详情
DownloadDeckResponse
deckResponse
=
DeckSquareApiUtil
.
getDeckById
(
onlineDeck
.
getDeckId
());
DownloadDeckResponse
deckResponse
=
DeckSquareApiUtil
.
getDeckById
(
onlineDeck
.
getDeckId
());
...
@@ -577,13 +584,14 @@ public class DeckSquareApiUtil {
...
@@ -577,13 +584,14 @@ public class DeckSquareApiUtil {
// 保存在线卡组到本地
// 保存在线卡组到本地
boolean
saved
=
DeckSquareFileUtil
.
saveFileToPath
(
localPath
,
onlineDeck
.
getDeckName
(),
deckResponse
.
getData
().
getDeckYdk
());
String
fileName
=
onlineDeck
.
getDeckName
()
+
Constants
.
YDK_FILE_EX
;
boolean
saved
=
DeckSquareFileUtil
.
saveFileToPath
(
localPath
,
fileName
,
deckResponse
.
getData
().
getDeckYdk
(),
onlineUpdateDate
);
if
(!
saved
)
{
if
(!
saved
)
{
LogUtil
.
e
(
TAG
,
"downloadOnlineDeck-Failed to save deck file: "
+
localPath
);
LogUtil
.
e
(
TAG
,
"downloadOnlineDeck-Failed to save deck file: "
+
fileName
);
return
false
;
return
false
;
}
}
LogUtil
.
i
(
TAG
,
"Deck updated: "
+
localPath
);
LogUtil
.
i
(
TAG
,
"Deck updated: "
+
fileName
);
return
true
;
return
true
;
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
LogUtil
.
e
(
TAG
,
"Error downloading deck: "
+
e
.
getMessage
());
LogUtil
.
e
(
TAG
,
"Error downloading deck: "
+
e
.
getMessage
());
...
...
mobile/src/main/java/cn/garymb/ygomobile/deck_square/DeckSquareFileUtil.java
View file @
c101d738
...
@@ -201,23 +201,37 @@ public class DeckSquareFileUtil {
...
@@ -201,23 +201,37 @@ public class DeckSquareFileUtil {
return
content
;
return
content
;
}
}
public
static
boolean
saveFileToPath
(
String
path
,
String
fileName
,
String
content
)
{
/**
* 保存文件到指定路径,并设置指定的最后修改时间
* @param path 保存路径
* @param fileName 文件名
* @param content 文件内容
* @param modificationTime 期望的最后修改时间(毫秒时间戳)
* @return 保存是否成功
*/
public
static
boolean
saveFileToPath
(
String
path
,
String
fileName
,
String
content
,
long
modificationTime
)
{
try
{
try
{
//
Create file object
//
创建文件对象
File
file
=
new
File
(
path
,
fileName
);
File
file
=
new
File
(
path
,
fileName
);
// Create file output stream
// 创建文件输出流
FileOutputStream
fos
=
new
FileOutputStream
(
file
);
try
(
FileOutputStream
fos
=
new
FileOutputStream
(
file
))
{
// 写入内容
// Write content
fos
.
write
(
content
.
getBytes
());
fos
.
write
(
content
.
getBytes
());
fos
.
flush
();
fos
.
flush
();
fos
.
close
();
}
// 设置指定的最后修改时间
boolean
timeSet
=
file
.
setLastModified
(
modificationTime
);
if
(!
timeSet
)
{
LogUtil
.
w
(
TAG
,
"设置文件修改时间失败: "
+
file
.
getPath
());
}
return
true
;
}
catch
(
IOException
e
)
{
}
catch
(
IOException
e
)
{
LogUtil
.
e
(
TAG
,
"保存文件失败"
,
e
);
LogUtil
.
e
(
TAG
,
"保存文件失败"
,
e
);
return
false
;
return
false
;
}
}
return
true
;
}
}
...
...
mobile/src/main/java/cn/garymb/ygomobile/ui/adapters/DeckListAdapter.java
View file @
c101d738
...
@@ -12,8 +12,12 @@ import android.widget.TextView;
...
@@ -12,8 +12,12 @@ import android.widget.TextView;
import
com.chad.library.adapter.base.BaseQuickAdapter
;
import
com.chad.library.adapter.base.BaseQuickAdapter
;
import
com.chad.library.adapter.base.listener.OnItemClickListener
;
import
com.chad.library.adapter.base.listener.OnItemClickListener
;
import
java.text.SimpleDateFormat
;
import
java.util.ArrayList
;
import
java.util.ArrayList
;
import
java.util.Date
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Locale
;
import
java.util.TimeZone
;
import
cn.garymb.ygomobile.bean.Deck
;
import
cn.garymb.ygomobile.bean.Deck
;
import
cn.garymb.ygomobile.bean.DeckInfo
;
import
cn.garymb.ygomobile.bean.DeckInfo
;
...
@@ -70,6 +74,15 @@ public class DeckListAdapter<T extends TextSelect> extends BaseQuickAdapter<T, D
...
@@ -70,6 +74,15 @@ public class DeckListAdapter<T extends TextSelect> extends BaseQuickAdapter<T, D
mContext
=
context
;
mContext
=
context
;
}
}
/**
* 将时间戳转换为 ISO 8601 格式的时间字符串
*/
@SuppressLint
(
"SimpleDateFormat"
)
public
static
String
convertMillisToIsoString
(
long
timeMillis
)
{
SimpleDateFormat
sdf
=
new
SimpleDateFormat
(
"yyyy-MM-dd'T'HH:mm:ss"
,
Locale
.
CHINA
);
sdf
.
setTimeZone
(
TimeZone
.
getTimeZone
(
"UTC"
));
return
sdf
.
format
(
new
Date
(
timeMillis
));
}
@SuppressLint
(
"ResourceType"
)
@SuppressLint
(
"ResourceType"
)
@Override
@Override
...
@@ -109,6 +122,7 @@ public class DeckListAdapter<T extends TextSelect> extends BaseQuickAdapter<T, D
...
@@ -109,6 +122,7 @@ public class DeckListAdapter<T extends TextSelect> extends BaseQuickAdapter<T, D
holder
.
side
.
setText
(
"-"
);
holder
.
side
.
setText
(
"-"
);
holder
.
side
.
setTextColor
(
Color
.
RED
);
holder
.
side
.
setTextColor
(
Color
.
RED
);
}
}
holder
.
file_time
.
setText
(
convertMillisToIsoString
(
deckFile
.
getDate
()));
if
(
deckFile
.
getTypeName
().
equals
(
YGOUtil
.
s
(
R
.
string
.
category_pack
))
||
deckFile
.
getPath
().
contains
(
"cacheDeck"
))
{
if
(
deckFile
.
getTypeName
().
equals
(
YGOUtil
.
s
(
R
.
string
.
category_pack
))
||
deckFile
.
getPath
().
contains
(
"cacheDeck"
))
{
//卡包展示时不显示额外和副卡组数量文本
//卡包展示时不显示额外和副卡组数量文本
holder
.
ll_extra_n_side
.
setVisibility
(
View
.
GONE
);
holder
.
ll_extra_n_side
.
setVisibility
(
View
.
GONE
);
...
@@ -245,6 +259,7 @@ class DeckViewHolder extends com.chad.library.adapter.base.viewholder.BaseViewHo
...
@@ -245,6 +259,7 @@ class DeckViewHolder extends com.chad.library.adapter.base.viewholder.BaseViewHo
TextView
main
;
TextView
main
;
TextView
extra
;
TextView
extra
;
TextView
side
;
TextView
side
;
TextView
file_time
;
LinearLayout
ll_extra_n_side
;
LinearLayout
ll_extra_n_side
;
View
item_deck_list
;
View
item_deck_list
;
View
deck_info
;
View
deck_info
;
...
@@ -259,6 +274,7 @@ class DeckViewHolder extends com.chad.library.adapter.base.viewholder.BaseViewHo
...
@@ -259,6 +274,7 @@ class DeckViewHolder extends com.chad.library.adapter.base.viewholder.BaseViewHo
main
=
findView
(
R
.
id
.
count_main
);
main
=
findView
(
R
.
id
.
count_main
);
extra
=
findView
(
R
.
id
.
count_ex
);
extra
=
findView
(
R
.
id
.
count_ex
);
side
=
findView
(
R
.
id
.
count_side
);
side
=
findView
(
R
.
id
.
count_side
);
file_time
=
findView
(
R
.
id
.
file_time
);
ll_extra_n_side
=
findView
(
R
.
id
.
ll_extra_n_side
);
ll_extra_n_side
=
findView
(
R
.
id
.
ll_extra_n_side
);
prerelease_star
=
findView
(
R
.
id
.
prerelease_star
);
prerelease_star
=
findView
(
R
.
id
.
prerelease_star
);
banned_mark
=
findView
(
R
.
id
.
banned_mark
);
banned_mark
=
findView
(
R
.
id
.
banned_mark
);
...
...
mobile/src/main/java/cn/garymb/ygomobile/ui/cards/DeckManagerFragment.java
View file @
c101d738
...
@@ -1353,7 +1353,7 @@ public class DeckManagerFragment extends BaseFragemnt implements RecyclerViewIte
...
@@ -1353,7 +1353,7 @@ public class DeckManagerFragment extends BaseFragemnt implements RecyclerViewIte
String
fileFullName
=
deckData
.
getDeckName
()
+
".ydk"
;
String
fileFullName
=
deckData
.
getDeckName
()
+
".ydk"
;
File
dir
=
new
File
(
getActivity
().
getApplicationInfo
().
dataDir
,
"cache"
);
File
dir
=
new
File
(
getActivity
().
getApplicationInfo
().
dataDir
,
"cache"
);
//将卡组存到cache缓存目录中
//将卡组存到cache缓存目录中
boolean
result
=
DeckSquareFileUtil
.
saveFileToPath
(
dir
.
getPath
(),
fileFullName
,
deckData
.
getDeckYdk
());
boolean
result
=
DeckSquareFileUtil
.
saveFileToPath
(
dir
.
getPath
(),
fileFullName
,
deckData
.
getDeckYdk
()
,
Long
.
valueOf
(
deckData
.
getDeckUpdateDate
())
);
if
(
result
)
{
//存储成功,使用预加载功能
if
(
result
)
{
//存储成功,使用预加载功能
LogUtil
.
i
(
TAG
,
"square deck detail done"
);
LogUtil
.
i
(
TAG
,
"square deck detail done"
);
//File file = new File(dir, fileFullName);
//File file = new File(dir, fileFullName);
...
...
mobile/src/main/res/drawable/baseline_more_time_24.xml
0 → 100644
View file @
c101d738
<vector
xmlns:android=
"http://schemas.android.com/apk/res/android"
android:height=
"24dp"
android:tint=
"#91BF03"
android:viewportHeight=
"24"
android:viewportWidth=
"24"
android:width=
"24dp"
>
<path
android:fillColor=
"@android:color/white"
android:pathData=
"M10,8l0,6l4.7,2.9l0.8,-1.2l-4,-2.4l0,-5.3z"
/>
<path
android:fillColor=
"@android:color/white"
android:pathData=
"M17.92,12c0.05,0.33 0.08,0.66 0.08,1c0,3.9 -3.1,7 -7,7s-7,-3.1 -7,-7c0,-3.9 3.1,-7 7,-7c0.7,0 1.37,0.1 2,0.29V4.23C12.36,4.08 11.69,4 11,4c-5,0 -9,4 -9,9s4,9 9,9s9,-4 9,-9c0,-0.34 -0.02,-0.67 -0.06,-1H17.92z"
/>
<path
android:fillColor=
"@android:color/white"
android:pathData=
"M20,5l0,-3l-2,0l0,3l-3,0l0,2l3,0l0,3l2,0l0,-3l3,0l0,-2z"
/>
</vector>
mobile/src/main/res/layout/item_deck_list_swipe.xml
View file @
c101d738
...
@@ -132,6 +132,23 @@
...
@@ -132,6 +132,23 @@
android:textColor=
"@color/holo_blue_bright"
android:textColor=
"@color/holo_blue_bright"
android:textSize=
"10sp"
android:textSize=
"10sp"
tools:text=
"15"
/>
tools:text=
"15"
/>
<View
android:layout_width=
"0dp"
android:layout_height=
"0dp"
android:layout_weight=
"1"
/>
<ImageView
android:layout_width=
"15dp"
android:layout_height=
"15dp"
android:src=
"@drawable/baseline_more_time_24"
/>
<TextView
android:id=
"@+id/file_time"
android:layout_width=
"wrap_content"
android:layout_height=
"wrap_content"
android:maxLines=
"1"
android:singleLine=
"true"
android:textColor=
"@color/holo_blue_bright"
android:textSize=
"7sp"
tools:text=
"2025-07-03T19:47:26"
/>
</LinearLayout>
</LinearLayout>
</LinearLayout>
</LinearLayout>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment