Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
1
1weather
Overview
Overview
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
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Dmitriy Stepanets
1weather
Commits
87fbe6fe
Commit
87fbe6fe
authored
Aug 16, 2021
by
Dmitriy Stepanets
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added custom dot animation
parent
f08763a3
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
57 additions
and
34 deletions
+57
-34
1Weather/AppDelegate.swift
+10
-3
1Weather/UI/View controllers/Onboarding/InitialOnboarding/OnboardingPageControl.swift
+47
-31
No files found.
1Weather/AppDelegate.swift
View file @
87fbe6fe
...
@@ -80,9 +80,16 @@ class AppDelegate: UIResponder, UIApplicationDelegate {
...
@@ -80,9 +80,16 @@ class AppDelegate: UIResponder, UIApplicationDelegate {
FirebaseApp
.
configure
()
FirebaseApp
.
configure
()
ConfigManager
.
shared
.
updateConfig
()
ConfigManager
.
shared
.
updateConfig
()
//App UI
#if DEBUG
let
appCoordinator
=
AppCoordinator
(
window
:
self
.
window
!
)
let
ctr
=
OnboardingPageController
(
coordinator
:
AppCoordinator
(
window
:
self
.
window
!
))
appCoordinator
.
start
()
window
?
.
rootViewController
=
ctr
window
?
.
makeKeyAndVisible
()
#else
#endif
// //App UI
// let appCoordinator = AppCoordinator(window: self.window!)
// appCoordinator.start()
ThemeManager
.
setBaseTheme
()
ThemeManager
.
setBaseTheme
()
...
...
1Weather/UI/View controllers/Onboarding/InitialOnboarding/OnboardingPageControl.swift
View file @
87fbe6fe
...
@@ -11,10 +11,24 @@ class OnboardingPageControl: UIView {
...
@@ -11,10 +11,24 @@ class OnboardingPageControl: UIView {
//Private
//Private
private
let
kSpacePerDot
:
CGFloat
=
10
private
let
kSpacePerDot
:
CGFloat
=
10
private
let
kDotSize
:
CGSize
=
.
init
(
width
:
9
,
height
:
9
)
private
let
kDotSize
:
CGSize
=
.
init
(
width
:
9
,
height
:
9
)
private
let
kIndicatorSize
:
CGSize
=
.
init
(
width
:
6
,
height
:
6
)
private
let
kIndicatorSize
:
CGSize
=
.
init
(
width
:
23
,
height
:
9
)
private
let
kDotColor
=
UIColor
(
hex
:
0xD0D0D0
)
private
let
kIndicatorColor
=
ThemeManager
.
currentTheme
.
graphTintColor
private
let
totalPagesCount
:
Int
private
let
totalPagesCount
:
Int
private
let
indicator
=
UIView
()
private
var
dots
=
[
UIView
]()
private
var
dots
=
[
UIView
]()
private
lazy
var
dotColorComponents
:
(
red
:
CGFloat
,
green
:
CGFloat
,
blue
:
CGFloat
)
=
{
let
components
=
kDotColor
.
cgColor
.
components
return
(
components
?[
0
]
??
0
,
components
?[
1
]
??
0
,
components
?[
2
]
??
0
)
}()
private
lazy
var
indicatorColorComponents
:
(
red
:
CGFloat
,
green
:
CGFloat
,
blue
:
CGFloat
)
=
{
let
components
=
kIndicatorColor
.
cgColor
.
components
return
(
components
?[
0
]
??
0
,
components
?[
1
]
??
0
,
components
?[
2
]
??
0
)
}()
init
(
totalPagesCount
:
Int
)
{
init
(
totalPagesCount
:
Int
)
{
self
.
totalPagesCount
=
totalPagesCount
self
.
totalPagesCount
=
totalPagesCount
...
@@ -22,7 +36,6 @@ class OnboardingPageControl: UIView {
...
@@ -22,7 +36,6 @@ class OnboardingPageControl: UIView {
prepareView
()
prepareView
()
prepareDots
()
prepareDots
()
prepareIndicator
()
}
}
required
init
?(
coder
:
NSCoder
)
{
required
init
?(
coder
:
NSCoder
)
{
...
@@ -37,25 +50,33 @@ class OnboardingPageControl: UIView {
...
@@ -37,25 +50,33 @@ class OnboardingPageControl: UIView {
let
targetDot
=
dots
[
nextPageIndex
]
let
targetDot
=
dots
[
nextPageIndex
]
let
previousDot
=
dots
[
currentPageIndex
]
let
previousDot
=
dots
[
currentPageIndex
]
//
Scale
//
Width
let
scaleDelta
=
(
kDotSize
.
width
-
kIndicator
Size
.
width
)
*
scrollProgress
let
widthDelta
=
(
kIndicatorSize
.
width
-
kDot
Size
.
width
)
*
scrollProgress
targetDot
.
snp
.
updateConstraints
{
update
in
targetDot
.
snp
.
updateConstraints
{
update
in
update
.
width
.
equalTo
(
kDotSize
.
width
-
scaleDelta
)
update
.
width
.
equalTo
(
kDotSize
.
width
+
widthDelta
)
update
.
height
.
equalTo
(
kDotSize
.
height
-
scaleDelta
)
}
}
targetDot
.
layer
.
cornerRadius
=
(
kDotSize
.
height
-
scaleDelta
)
/
2
previousDot
.
snp
.
updateConstraints
{
update
in
previousDot
.
snp
.
updateConstraints
{
update
in
update
.
width
.
equalTo
(
kIndicatorSize
.
width
+
scaleDelta
)
update
.
width
.
equalTo
(
kIndicatorSize
.
width
-
widthDelta
)
update
.
height
.
equalTo
(
kIndicatorSize
.
height
+
scaleDelta
)
}
}
previousDot
.
layer
.
cornerRadius
=
(
kIndicatorSize
.
height
+
scaleDelta
)
/
2
//Offset
//Color
let
offsetDelta
=
targetDot
.
frame
.
origin
.
x
-
previousDot
.
frame
.
origin
.
x
//Blue to gray
indicator
.
snp
.
updateConstraints
{
update
in
let
previousColorDelta
:
(
red
:
CGFloat
,
green
:
CGFloat
,
blue
:
CGFloat
)
=
(
indicatorColorComponents
.
red
-
dotColorComponents
.
red
,
update
.
left
.
equalToSuperview
()
.
inset
(
previousDot
.
frame
.
origin
.
x
+
offsetDelta
*
scrollProgress
)
indicatorColorComponents
.
green
-
dotColorComponents
.
green
,
}
indicatorColorComponents
.
blue
-
dotColorComponents
.
blue
)
previousDot
.
backgroundColor
=
UIColor
(
red
:
indicatorColorComponents
.
red
-
previousColorDelta
.
red
*
scrollProgress
,
green
:
indicatorColorComponents
.
green
-
previousColorDelta
.
green
*
scrollProgress
,
blue
:
indicatorColorComponents
.
blue
-
previousColorDelta
.
blue
*
scrollProgress
,
alpha
:
1
)
//Gray to blue
let
targetColorDelta
:
(
red
:
CGFloat
,
green
:
CGFloat
,
blue
:
CGFloat
)
=
(
dotColorComponents
.
red
-
indicatorColorComponents
.
red
,
dotColorComponents
.
green
-
indicatorColorComponents
.
green
,
dotColorComponents
.
blue
-
indicatorColorComponents
.
blue
)
targetDot
.
backgroundColor
=
UIColor
(
red
:
dotColorComponents
.
red
-
targetColorDelta
.
red
*
scrollProgress
,
green
:
dotColorComponents
.
green
-
targetColorDelta
.
green
*
scrollProgress
,
blue
:
dotColorComponents
.
blue
-
targetColorDelta
.
blue
*
scrollProgress
,
alpha
:
1
)
}
}
}
}
...
@@ -70,7 +91,7 @@ private extension OnboardingPageControl {
...
@@ -70,7 +91,7 @@ private extension OnboardingPageControl {
func
prepareDots
()
{
func
prepareDots
()
{
for
index
in
0
..<
totalPagesCount
{
for
index
in
0
..<
totalPagesCount
{
let
dot
=
UIView
()
let
dot
=
UIView
()
dot
.
backgroundColor
=
UIColor
(
hex
:
0xD0D0D0
)
dot
.
backgroundColor
=
index
==
0
?
kIndicatorColor
:
kDotColor
dot
.
layer
.
cornerRadius
=
kDotSize
.
height
/
2
dot
.
layer
.
cornerRadius
=
kDotSize
.
height
/
2
addSubview
(
dot
)
addSubview
(
dot
)
dots
.
append
(
dot
)
dots
.
append
(
dot
)
...
@@ -78,23 +99,18 @@ private extension OnboardingPageControl {
...
@@ -78,23 +99,18 @@ private extension OnboardingPageControl {
dot
.
snp
.
makeConstraints
{
make
in
dot
.
snp
.
makeConstraints
{
make
in
make
.
size
.
equalTo
(
index
==
0
?
kIndicatorSize
:
kDotSize
)
make
.
size
.
equalTo
(
index
==
0
?
kIndicatorSize
:
kDotSize
)
make
.
centerY
.
equalToSuperview
()
make
.
centerY
.
equalToSuperview
()
make
.
left
.
equalToSuperview
()
.
inset
(
CGFloat
(
index
)
*
(
kDotSize
.
width
+
kSpacePerDot
))
if
index
==
0
{
make
.
left
.
equalToSuperview
()
}
else
{
make
.
left
.
equalTo
(
dots
[
index
-
1
]
.
snp
.
right
)
.
offset
(
kSpacePerDot
)
}
if
index
==
totalPagesCount
-
1
{
if
index
==
totalPagesCount
-
1
{
make
.
right
.
equalToSuperview
()
make
.
right
.
equalToSuperview
()
}
}
}
}
}
}
}
}
func
prepareIndicator
()
{
indicator
.
backgroundColor
=
ThemeManager
.
currentTheme
.
graphTintColor
indicator
.
layer
.
cornerRadius
=
kIndicatorSize
.
height
/
2
addSubview
(
indicator
)
indicator
.
snp
.
makeConstraints
{
make
in
make
.
left
.
equalToSuperview
()
make
.
centerY
.
equalToSuperview
()
make
.
size
.
equalTo
(
kIndicatorSize
)
}
}
}
}
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