Switching between light and dark theme
up vote
0
down vote
favorite
I am following an article to implement light and dark theme for one of my apps. The article can be found here. In this article, an interesting approach is used to edit all colors at once so there is no need to change all labels, backgrounds, ... separately. The new theme is set like this:
private func setNewTheme(_ newTheme: AppTheme) {
let window = UIApplication.shared.delegate!.window!!
UIView.transition(
with: window,
duration: 0.3,
options: [.transitionCrossDissolve],
animations: {
self.theme.value = newTheme
},
completion: nil
)
}
I suggest to read the article to understand the entire working of this mechanism. This works great and changes my backgrounds, colors of the UITabBar, colors of the UINavigationController etc. However, in some of my UIViewControllers, there is a UICollectionView which I would like to update as well. The colors remain the same, but I guess I need to reload the data in order for it to work?
My question is; how could I implement a functionality where my UICollectionViews would be reloaded when the other theme is set?
If the article I am mentioning is not best practice, please guide me towards the best way to implement this feature.
ios swift uicollectionview themes
add a comment |
up vote
0
down vote
favorite
I am following an article to implement light and dark theme for one of my apps. The article can be found here. In this article, an interesting approach is used to edit all colors at once so there is no need to change all labels, backgrounds, ... separately. The new theme is set like this:
private func setNewTheme(_ newTheme: AppTheme) {
let window = UIApplication.shared.delegate!.window!!
UIView.transition(
with: window,
duration: 0.3,
options: [.transitionCrossDissolve],
animations: {
self.theme.value = newTheme
},
completion: nil
)
}
I suggest to read the article to understand the entire working of this mechanism. This works great and changes my backgrounds, colors of the UITabBar, colors of the UINavigationController etc. However, in some of my UIViewControllers, there is a UICollectionView which I would like to update as well. The colors remain the same, but I guess I need to reload the data in order for it to work?
My question is; how could I implement a functionality where my UICollectionViews would be reloaded when the other theme is set?
If the article I am mentioning is not best practice, please guide me towards the best way to implement this feature.
ios swift uicollectionview themes
2
You should use a Notification for this. Documentation for NotificationCenter: developer.apple.com/documentation/foundation/notificationcenter
– Tamás Sengel
Nov 15 at 1:01
add a comment |
up vote
0
down vote
favorite
up vote
0
down vote
favorite
I am following an article to implement light and dark theme for one of my apps. The article can be found here. In this article, an interesting approach is used to edit all colors at once so there is no need to change all labels, backgrounds, ... separately. The new theme is set like this:
private func setNewTheme(_ newTheme: AppTheme) {
let window = UIApplication.shared.delegate!.window!!
UIView.transition(
with: window,
duration: 0.3,
options: [.transitionCrossDissolve],
animations: {
self.theme.value = newTheme
},
completion: nil
)
}
I suggest to read the article to understand the entire working of this mechanism. This works great and changes my backgrounds, colors of the UITabBar, colors of the UINavigationController etc. However, in some of my UIViewControllers, there is a UICollectionView which I would like to update as well. The colors remain the same, but I guess I need to reload the data in order for it to work?
My question is; how could I implement a functionality where my UICollectionViews would be reloaded when the other theme is set?
If the article I am mentioning is not best practice, please guide me towards the best way to implement this feature.
ios swift uicollectionview themes
I am following an article to implement light and dark theme for one of my apps. The article can be found here. In this article, an interesting approach is used to edit all colors at once so there is no need to change all labels, backgrounds, ... separately. The new theme is set like this:
private func setNewTheme(_ newTheme: AppTheme) {
let window = UIApplication.shared.delegate!.window!!
UIView.transition(
with: window,
duration: 0.3,
options: [.transitionCrossDissolve],
animations: {
self.theme.value = newTheme
},
completion: nil
)
}
I suggest to read the article to understand the entire working of this mechanism. This works great and changes my backgrounds, colors of the UITabBar, colors of the UINavigationController etc. However, in some of my UIViewControllers, there is a UICollectionView which I would like to update as well. The colors remain the same, but I guess I need to reload the data in order for it to work?
My question is; how could I implement a functionality where my UICollectionViews would be reloaded when the other theme is set?
If the article I am mentioning is not best practice, please guide me towards the best way to implement this feature.
ios swift uicollectionview themes
ios swift uicollectionview themes
asked Nov 15 at 0:53
PennyWise
67110
67110
2
You should use a Notification for this. Documentation for NotificationCenter: developer.apple.com/documentation/foundation/notificationcenter
– Tamás Sengel
Nov 15 at 1:01
add a comment |
2
You should use a Notification for this. Documentation for NotificationCenter: developer.apple.com/documentation/foundation/notificationcenter
– Tamás Sengel
Nov 15 at 1:01
2
2
You should use a Notification for this. Documentation for NotificationCenter: developer.apple.com/documentation/foundation/notificationcenter
– Tamás Sengel
Nov 15 at 1:01
You should use a Notification for this. Documentation for NotificationCenter: developer.apple.com/documentation/foundation/notificationcenter
– Tamás Sengel
Nov 15 at 1:01
add a comment |
1 Answer
1
active
oldest
votes
up vote
0
down vote
Look at here.
I think this repo can give u some suggestion.
add a comment |
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
0
down vote
Look at here.
I think this repo can give u some suggestion.
add a comment |
up vote
0
down vote
Look at here.
I think this repo can give u some suggestion.
add a comment |
up vote
0
down vote
up vote
0
down vote
Look at here.
I think this repo can give u some suggestion.
Look at here.
I think this repo can give u some suggestion.
answered Nov 15 at 1:56
Kirinzer
111
111
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53310951%2fswitching-between-light-and-dark-theme%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
2
You should use a Notification for this. Documentation for NotificationCenter: developer.apple.com/documentation/foundation/notificationcenter
– Tamás Sengel
Nov 15 at 1:01