Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Sign in / Register
Toggle navigation
P
PhoneManager
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Yang
PhoneManager
Commits
7e531da8
Commit
7e531da8
authored
Apr 11, 2025
by
CZ1004
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修改首页问题
parent
939708d2
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
231 additions
and
221 deletions
+231
-221
CompressCompletedLight.json
...mation/CompressCompletedLight/CompressCompletedLight.json
+1
-1
CompressCompletedLightOld.json
...ion/CompressCompletedLight/CompressCompletedLightOld.json
+1
-0
ChargeInfoSettingView.swift
...ger/Class/Session/Charge/View/ChargeInfoSettingView.swift
+1
-1
HomePhotosDetailViewController.swift
...sion/Home/Controller/HomePhotosDetailViewController.swift
+90
-88
HomeVideoDetailController.swift
...s/Session/Home/Controller/HomeVideoDetailController.swift
+101
-117
HomeViewController.swift
...er/Class/Session/Home/Controller/HomeViewController.swift
+5
-0
VideoDetaiNavView.swift
PhoneManager/Class/Session/Home/View/VideoDetaiNavView.swift
+1
-1
PMShowImgVideoController.swift
...nager/Class/Session/Secret/PMShowImgVideoController.swift
+0
-13
PhotoAndVideoMananger.swift
...l/Class/PhotoAndVideoMananger/PhotoAndVideoMananger.swift
+31
-0
No files found.
PhoneManager/Class/Resource/Animation/CompressCompletedLight/CompressCompletedLight.json
View file @
7e531da8
{
"v"
:
"5.5.7"
,
"meta"
:{
"g"
:
"LottieFiles AE 0.1.20"
,
"a"
:
""
,
"k"
:
""
,
"d"
:
""
,
"tc"
:
""
},
"fr"
:
30
,
"ip"
:
0
,
"op"
:
60
,
"w"
:
500
,
"h"
:
500
,
"nm"
:
"Comp 1"
,
"assets"
:[{
"id"
:
"image_0"
,
"w"
:
450
,
"h"
:
451
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"image_1"
,
"w"
:
213
,
"h"
:
220
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"comp_0"
,
"layers"
:[{
"ind"
:
1
,
"ty"
:
2
,
"nm"
:
"Man/3704194.ai"
,
"cl"
:
"ai"
,
"refId"
:
"image_0"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
},
"r"
:{
"a"
:
0
,
"k"
:
0
},
"p"
:{
"a"
:
0
,
"k"
:[
225
,
225.5
,
0
]},
"a"
:{
"a"
:
0
,
"k"
:[
225
,
225.5
,
0
]},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
]}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
150
,
"st"
:
0
}]},{
"id"
:
"comp_1"
,
"layers"
:[{
"ind"
:
1
,
"ty"
:
2
,
"nm"
:
"Box/3704194.ai"
,
"cl"
:
"ai"
,
"refId"
:
"image_1"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
},
"r"
:{
"a"
:
0
,
"k"
:
0
},
"p"
:{
"a"
:
0
,
"k"
:[
106.5
,
110
,
0
]},
"a"
:{
"a"
:
0
,
"k"
:[
106.5
,
110
,
0
]},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
]}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
150
,
"st"
:
0
}]}],
"layers"
:[{
"ind"
:
1
,
"ty"
:
0
,
"nm"
:
"Man/3704194"
,
"refId"
:
"comp_0"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
},
"r"
:{
"a"
:
0
,
"k"
:
0
},
"p"
:{
"a"
:
0
,
"k"
:[
250
,
250
,
0
]},
"a"
:{
"a"
:
0
,
"k"
:[
225
,
225.5
,
0
]},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
]}},
"ao"
:
0
,
"w"
:
450
,
"h"
:
451
,
"ip"
:
0
,
"op"
:
91
,
"st"
:
0
},{
"ind"
:
2
,
"ty"
:
0
,
"nm"
:
"Box/3704194"
,
"refId"
:
"comp_1"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
},
"r"
:{
"a"
:
0
,
"k"
:
0
},
"p"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:
0.833
,
"y"
:
0.833
},
"o"
:{
"x"
:
0.167
,
"y"
:
0.167
},
"t"
:
0
,
"s"
:[
290
,
216
,
0
],
"to"
:[
0
,
27.667
,
0
],
"ti"
:[
0
,
-27.667
,
0
]},{
"t"
:
59
,
"s"
:[
290
,
382
,
0
]}]},
"a"
:{
"a"
:
0
,
"k"
:[
106.5
,
110
,
0
]},
"s"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
,
0.833
,
0.833
],
"y"
:[
0.833
,
0.833
,
0.833
]},
"o"
:{
"x"
:[
0.167
,
0.167
,
0.167
],
"y"
:[
0.167
,
0.167
,
0.167
]},
"t"
:
0
,
"s"
:[
70
,
70
,
100
]},{
"t"
:
59
,
"s"
:[
40
,
40
,
100
]}]}},
"ao"
:
0
,
"w"
:
213
,
"h"
:
220
,
"ip"
:
0
,
"op"
:
91
,
"st"
:
0
}],
"markers"
:[]}
\ No newline at end of file
{
"v"
:
"5.6.3"
,
"fr"
:
25
,
"ip"
:
0
,
"op"
:
100
,
"w"
:
600
,
"h"
:
600
,
"nm"
:
"图片压缩动画"
,
"ddd"
:
0
,
"assets"
:[{
"id"
:
"image_0"
,
"w"
:
72
,
"h"
:
12
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"image_1"
,
"w"
:
44
,
"h"
:
77
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"image_2"
,
"w"
:
240
,
"h"
:
24
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"image_3"
,
"w"
:
245
,
"h"
:
30
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"image_4"
,
"w"
:
108
,
"h"
:
108
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"image_5"
,
"w"
:
450
,
"h"
:
450
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"image_6"
,
"w"
:
504
,
"h"
:
504
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"comp_0"
,
"layers"
:[{
"ddd"
:
0
,
"ind"
:
1
,
"ty"
:
4
,
"nm"
:
"形状图层 1"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
,
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
0
,
"k"
:[
296.287
,
291.5
,
0
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
0
,
0
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
],
"ix"
:
6
}},
"ao"
:
0
,
"shapes"
:[{
"ty"
:
"gr"
,
"it"
:[{
"ind"
:
0
,
"ty"
:
"sh"
,
"ix"
:
1
,
"ks"
:{
"a"
:
0
,
"k"
:{
"i"
:[[
0
,
0
],[
0
,
0
],[
0
,
0
]],
"o"
:[[
0
,
0
],[
0
,
0
],[
0
,
0
]],
"v"
:[[
-53.155
,
-4
],[
-14.155
,
41
],[
63.697
,
-24
]],
"c"
:
false
},
"ix"
:
2
},
"nm"
:
"路径 1"
,
"mn"
:
"ADBE Vector Shape - Group"
,
"hd"
:
false
},{
"ty"
:
"tm"
,
"s"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
1
},
"e"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
60
,
"s"
:[
0
],
"e"
:[
100
]},{
"t"
:
74
}],
"ix"
:
2
},
"o"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
3
},
"m"
:
1
,
"ix"
:
2
,
"nm"
:
"修剪路径 1"
,
"mn"
:
"ADBE Vector Filter - Trim"
,
"hd"
:
false
},{
"ty"
:
"st"
,
"c"
:{
"a"
:
0
,
"k"
:[
0
,
0.509803950787
,
1
,
1
],
"ix"
:
3
},
"o"
:{
"a"
:
0
,
"k"
:
100
,
"ix"
:
4
},
"w"
:{
"a"
:
0
,
"k"
:
18
,
"ix"
:
5
},
"lc"
:
2
,
"lj"
:
2
,
"bm"
:
0
,
"nm"
:
"描边 1"
,
"mn"
:
"ADBE Vector Graphic - Stroke"
,
"hd"
:
false
},{
"ty"
:
"tr"
,
"p"
:{
"a"
:
0
,
"k"
:[
0
,
0
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
0
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
0
,
"k"
:[
108.392
,
100
],
"ix"
:
3
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
6
},
"o"
:{
"a"
:
0
,
"k"
:
100
,
"ix"
:
7
},
"sk"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
4
},
"sa"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
5
},
"nm"
:
"变换"
}],
"nm"
:
"形状 1"
,
"np"
:
4
,
"cix"
:
2
,
"bm"
:
0
,
"ix"
:
1
,
"mn"
:
"ADBE Vector Group"
,
"hd"
:
false
}],
"ip"
:
60
,
"op"
:
100
,
"st"
:
0
,
"bm"
:
0
},{
"ddd"
:
0
,
"ind"
:
2
,
"ty"
:
4
,
"nm"
:
"形状图层 2"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
,
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
0
,
"k"
:[
302.202
,
302.972
,
0
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
35.265
,
44.882
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
0
,
"k"
:[
156.227
,
156.227
,
100
],
"ix"
:
6
}},
"ao"
:
0
,
"shapes"
:[{
"ty"
:
"gr"
,
"it"
:[{
"d"
:
1
,
"ty"
:
"el"
,
"s"
:{
"a"
:
0
,
"k"
:[
151
,
151
],
"ix"
:
2
},
"p"
:{
"a"
:
0
,
"k"
:[
0
,
0
],
"ix"
:
3
},
"nm"
:
"椭圆路径 1"
,
"mn"
:
"ADBE Vector Shape - Ellipse"
,
"hd"
:
false
},{
"ty"
:
"fl"
,
"c"
:{
"a"
:
0
,
"k"
:[
1
,
1
,
1
,
1
],
"ix"
:
4
},
"o"
:{
"a"
:
0
,
"k"
:
100
,
"ix"
:
5
},
"r"
:
1
,
"bm"
:
0
,
"nm"
:
"填充 1"
,
"mn"
:
"ADBE Vector Graphic - Fill"
,
"hd"
:
false
},{
"ty"
:
"tr"
,
"p"
:{
"a"
:
0
,
"k"
:[
33.5
,
42.5
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
0
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
],
"ix"
:
3
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
6
},
"o"
:{
"a"
:
0
,
"k"
:
100
,
"ix"
:
7
},
"sk"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
4
},
"sa"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
5
},
"nm"
:
"变换"
}],
"nm"
:
"椭圆 1"
,
"np"
:
3
,
"cix"
:
2
,
"bm"
:
0
,
"ix"
:
1
,
"mn"
:
"ADBE Vector Group"
,
"hd"
:
false
}],
"ip"
:
60
,
"op"
:
100
,
"st"
:
0
,
"bm"
:
0
}]}],
"layers"
:[{
"ddd"
:
0
,
"ind"
:
1
,
"ty"
:
0
,
"nm"
:
"勾"
,
"refId"
:
"comp_0"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
,
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
0
,
"k"
:[
300
,
300
,
0
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
300
,
300
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.25
,
0.25
,
0.25
],
"y"
:[
1
,
1
,
1
]},
"o"
:{
"x"
:[
0.167
,
0.167
,
0.167
],
"y"
:[
0.167
,
0.167
,
3.333
]},
"t"
:
55
,
"s"
:[
80
,
80
,
100
],
"e"
:[
100
,
100
,
100
]},{
"i"
:{
"x"
:[
0.25
,
0.25
,
0.25
],
"y"
:[
1
,
1
,
1
]},
"o"
:{
"x"
:[
0.167
,
0.167
,
0.167
],
"y"
:[
0.167
,
0.167
,
-3.333
]},
"t"
:
77.564
,
"s"
:[
100
,
100
,
100
],
"e"
:[
80
,
80
,
100
]},{
"t"
:
99
}],
"ix"
:
6
}},
"ao"
:
0
,
"w"
:
600
,
"h"
:
600
,
"ip"
:
55
,
"op"
:
100
,
"st"
:
0
,
"bm"
:
0
},{
"ddd"
:
0
,
"ind"
:
2
,
"ty"
:
2
,
"nm"
:
"小帽子"
,
"parent"
:
4
,
"refId"
:
"image_0"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
45
,
"s"
:[
100
],
"e"
:[
0
]},{
"t"
:
55
}],
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
0
,
"k"
:[
129
,
-12
,
0
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
36
,
6
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
],
"ix"
:
6
}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
75
,
"st"
:
0
,
"bm"
:
0
},{
"ddd"
:
0
,
"ind"
:
3
,
"ty"
:
2
,
"nm"
:
"弹簧"
,
"parent"
:
4
,
"refId"
:
"image_1"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
45
,
"s"
:[
100
],
"e"
:[
0
]},{
"t"
:
55
}],
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:
0.45
,
"y"
:
1
},
"o"
:{
"x"
:
0.55
,
"y"
:
0
},
"t"
:
30
,
"s"
:[
130.431
,
-48.53
,
0
],
"e"
:[
130.431
,
-31.53
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"i"
:{
"x"
:
0.45
,
"y"
:
0.45
},
"o"
:{
"x"
:
0.55
,
"y"
:
0.55
},
"t"
:
35
,
"s"
:[
130.431
,
-31.53
,
0
],
"e"
:[
130.431
,
-31.53
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"i"
:{
"x"
:
0.45
,
"y"
:
1
},
"o"
:{
"x"
:
0.55
,
"y"
:
0
},
"t"
:
40
,
"s"
:[
130.431
,
-31.53
,
0
],
"e"
:[
130.431
,
-48.53
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"t"
:
45
}],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
22
,
38.5
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.45
,
0.45
,
0.45
],
"y"
:[
1
,
1
,
1
]},
"o"
:{
"x"
:[
0.55
,
0.55
,
0.55
],
"y"
:[
0
,
0
,
0
]},
"t"
:
30
,
"s"
:[
97.471
,
97.471
,
100
],
"e"
:[
97.471
,
42.926
,
100
]},{
"i"
:{
"x"
:[
0.45
,
0.45
,
0.45
],
"y"
:[
1
,
1
,
1
]},
"o"
:{
"x"
:[
0.55
,
0.55
,
0.55
],
"y"
:[
0
,
0
,
0
]},
"t"
:
35
,
"s"
:[
97.471
,
42.926
,
100
],
"e"
:[
97.471
,
42.926
,
100
]},{
"i"
:{
"x"
:[
0.45
,
0.45
,
0.45
],
"y"
:[
1
,
1
,
1
]},
"o"
:{
"x"
:[
0.55
,
0.55
,
0.55
],
"y"
:[
0
,
0
,
0
]},
"t"
:
40
,
"s"
:[
97.471
,
42.926
,
100
],
"e"
:[
97.471
,
97.471
,
100
]},{
"t"
:
45
}],
"ix"
:
6
}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
75
,
"st"
:
0
,
"bm"
:
0
},{
"ddd"
:
0
,
"ind"
:
4
,
"ty"
:
2
,
"nm"
:
"上压缩盖"
,
"refId"
:
"image_2"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
45
,
"s"
:[
100
],
"e"
:[
0
]},{
"t"
:
55
}],
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:
0.32
,
"y"
:
1
},
"o"
:{
"x"
:
0.68
,
"y"
:
0
},
"t"
:
20
,
"s"
:[
300
,
246
,
0
],
"e"
:[
300
,
390.09
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"i"
:{
"x"
:
0.3
,
"y"
:
0.3
},
"o"
:{
"x"
:
0.68
,
"y"
:
0.68
},
"t"
:
35
,
"s"
:[
300
,
390.09
,
0
],
"e"
:[
300
,
390.09
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"i"
:{
"x"
:
0.3
,
"y"
:
1
},
"o"
:{
"x"
:
0.7
,
"y"
:
0
},
"t"
:
40
,
"s"
:[
300
,
390.09
,
0
],
"e"
:[
300
,
246.09
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"t"
:
55
}],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
120
,
12
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
],
"ix"
:
6
}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
75
,
"st"
:
0
,
"bm"
:
0
},{
"ddd"
:
0
,
"ind"
:
5
,
"ty"
:
2
,
"nm"
:
"下压缩盖"
,
"refId"
:
"image_3"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
45
,
"s"
:[
100
],
"e"
:[
0
]},{
"t"
:
55
}],
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
0
,
"k"
:[
300
,
417
,
0
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
122.5
,
15
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
],
"ix"
:
6
}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
75
,
"st"
:
0
,
"bm"
:
0
},{
"ddd"
:
0
,
"ind"
:
6
,
"ty"
:
2
,
"nm"
:
"icon_yasuo_home"
,
"refId"
:
"image_4"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
0
,
"s"
:[
0
],
"e"
:[
100
]},{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
15
,
"s"
:[
100
],
"e"
:[
0
]},{
"t"
:
55
}],
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:
0.35
,
"y"
:
1
},
"o"
:{
"x"
:
0.167
,
"y"
:
0
},
"t"
:
0
,
"s"
:[
601.689
,
330
,
0
],
"e"
:[
300
,
330
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"i"
:{
"x"
:
0.35
,
"y"
:
0.35
},
"o"
:{
"x"
:
0.167
,
"y"
:
0.167
},
"t"
:
15
,
"s"
:[
300
,
330
,
0
],
"e"
:[
300
,
330
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"i"
:{
"x"
:
0.833
,
"y"
:
0.833
},
"o"
:{
"x"
:
0.167
,
"y"
:
0
},
"t"
:
20
,
"s"
:[
300
,
330
,
0
],
"e"
:[
300
,
409.925
,
0
],
"to"
:[
0
,
0
,
0
],
"ti"
:[
0
,
0
,
0
]},{
"t"
:
35
}],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
54
,
54
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
,
0.833
,
0.833
],
"y"
:[
0.833
,
0.833
,
0.833
]},
"o"
:{
"x"
:[
0.167
,
0.167
,
0.167
],
"y"
:[
0.167
,
0.167
,
0.167
]},
"t"
:
20
,
"s"
:[
100
,
100
,
100
],
"e"
:[
20
,
20
,
100
]},{
"t"
:
35
}],
"ix"
:
6
}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
75
,
"st"
:
0
,
"bm"
:
0
},{
"ddd"
:
0
,
"ind"
:
7
,
"ty"
:
2
,
"nm"
:
"白色实心圆-小"
,
"refId"
:
"image_5"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
,
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
0
,
"k"
:[
300
,
300
,
0
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
225
,
225
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
],
"ix"
:
6
}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
101
,
"st"
:
0
,
"bm"
:
0
},{
"ddd"
:
0
,
"ind"
:
8
,
"ty"
:
2
,
"nm"
:
"白色边框圆-大"
,
"refId"
:
"image_6"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
0
,
"s"
:[
100
],
"e"
:[
0
]},{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
20.625
,
"s"
:[
0
],
"e"
:[
0
]},{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
33
,
"s"
:[
0
],
"e"
:[
100
]},{
"i"
:{
"x"
:[
0.833
],
"y"
:[
0.833
]},
"o"
:{
"x"
:[
0.167
],
"y"
:[
0.167
]},
"t"
:
34.375
,
"s"
:[
100
],
"e"
:[
0
]},{
"t"
:
55
}],
"ix"
:
11
},
"r"
:{
"a"
:
0
,
"k"
:
0
,
"ix"
:
10
},
"p"
:{
"a"
:
0
,
"k"
:[
300
,
300
,
0
],
"ix"
:
2
},
"a"
:{
"a"
:
0
,
"k"
:[
252
,
252
,
0
],
"ix"
:
1
},
"s"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
,
0.833
,
0.833
],
"y"
:[
0.833
,
0.833
,
0.833
]},
"o"
:{
"x"
:[
0.167
,
0.167
,
0.167
],
"y"
:[
0.167
,
0.167
,
0.167
]},
"t"
:
0
,
"s"
:[
100
,
100
,
100
],
"e"
:[
118.254
,
118.254
,
100
]},{
"i"
:{
"x"
:[
0.833
,
0.833
,
0.833
],
"y"
:[
0.833
,
0.833
,
0.833
]},
"o"
:{
"x"
:[
0.167
,
0.167
,
0.167
],
"y"
:[
0.167
,
0.167
,
0.167
]},
"t"
:
20.625
,
"s"
:[
118.254
,
118.254
,
100
],
"e"
:[
100
,
100
,
100
]},{
"i"
:{
"x"
:[
0.833
,
0.833
,
0.833
],
"y"
:[
0.833
,
0.833
,
0.833
]},
"o"
:{
"x"
:[
0.167
,
0.167
,
0.167
],
"y"
:[
0.167
,
0.167
,
0.167
]},
"t"
:
34.375
,
"s"
:[
100
,
100
,
100
],
"e"
:[
118.254
,
118.254
,
100
]},{
"t"
:
55
}],
"ix"
:
6
}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
101
,
"st"
:
0
,
"bm"
:
0
}],
"markers"
:[]}
PhoneManager/Class/Resource/Animation/CompressCompletedLight/CompressCompletedLightOld.json
0 → 100644
View file @
7e531da8
{
"v"
:
"5.5.7"
,
"meta"
:{
"g"
:
"LottieFiles AE 0.1.20"
,
"a"
:
""
,
"k"
:
""
,
"d"
:
""
,
"tc"
:
""
},
"fr"
:
30
,
"ip"
:
0
,
"op"
:
60
,
"w"
:
500
,
"h"
:
500
,
"nm"
:
"Comp 1"
,
"assets"
:[{
"id"
:
"image_0"
,
"w"
:
450
,
"h"
:
451
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"image_1"
,
"w"
:
213
,
"h"
:
220
,
"u"
:
""
,
"p"
:
""
,
"e"
:
1
},{
"id"
:
"comp_0"
,
"layers"
:[{
"ind"
:
1
,
"ty"
:
2
,
"nm"
:
"Man/3704194.ai"
,
"cl"
:
"ai"
,
"refId"
:
"image_0"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
},
"r"
:{
"a"
:
0
,
"k"
:
0
},
"p"
:{
"a"
:
0
,
"k"
:[
225
,
225.5
,
0
]},
"a"
:{
"a"
:
0
,
"k"
:[
225
,
225.5
,
0
]},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
]}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
150
,
"st"
:
0
}]},{
"id"
:
"comp_1"
,
"layers"
:[{
"ind"
:
1
,
"ty"
:
2
,
"nm"
:
"Box/3704194.ai"
,
"cl"
:
"ai"
,
"refId"
:
"image_1"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
},
"r"
:{
"a"
:
0
,
"k"
:
0
},
"p"
:{
"a"
:
0
,
"k"
:[
106.5
,
110
,
0
]},
"a"
:{
"a"
:
0
,
"k"
:[
106.5
,
110
,
0
]},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
]}},
"ao"
:
0
,
"ip"
:
0
,
"op"
:
150
,
"st"
:
0
}]}],
"layers"
:[{
"ind"
:
1
,
"ty"
:
0
,
"nm"
:
"Man/3704194"
,
"refId"
:
"comp_0"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
},
"r"
:{
"a"
:
0
,
"k"
:
0
},
"p"
:{
"a"
:
0
,
"k"
:[
250
,
250
,
0
]},
"a"
:{
"a"
:
0
,
"k"
:[
225
,
225.5
,
0
]},
"s"
:{
"a"
:
0
,
"k"
:[
100
,
100
,
100
]}},
"ao"
:
0
,
"w"
:
450
,
"h"
:
451
,
"ip"
:
0
,
"op"
:
91
,
"st"
:
0
},{
"ind"
:
2
,
"ty"
:
0
,
"nm"
:
"Box/3704194"
,
"refId"
:
"comp_1"
,
"sr"
:
1
,
"ks"
:{
"o"
:{
"a"
:
0
,
"k"
:
100
},
"r"
:{
"a"
:
0
,
"k"
:
0
},
"p"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:
0.833
,
"y"
:
0.833
},
"o"
:{
"x"
:
0.167
,
"y"
:
0.167
},
"t"
:
0
,
"s"
:[
290
,
216
,
0
],
"to"
:[
0
,
27.667
,
0
],
"ti"
:[
0
,
-27.667
,
0
]},{
"t"
:
59
,
"s"
:[
290
,
382
,
0
]}]},
"a"
:{
"a"
:
0
,
"k"
:[
106.5
,
110
,
0
]},
"s"
:{
"a"
:
1
,
"k"
:[{
"i"
:{
"x"
:[
0.833
,
0.833
,
0.833
],
"y"
:[
0.833
,
0.833
,
0.833
]},
"o"
:{
"x"
:[
0.167
,
0.167
,
0.167
],
"y"
:[
0.167
,
0.167
,
0.167
]},
"t"
:
0
,
"s"
:[
70
,
70
,
100
]},{
"t"
:
59
,
"s"
:[
40
,
40
,
100
]}]}},
"ao"
:
0
,
"w"
:
213
,
"h"
:
220
,
"ip"
:
0
,
"op"
:
91
,
"st"
:
0
}],
"markers"
:[]}
\ No newline at end of file
PhoneManager/Class/Session/Charge/View/ChargeInfoSettingView.swift
View file @
7e531da8
...
...
@@ -55,7 +55,7 @@ class ChargeInfoSettingView:UIView {
// 存储到userDefaults
UserDefaults
.
standard
.
set
(
String
(
flag
!
),
forKey
:
"chargePicInfo"
)
let
alert
=
UIAlertController
(
title
:
nil
,
message
:
"
完成
!"
,
preferredStyle
:
.
alert
)
let
alert
=
UIAlertController
(
title
:
nil
,
message
:
"
Done
!"
,
preferredStyle
:
.
alert
)
self
.
responderViewController
()?
.
present
(
alert
,
animated
:
true
,
completion
:
nil
)
// 2 秒后关闭弹窗
...
...
PhoneManager/Class/Session/Home/Controller/HomePhotosDetailViewController.swift
View file @
7e531da8
...
...
@@ -15,6 +15,7 @@ class HomePhotosDetailViewController : BaseViewController {
private
var
currentHeaderView
:
HomePhotosDetailCustomHeaderView
?
var
mediaType
:
PhotsFileType
?
@MainActor
required
init
?(
coder
:
NSCoder
)
{
...
...
@@ -36,6 +37,7 @@ class HomePhotosDetailViewController : BaseViewController {
dataArray
=
dataArray
+
item
}
self
.
resourceData
=
dataArray
self
.
sortByType
(
sortType
:
self
.
currentSort
)
}
var
model
:
HomePhotosModel
...
...
@@ -201,11 +203,19 @@ extension HomePhotosDetailViewController:WaterfallMutiSectionDelegate,UICollecti
cell
.
cellCallBack
=
{[
weak
self
]
ident
,
order
in
guard
let
self
else
{
return
}
DispatchQueue
.
main
.
async
{
// 点击跳转详情,左右滑动删除照片
let
vc
:
PreViewController
=
PreViewController
()
vc
.
dataSource
=
self
.
resourceData
vc
.
imageIdent
=
ident
// 点击之后跳转详情页面
let
vc
=
PMShowImgVideoController
()
vc
.
state
=
.
similarPhotos
vc
.
currentIdx
=
0
let
dataSource
=
ImageSeletedCollectionItem
()
dataSource
.
isSeleted
=
true
dataSource
.
id
=
ident
// 获取image
dataSource
.
image
=
PhotoAndVideoMananger
.
mananger
.
getImageFromAssetID
(
id
:
ident
)
vc
.
homeDataSource
=
[
dataSource
]
self
.
navigationController
?
.
pushViewController
(
vc
,
animated
:
true
)
}
}
cell
.
clickCallBack
=
{[
weak
self
]
click
,
order
in
...
...
@@ -254,6 +264,7 @@ extension HomePhotosDetailViewController:WaterfallMutiSectionDelegate,UICollecti
func
collectionView
(
_
collectionView
:
UICollectionView
,
didSelectItemAt
indexPath
:
IndexPath
)
{
// 点击之后跳转详情页面
}
func
referenceSizeForHeader
(
collectionView
collection
:
UICollectionView
,
layout
:
WaterfallMutiSectionFlowLayout
,
section
:
Int
)
->
CGSize
{
return
CGSize
(
width
:
self
.
collectionView
.
width
,
height
:
headerHeight
)
...
...
@@ -278,6 +289,7 @@ extension HomePhotosDetailViewController:WaterfallMutiSectionDelegate,UICollecti
guard
let
self
else
{
return
}
self
.
currentSort
=
sortType
as!
Int
self
.
sortByType
(
sortType
:
self
.
currentSort
)
self
.
changeHeaderTitle
()
}
}
...
...
@@ -292,97 +304,87 @@ extension HomePhotosDetailViewController:WaterfallMutiSectionDelegate,UICollecti
return
footer
}
}
/// 改变标题
func
changeHeaderTitle
(){
var
title
:
String
=
"Largest"
switch
self
.
currentSort
{
case
0
:
title
=
"Largest"
break
case
1
:
title
=
"Smallest"
break
case
2
:
title
=
"Newest"
break
case
3
:
title
=
"Oldest"
break
default
:
break
}
DispatchQueue
.
main
.
async
{
self
.
currentHeaderView
!.
selectlabel
.
text
=
title
self
.
collectionView
.
reloadData
()
}
}
/// 对当前页面资源排序(注意这里获取的资源是image)
/// - Parameter sortType: 排序类型
func
sortByType
(
sortType
:
Int
){
let
viewModel
=
CompressViewModel
()
if
self
.
datas
.
count
>
0
{
switch
sortType
{
case
0
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Largest"
// 按照文件大小降序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
1
,
sortKind
:
0
)
break
case
1
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Smallest"
// 按照文件大小升序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
0
,
sortKind
:
0
)
break
case
2
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Newest"
// 按照时间降序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
1
,
sortKind
:
1
)
break
case
3
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Oldest"
// 按照时间升序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
0
,
sortKind
:
1
)
break
default
:
break
// 实际就是对Video数据排序
var
assetsWithSize
:
[(
asset
:
PHAsset
,
size
:
Int64
)]
=
[]
let
allImagesResult
=
PHAsset
.
fetchAssets
(
withLocalIdentifiers
:
self
.
resourceData
,
options
:
nil
)
let
allImages
=
allImagesResult
.
objects
(
at
:
IndexSet
(
0
..<
allImagesResult
.
count
))
for
item
in
allImages
{
let
resources
=
PHAssetResource
.
assetResources
(
for
:
item
)
for
resource
in
resources
{
if
let
fileSize
=
resource
.
value
(
forKey
:
"fileSize"
)
as?
Int64
{
assetsWithSize
.
append
((
item
,
fileSize
))
}
}
var
finalData
:
[
String
]
=
[]
for
item
in
self
.
datas
{
finalData
.
append
(
item
.
ident
)
}
if
sortType
==
0
||
sortType
==
1
{
if
sortType
==
0
{
assetsWithSize
=
assetsWithSize
.
sorted
{
$0
.
size
>
$1
.
size
}
}
else
{
assetsWithSize
=
assetsWithSize
.
sorted
{
$0
.
size
<
$1
.
size
}
}
self
.
resourceData
=
finalData
self
.
collectionView
.
reloadData
()
}
else
{
DispatchQueue
.
global
()
.
async
{
let
fetchResult
=
PHAsset
.
fetchAssets
(
withLocalIdentifiers
:
self
.
resourceData
,
options
:
nil
)
let
assetsArray
=
fetchResult
.
objects
(
at
:
IndexSet
(
0
..<
fetchResult
.
count
))
let
options
=
PHImageRequestOptions
()
options
.
isSynchronous
=
false
options
.
deliveryMode
=
.
highQualityFormat
options
.
isNetworkAccessAllowed
=
true
var
count
=
0
for
item
in
assetsArray
{
PHImageManager
.
default
()
.
requestImageDataAndOrientation
(
for
:
item
,
options
:
options
)
{
(
imageData
,
_
,
_
,
error
)
in
guard
let
originalData
=
imageData
else
{
return
}
let
model
=
ResourceModel
(
ident
:
item
.
localIdentifier
,
orgSize
:
Double
(
originalData
.
count
),
createDate
:
item
.
creationDate
!
)
self
.
datas
.
append
(
model
)
// 输出排序后的资源信息
var
sources
:[
String
]
=
[]
for
(
_
,
item
)
in
assetsWithSize
.
enumerated
()
{
sources
.
append
(
item
.
asset
.
localIdentifier
)
}
self
.
resourceData
=
sources
}
if
sortType
==
2
||
sortType
==
3
{
var
assetsWithDate
:
[(
asset
:
PHAsset
,
size
:
Int64
)]
=
[]
if
sortType
==
2
{
assetsWithDate
=
assetsWithSize
.
sorted
{
guard
let
date1
=
$0
.
asset
.
creationDate
,
let
date2
=
$1
.
asset
.
creationDate
else
{
return
false
}
count
=
count
+
1
// 表示结束了
if
count
==
assetsArray
.
count
{
DispatchQueue
.
main
.
async
{
switch
sortType
{
case
0
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Largest"
// 按照文件大小降序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
1
,
sortKind
:
0
)
break
case
1
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Smallest"
// 按照文件大小升序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
0
,
sortKind
:
0
)
break
case
2
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Newest"
// 按照时间降序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
1
,
sortKind
:
1
)
break
case
3
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Oldest"
// 按照时间升序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
0
,
sortKind
:
1
)
break
default
:
break
}
var
finalData
:
[
String
]
=
[]
for
item
in
self
.
datas
{
finalData
.
append
(
item
.
ident
)
}
self
.
resourceData
=
finalData
self
.
collectionView
.
reloadData
()
}
return
date1
>
date2
}
}
else
{
assetsWithDate
=
assetsWithSize
.
sorted
{
guard
let
date1
=
$0
.
asset
.
creationDate
,
let
date2
=
$1
.
asset
.
creationDate
else
{
return
false
}
return
date1
<
date2
}
}
var
sources
:[
String
]
=
[]
for
item
in
assetsWithDate
{
sources
.
append
(
item
.
asset
.
localIdentifier
)
}
self
.
resourceData
=
sources
}
}
...
...
@@ -407,7 +409,7 @@ extension HomePhotosDetailViewController:WaterfallMutiSectionDelegate,UICollecti
// 更新页面
DispatchQueue
.
main
.
async
{
self
.
clearSelected
()
self
.
collectionView
.
reload
Data
(
)
self
.
collectionView
.
reload
Sections
(
IndexSet
(
integer
:
0
)
)
}
}
...
...
PhoneManager/Class/Session/Home/Controller/HomeVideoDetailController.swift
View file @
7e531da8
...
...
@@ -14,8 +14,6 @@ class HomeVideoDetailController :BaseViewController {
private
var
currentHeaderView
:
HomeVideoDetailCustomHeaderView
?
var
datas
:
[
ResourceModel
]
=
[]
@MainActor
required
init
?(
coder
:
NSCoder
)
{
fatalError
(
"init(coder:) has not been implemented"
)
}
...
...
@@ -35,6 +33,7 @@ class HomeVideoDetailController :BaseViewController {
dataArray
=
dataArray
+
item
}
self
.
resourceData
=
dataArray
self
.
sortByType
(
sortType
:
self
.
currentSort
)
}
var
model
:
HomePhotosModel
...
...
@@ -206,9 +205,33 @@ extension HomeVideoDetailController:WaterfallMutiSectionDelegate,UICollectionVie
}
cell
.
cellCallBack
=
{[
weak
self
]
ident
,
order
in
guard
let
self
else
{
return
}
DispatchQueue
.
main
.
async
{
let
vc
:
PreVideoController
=
PreVideoController
(
localIdentifier
:
ident
)
self
.
navigationController
?
.
pushViewController
(
vc
,
animated
:
true
)
// 获取视频的图片
PhotoAndVideoMananger
.
mananger
.
getVideoImageByIdent
(
ident
:
ident
)
{
image
in
// 点击之后跳转详情页面
print
(
"cellCallBack"
)
let
vc
=
PMShowImgVideoController
()
vc
.
state
=
.
similarVideos
vc
.
currentIdx
=
0
let
dataSource
=
ImageSeletedCollectionItem
()
dataSource
.
isSeleted
=
true
dataSource
.
id
=
ident
dataSource
.
image
=
image
vc
.
homeDataSource
=
[
dataSource
]
DispatchQueue
.
main
.
async
{
self
.
navigationController
?
.
pushViewController
(
vc
,
animated
:
true
)
}
}
errorHandler
:
{
DispatchQueue
.
main
.
async
{
let
alert
=
UIAlertController
(
title
:
nil
,
message
:
"Get Video image failure"
,
preferredStyle
:
.
alert
)
self
.
navigationController
?
.
present
(
alert
,
animated
:
true
)
// 疫苗之后消失
DispatchQueue
.
main
.
asyncAfter
(
deadline
:
.
now
()
+
1
)
{
alert
.
dismiss
(
animated
:
true
,
completion
:
nil
)
self
.
navigationController
?
.
popViewController
(
animated
:
true
)
}
}
}
}
...
...
@@ -263,6 +286,7 @@ extension HomeVideoDetailController:WaterfallMutiSectionDelegate,UICollectionVie
guard
let
self
else
{
return
}
self
.
currentSort
=
sortType
as!
Int
self
.
sortByType
(
sortType
:
self
.
currentSort
)
self
.
changeHeaderTitle
()
}
}
return
header
...
...
@@ -278,32 +302,6 @@ extension HomeVideoDetailController:WaterfallMutiSectionDelegate,UICollectionVie
}
func
sortByType
(
sortType
:
Int
,
header
:
CompressCustomHeaderView
){
switch
sortType
{
case
0
:
header
.
selectlabel
.
text
=
"Largest"
// 按照文件大小降序
break
case
1
:
header
.
selectlabel
.
text
=
"Smallest"
// 按照文件大小升序
break
case
2
:
header
.
selectlabel
.
text
=
"Newest"
// 按照时间降序
break
case
3
:
header
.
selectlabel
.
text
=
"Oldest"
// 按照时间升序
break
default
:
break
}
}
@objc
func
deleteButtonAction
(){
...
...
@@ -326,7 +324,7 @@ extension HomeVideoDetailController:WaterfallMutiSectionDelegate,UICollectionVie
// 更新页面
DispatchQueue
.
main
.
async
{
self
.
clearSelected
()
self
.
collectionView
.
reload
Data
(
)
self
.
collectionView
.
reload
Sections
(
IndexSet
(
integer
:
0
)
)
}
}
...
...
@@ -335,105 +333,91 @@ extension HomeVideoDetailController:WaterfallMutiSectionDelegate,UICollectionVie
}
func
clearSelected
()
{
self
.
selectedModel
.
removeAll
()
}
/// 改变标题
func
changeHeaderTitle
(){
var
title
:
String
=
"Largest"
switch
self
.
currentSort
{
case
0
:
title
=
"Largest"
break
case
1
:
title
=
"Smallest"
break
case
2
:
title
=
"Newest"
break
case
3
:
title
=
"Oldest"
break
default
:
break
}
DispatchQueue
.
main
.
async
{
self
.
currentHeaderView
!.
selectlabel
.
text
=
title
self
.
collectionView
.
reloadData
()
}
}
func
sortByType
(
sortType
:
Int
){
let
viewModel
=
CompressViewModel
()
if
self
.
datas
.
count
>
0
{
switch
sortType
{
case
0
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Largest"
// 按照文件大小降序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
1
,
sortKind
:
0
)
break
case
1
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Smallest"
// 按照文件大小升序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
0
,
sortKind
:
0
)
break
case
2
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Newest"
// 按照时间降序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
1
,
sortKind
:
1
)
break
case
3
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Oldest"
// 按照时间升序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
0
,
sortKind
:
1
)
break
default
:
break
// 实际就是对Video数据排序
var
assetsWithSize
:
[(
asset
:
PHAsset
,
size
:
Int64
)]
=
[]
let
allVideos
=
PHAsset
.
fetchAssets
(
withLocalIdentifiers
:
self
.
resourceData
,
options
:
nil
)
allVideos
.
enumerateObjects
{
(
asset
,
index
,
stop
)
in
let
resources
=
PHAssetResource
.
assetResources
(
for
:
asset
)
for
resource
in
resources
{
if
let
fileSize
=
resource
.
value
(
forKey
:
"fileSize"
)
as?
Int64
{
assetsWithSize
.
append
((
asset
,
fileSize
))
}
}
var
finalData
:
[
String
]
=
[]
for
item
in
self
.
datas
{
finalData
.
append
(
item
.
ident
)
}
if
sortType
==
0
||
sortType
==
1
{
if
sortType
==
0
{
assetsWithSize
=
assetsWithSize
.
sorted
{
$0
.
size
>
$1
.
size
}
}
else
{
assetsWithSize
=
assetsWithSize
.
sorted
{
$0
.
size
<
$1
.
size
}
}
self
.
resourceData
=
finalData
self
.
collectionView
.
reloadData
()
}
else
{
DispatchQueue
.
global
()
.
async
{
let
fetchResult
=
PHAsset
.
fetchAssets
(
withLocalIdentifiers
:
self
.
resourceData
,
options
:
nil
)
let
assetsArray
=
fetchResult
.
objects
(
at
:
IndexSet
(
0
..<
fetchResult
.
count
))
let
options
=
PHImageRequestOptions
()
options
.
isSynchronous
=
false
options
.
deliveryMode
=
.
highQualityFormat
options
.
isNetworkAccessAllowed
=
true
var
count
=
0
for
item
in
assetsArray
{
PHImageManager
.
default
()
.
requestImageDataAndOrientation
(
for
:
item
,
options
:
options
)
{
(
imageData
,
_
,
_
,
error
)
in
guard
let
originalData
=
imageData
else
{
return
}
let
model
=
ResourceModel
(
ident
:
item
.
localIdentifier
,
orgSize
:
Double
(
originalData
.
count
),
createDate
:
item
.
creationDate
!
)
self
.
datas
.
append
(
model
)
// 输出排序后的资源信息
var
sources
:[
String
]
=
[]
for
(
_
,
item
)
in
assetsWithSize
.
enumerated
()
{
sources
.
append
(
item
.
asset
.
localIdentifier
)
}
self
.
resourceData
=
sources
}
if
sortType
==
2
||
sortType
==
3
{
var
assetsWithDate
:
[(
asset
:
PHAsset
,
size
:
Int64
)]
=
[]
if
sortType
==
2
{
assetsWithDate
=
assetsWithSize
.
sorted
{
guard
let
date1
=
$0
.
asset
.
creationDate
,
let
date2
=
$1
.
asset
.
creationDate
else
{
return
false
}
count
=
count
+
1
// 表示结束了
if
count
==
assetsArray
.
count
{
DispatchQueue
.
main
.
async
{
switch
sortType
{
case
0
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Largest"
// 按照文件大小降序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
1
,
sortKind
:
0
)
break
case
1
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Smallest"
// 按照文件大小升序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
0
,
sortKind
:
0
)
break
case
2
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Newest"
// 按照时间降序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
1
,
sortKind
:
1
)
break
case
3
:
self
.
currentHeaderView
!.
selectlabel
.
text
=
"Oldest"
// 按照时间升序
self
.
datas
=
viewModel
.
sortRsource
(
resource
:
self
.
datas
,
sortType
:
0
,
sortKind
:
1
)
break
default
:
break
}
var
finalData
:
[
String
]
=
[]
for
item
in
self
.
datas
{
finalData
.
append
(
item
.
ident
)
}
self
.
resourceData
=
finalData
self
.
collectionView
.
reloadData
()
}
return
date1
>
date2
}
}
else
{
assetsWithDate
=
assetsWithSize
.
sorted
{
guard
let
date1
=
$0
.
asset
.
creationDate
,
let
date2
=
$1
.
asset
.
creationDate
else
{
return
false
}
return
date1
<
date2
}
}
var
sources
:[
String
]
=
[]
for
item
in
assetsWithDate
{
sources
.
append
(
item
.
asset
.
localIdentifier
)
}
self
.
resourceData
=
sources
}
}
}
PhoneManager/Class/Session/Home/Controller/HomeViewController.swift
View file @
7e531da8
...
...
@@ -60,6 +60,11 @@ class HomeViewController:BaseViewController {
if
otherItemRow
==
2
||
otherItemRow
==
4
{
DispatchQueue
.
main
.
async
{
let
vc
:
HomePhotosDetailViewController
=
HomePhotosDetailViewController
(
model
:
model
)
if
otherItemRow
==
2
{
vc
.
mediaType
=
.
screenshots
}
else
{
vc
.
mediaType
=
.
Other
}
vc
.
dealData
()
self
.
navigationController
?
.
pushViewController
(
vc
,
animated
:
true
)
}
...
...
PhoneManager/Class/Session/Home/View/VideoDetaiNavView.swift
View file @
7e531da8
...
...
@@ -54,7 +54,7 @@ class VideoDetaiNavView : UIView {
self
.
addSubview
(
self
.
seletedAllBtn
)
self
.
seletedAllBtn
.
snp
.
makeConstraints
{
make
in
make
.
right
.
equalToSuperview
()
.
offset
(
-
15
)
make
.
right
.
equalToSuperview
()
.
offset
(
-
23
)
make
.
centerY
.
equalTo
(
self
.
backButton
.
snp
.
centerY
)
}
...
...
PhoneManager/Class/Session/Secret/PMShowImgVideoController.swift
View file @
7e531da8
...
...
@@ -231,19 +231,6 @@ extension PMShowImgVideoController : UICollectionViewDelegate,UICollectionViewDa
completion
(
nil
,
NSError
(
domain
:
"com.example.error"
,
code
:
1
,
userInfo
:
[
NSLocalizedDescriptionKey
:
"未找到对应视频资源"
]))
return
}
PHPhotoLibrary
.
requestAuthorization
{
status
in
switch
status
{
case
.
authorized
:
print
(
"Access granted"
)
case
.
denied
,
.
restricted
:
print
(
"Access denied"
)
case
.
notDetermined
:
print
(
"Access not determined"
)
@unknown
default
:
print
(
"Unhandled authorization status"
)
}
}
let
options
=
PHVideoRequestOptions
()
options
.
isNetworkAccessAllowed
=
true
// 允许从网络下载
...
...
PhoneManager/Class/Tool/Class/PhotoAndVideoMananger/PhotoAndVideoMananger.swift
View file @
7e531da8
...
...
@@ -799,6 +799,37 @@ class PhotoAndVideoMananger {
// MARK: - 处理截图数据-------------------------------------------------------
/// 获取视频第一帧
/// - Parameters:
/// - ident: 视频的标识
/// - finished: 完成回调
func
getVideoImageByIdent
(
ident
:
String
,
finished
:
@escaping
(
UIImage
)
->
Void
,
errorHandler
:
@escaping
()
->
Void
){
// 定义请求选项来获取视频的第一帧
let
options
=
PHImageRequestOptions
()
// 获取当前版本的照片或视频
options
.
version
=
.
current
// 尽可能快地提供结果
options
.
deliveryMode
=
.
opportunistic
// 允许从iCloud请求
options
.
isNetworkAccessAllowed
=
true
// 异步请求
options
.
isSynchronous
=
true
// 从 PHAsset 获取 AVAsset
if
let
videoAsset
=
PhotoAndVideoMananger
.
mananger
.
getPHAsssetwithID
(
ids
:
[
ident
]){
// 使用requestImageForAsset方法请求视频的第一帧图片
PHImageManager
.
default
()
.
requestImage
(
for
:
videoAsset
,
targetSize
:
CGSize
(
width
:
400
,
height
:
400
),
contentMode
:
PHImageContentMode
.
aspectFit
,
options
:
options
)
{
image
,
_
in
// 处理获取到的图片
if
let
thumbnailImage
=
image
{
// 使用获取到的图片,例如显示在UIImageView上
finished
(
thumbnailImage
)
}
else
{
errorHandler
()
}
}
}
}
}
...
...
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