Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

GUI Stilization #4

Open
EvilLord666 opened this issue Dec 28, 2017 · 6 comments
Open

GUI Stilization #4

EvilLord666 opened this issue Dec 28, 2017 · 6 comments
Assignees

Comments

@EvilLord666
Copy link
Member

We should use styles for achieving a good looking UI. Perhaps we should take it from one of the themes

@EvilLord666
Copy link
Member Author

We should select theme in settings (we should add a button for changes)
Styles and resources for themes should be described in app resources file

@Edisson
Copy link

Edisson commented Jan 28, 2018

ok, working on it

@EvilLord666
Copy link
Member Author

deal! 👍

@Edisson
Copy link

Edisson commented Jan 29, 2018

Mike, let's choose one of the methods are able in WPF for skin loading.


The first method: using Loose XAML

  • Loose skin mechanism is based on loose XAML files which are actually resource dictionaries.

Here are
Pros

  • Loose XAML files are dynamic, thus can be edited online and offline (whether the application is running or not), without compiling or parsing.

Cons

  • Slow load time since each loose XAML file should be parsed and tokenized at runtime.
  • Not safe since it can be edited without any build/compile action.

The second method: Compiled

  • Compiled skin mechanism is based on resource dictionaries inside XAML files, which are parsed, serialized (baml) and packed into the governed assembly.

Pros

  • Fast load time.
  • Safe since being parsed, tokenized and serialized.
  • Custom types are usually compiled into the same assembly.
  • Can be shared by placing the assembly in the GAC.

Cons

  • Must be loaded into the running application (AppDomain) to take effect.
  • Once loaded can't be unloaded until restarting the application. This consumes a lot of memory depending on the assembly size and the amount of skins.
  • Static, and should be parsed, serialized (baml) and packed into the governed assembly.
  • Can't be loaded unless referenced (add reference to assembly) at design time.

If we plan to have only two skins in this app I guess it wouldn't be so bad to use "Compiled" variant, isn't it?

@EvilLord666
Copy link
Member Author

What about https://github.com/MahApps/MahApps.Metro This project have net4.0 project, we could possibly use it via nuget or via github dependent project

@Edisson
Copy link

Edisson commented Mar 1, 2018

Yeah, I looked at it, it isn't really bad!
We can adopt it.

The point is there are two almost similar ways to switch between the themes of an app (I don't speak about themes from dll variant now):
it is necessary to add xaml files in project, Do smth like merge resource dictionaries and apply this or that style from xaml but they have to be loaded in pre-compile stage!
I started doing the same thing as in mentioned nuget package.
Currently there are some issues with stylization of some controls but using this package might be helpful.
Need to consider it in detail.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants