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

[Other Issues]: Is it possible to use this framework to more resemble Win10/Material design ? #114

Open
lorinkundert opened this issue May 28, 2021 · 27 comments
Labels
answered This question has been adequately answered. area:themes All things to do with themes. question Further information is requested version:100 All things to do with V100.
Milestone

Comments

@lorinkundert
Copy link

Today many tools are focused on an interface that more resembles Win10/Material design, your framework is capable but there is some padded area immediately starting from the inner border of the window to the other controls, this leaves a large gap along the edges, how can that be removed? changes to border width do not affect it.

@lorinkundert lorinkundert added discussion Discussion thread. other All other issues. labels May 28, 2021
@Smurf-IV
Copy link
Member

Can you show an "enlarged" image of what you are seeing please.
(Show the document tree as well if you can)
I have been able to get the Krypton control(s) right into the edges, so it might be something to with the hierarchy of padding and margins of the parent up the tree to the form.

@lorinkundert
Copy link
Author

lorinkundert commented May 28, 2021

Border

The Ribbon and Statusbar never touch the edge of the form

@PWagner1
Copy link
Contributor

I would add the Feature Request and/or Enhancement tag(s) to this thread. Seems that a BorderWidth option needs to be added to the KryptonForm.

@Smurf-IV
Copy link
Member

Smurf-IV commented May 28, 2021

No.. It's the AllowFormChrome setting:
image

But: The bug is then that the Title bar is not rendered.
If you do not want a title bar or borders (i.e. to have full control over the layout) then use the following:
FormBorderStyle = FormBorderStyle.None

@Smurf-IV Smurf-IV added answered This question has been adequately answered. question Further information is requested wontfix This will not be worked on and removed discussion Discussion thread. other All other issues. labels May 29, 2021
@Smurf-IV Smurf-IV changed the title [Other Issues]: Would not call this a bug, but rather information [Other Issues]: Is it possible to use this framework to more resemble Win10/Material design ? May 29, 2021
@lorinkundert
Copy link
Author

What we will need is access to 'Border.Padding' it is usually fixed in the registry system wide which mine is so KryptonForm needs it.

@Smurf-IV
Copy link
Member

If you want padding, then just place a Panel on the form, and setting padding / margins in that..
I'm not following what else is needed if "Border.Padding" is not the drawing of a border ??

@lorinkundert
Copy link
Author

desired effect

We need this kind of window, theme is unimportant

@DarthVader85PA
Copy link

desired effect

We need this kind of window, theme is unimportant

Hello @ALL,

I think this looks like a Metro-Framework or WPF? Krypton is not yet a Metro-Control-Set. Perhaps you have a look to a NuGet-Package with Metro-Controls like MetroFramework-Modern-UI: https://github.com/dennismagno/metroframework-modern-ui

@Wagnerp and @Smurf-IV:
Perhaps can be a theme bring a solution?

Greetings from Germany,
Danny

@Smurf-IV
Copy link
Member

Interesting..
Even with that framework there is a border:
image

@Smurf-IV
Copy link
Member

Smurf-IV commented May 31, 2021

A solution would be to set AllowFormChrome to false, and fix the Themed title bar, and the above "LSD Tool" look would be possible without any modifications to Krypton drawing for everything else.

Another Solution is the FormBorderStyle = FormBorderStyle.None, and use panels and Normal Krypton controls to perform the Drag Drop / Sizing.

The first is a bug, and would then be simple (Once fixed).
The 2nd means no Krypton Code changes, but more work on the developer to simulate windows Drag Drop / Sizing.

@Smurf-IV
Copy link
Member

Quick demo of Option 2:
image

@Smurf-IV
Copy link
Member

Smurf-IV commented May 31, 2021

And with the black theme:
image

@PWagner1
Copy link
Contributor

desired effect
We need this kind of window, theme is unimportant

Hello @ALL,

I think this looks like a Metro-Framework or WPF? Krypton is not yet a Metro-Control-Set. Perhaps you have a look to a NuGet-Package with Metro-Controls like MetroFramework-Modern-UI: https://github.com/dennismagno/metroframework-modern-ui

@Wagnerp and @Smurf-IV:
Perhaps can be a theme bring a solution?

Greetings from Germany,
Danny

Now that would be interesting, maybe in a future update?

@lorinkundert
Copy link
Author

This is from ComponentOne, commercial product, I want to get away from the problems with handling the licenses. I know what the problem is though, the border and border padding at the form level are really window level, it's what gave Windows 7 that ugly fat border, from glancing at your code I t seems you get the default system metrics but we need to get the current metrics. I modifed the registry to eliminate that padding and it works on every window except Krypton, so something is missing, if I can find it, I will let you know.

@lorinkundert
Copy link
Author

lorinkundert commented Jun 1, 2021

Themes can change the padding according to Microsoft, so I will start with the chrome code and metrics. This is how ComponentOne did it, through the theme engine.

@lorinkundert
Copy link
Author

This is where that property is

[DllImport("user32.dll")]
static extern int GetSystemMetrics(92);

CXPADDEDBORDER = 92, // 0x5C

@Smurf-IV
Copy link
Member

Smurf-IV commented Jun 4, 2021

@lorinkundert
Does #139, cover this now ?
Please close this if it does - Thanks

@Smurf-IV
Copy link
Member

Smurf-IV commented Jun 6, 2021

Note:
An active Material Design Winform UI kit:
https://github.com/leocb/MaterialSkin

@PWagner1
Copy link
Contributor

PWagner1 commented Jun 6, 2021

@Smurf-IV Is this best suited for the Extended Toolkit?

@Smurf-IV
Copy link
Member

Smurf-IV commented Jun 6, 2021

No.
When the Fixes related to this are done, then it will just be a Theme (like the Office 365 variants) that will need to be added to the Standard toolkit.

@Smurf-IV Smurf-IV added the area:themes All things to do with themes. label Jun 11, 2021
@Smurf-IV Smurf-IV removed the wontfix This will not be worked on label Jul 16, 2022
@AngeloCresta
Copy link

Yes, it's possible to create a sort of "proxy class" to interface the ModernUI framework with Krypton, I've started this week ...
here some screen shots:
image
image
image
image

the form is a modern form, and on change style/theme event will "customize" the krypton palette on the fly.

@PWagner1
Copy link
Contributor

PWagner1 commented Dec 7, 2022

@AngeloCresta I think the #827 will help with this, as I think the current XML implementation is too complex to understand.

@AngeloCresta
Copy link

Actually, you don't need to use the xml, you can just set the color values on a custom palette ad assign it back to the krypton manager, like in this snippet:

`

        //init base palette
        KryptonPalette kryptonPaletteOffice365Black = new KryptonPalette();
        KryptonPalette kryptonPaletteOffice365Silver = new KryptonPalette();

        kryptonPaletteOffice365Black.BasePaletteMode = PaletteMode.Office365Black;
        kryptonPaletteOffice365Silver.BasePaletteMode = PaletteMode.Office365Silver;

        //set according to metro style
        if (mts == ModernThemeStyle.Dark)
        kryptonManager.GlobalPalette = kryptonPaletteOffice365Black;        
        else
        kryptonManager.GlobalPalette = kryptonPaletteOffice365Silver;
        
        //init color management
        KryptonPalette kp = new KryptonPalette();
        try
        {kp.BasePalette = (KryptonPalette)kryptonManager.GlobalPalette;}
        catch (Exception ex)
        {Debug.WriteLine(ex.Message);}

        //round?
        int round = 0;

        //color proxy for buttons common
        kp.ButtonStyles.ButtonCommon.StateNormal.Back.ColorStyle = PaletteColorStyle.Solid;
        kp.ButtonStyles.ButtonCommon.StateNormal.Back.Color1 = Color.Gray;
        kp.ButtonStyles.ButtonCommon.StateNormal.Back.Color2 = Color.Gray;
        kp.ButtonStyles.ButtonCommon.StateNormal.Border.Color1 = Color.DarkGray;
        kp.ButtonStyles.ButtonCommon.StateNormal.Border.Color2 = Color.DarkGray;
        kp.ButtonStyles.ButtonCommon.StateNormal.Content.ShortText.Color1 = Color.Black;
        kp.ButtonStyles.ButtonCommon.StateNormal.Content.ShortText.Color2 = Color.Black;
        kp.ButtonStyles.ButtonCommon.StateNormal.Content.LongText.Color1 = Color.Black;
        kp.ButtonStyles.ButtonCommon.StateNormal.Content.LongText.Color2 = Color.Black;
        kp.ButtonStyles.ButtonCommon.StateNormal.Border.Rounding = round;

        kp.ButtonStyles.ButtonCommon.StateTracking.Back.ColorStyle = PaletteColorStyle.Solid;
        kp.ButtonStyles.ButtonCommon.StateTracking.Back.Color1 = Color.Red;
        kp.ButtonStyles.ButtonCommon.StateTracking.Back.Color2 = Color.Red; 
        kp.ButtonStyles.ButtonCommon.StateTracking.Border.Color1 = Color.Pink;
        kp.ButtonStyles.ButtonCommon.StateTracking.Border.Color2 = Color.Pink;
        kp.ButtonStyles.ButtonCommon.StateTracking.Content.ShortText.Color1 = Color.White;
        kp.ButtonStyles.ButtonCommon.StateTracking.Content.ShortText.Color2 = Color.White; 
        kp.ButtonStyles.ButtonCommon.StateTracking.Content.LongText.Color1 = Color.White; 
        kp.ButtonStyles.ButtonCommon.StateTracking.Content.LongText.Color2 = Color.White; 
        kp.ButtonStyles.ButtonCommon.StateTracking.Border.Rounding = round;

        //.....

        //set back the customized palette to krypton manager
        kryptonManager.GlobalPalette = kp;
        kryptonManager.GlobalPaletteMode = PaletteModeManager.Custom;

`
I've used this approach for my proxy class, creating a specific function where the KryptonManager is passed and new values are set according to some events (ModernUI or MetroUI changing theme or style).
All the relevant color properties are exposed.

image

Regards,
Angelo
(AdvancedComputing - Extended Renderer .... ;) )

@PWagner1
Copy link
Contributor

Hi @AngeloCresta

Looks good, no what I meant is rather than using XML files, allow the KryptonManager to 'import' class files, based on PaletteBase, which I think is similar to what you're attempting to do?

cc @Smurf-IV

@Smurf-IV
Copy link
Member

based on PaletteBase

will be IPaletteBase, so that any implementation of Serialisation by the developer can be used.

IPaletteBase may (will) be extended to allow up to date functionality, once I get my head round it's usage within the Krypton components (It's big !)

@Smurf-IV
Copy link
Member

I think that this is "Now possible" via a New theme and either the use of the new setting in

  • #124, When setting AllowFormChrome = false, then the Form Bar should still be Theme rendered
    • AllowFormChrome has been removed and replaced with UseThemeFormChromeBorderWidth to better explain what it is doing
    • It means that a theme can get closer to "Material Design", and that the Title bar can still be themed (And rounded)

or

via setting the "Border width" to be 2 in the palette designer..

@Smurf-IV Smurf-IV added the version:100 All things to do with V100. label Jul 7, 2024
@Smurf-IV Smurf-IV added this to the Version 100 milestone Jul 7, 2024
@Smurf-IV
Copy link
Member

Smurf-IV commented Jul 7, 2024

This needs a revisit and probably a checklist of items to make Krypton "Flat" and "Metro"-able...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
answered This question has been adequately answered. area:themes All things to do with themes. question Further information is requested version:100 All things to do with V100.
Projects
None yet
Development

No branches or pull requests

5 participants