HISE Logo Forum
    • Categories
    • Register
    • Login

    Plugin doesn't respect UI Zoom Factor onInit

    Scheduled Pinned Locked Moved Scripting
    25 Posts 6 Posters 3.0k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • d.healeyD
      d.healey @ccbl
      last edited by

      @ccbl Have you set the buttons to save in preset?

      Free HISE Bootcamp Full Course for beginners.
      YouTube Channel - Public HISE tutorials
      My Patreon - HISE tutorials

      C 1 Reply Last reply Reply Quote 0
      • C
        ccbl @d.healey
        last edited by

        @d-healey Save in Preset is enabled yeah

        d.healeyD 1 Reply Last reply Reply Quote 0
        • d.healeyD
          d.healey @ccbl
          last edited by d.healey

          @ccbl Which button did you have enabled when you exported your plugin (or in the default preset if you're using one)?

          You can also condense your code quite a bit.

          const buttons = Content.getAllComponents("Button\\d"); // This assumes all your buttons are called "Button" - give them a sensible name of course.
          
          for (x in buttons)
              x.setControlCallback(onButtonControl);
          	
          inline function onButtonControl(component, value)
          {
              local index = buttons.indexOf(component);
              local values = [0.5, 0.75, 1.0];
          
              Settings.setZoomLevel(values[index]);
          }
          

          Free HISE Bootcamp Full Course for beginners.
          YouTube Channel - Public HISE tutorials
          My Patreon - HISE tutorials

          C MorphoiceM 2 Replies Last reply Reply Quote 0
          • C
            ccbl @d.healey
            last edited by

            @d-healey The 50% button is the default, and that is the one that is pressed upon export.

            d.healeyD 1 Reply Last reply Reply Quote 0
            • d.healeyD
              d.healey @ccbl
              last edited by

              @ccbl Does using Engine.setZoomLevel make a difference?

              Free HISE Bootcamp Full Course for beginners.
              YouTube Channel - Public HISE tutorials
              My Patreon - HISE tutorials

              C 1 Reply Last reply Reply Quote 0
              • C
                ccbl @d.healey
                last edited by

                @d-healey I'll give it a try. I used

                Settings.setZoomLevel(0.5)
                

                because the compiler said that

                Engine.setZoomLevel
                

                was depreciated.

                d.healeyD 1 Reply Last reply Reply Quote 0
                • d.healeyD
                  d.healey @ccbl
                  last edited by

                  @ccbl ah case in that case it probably won't help

                  Free HISE Bootcamp Full Course for beginners.
                  YouTube Channel - Public HISE tutorials
                  My Patreon - HISE tutorials

                  C 1 Reply Last reply Reply Quote 0
                  • C
                    ccbl @d.healey
                    last edited by

                    @d-healey yeah it didn't make a difference. Do you think it could be the buttons being in a radio group that is messing things up? Or do you think that it's just the script doesn't read the state of the buttons until one of them is pressed for the first time?

                    Still a little puzzled why Settings.setZoomLevel(0.5); outside of the button callbacks doesn't correctly set the zoom level on init though.

                    oskarshO 1 Reply Last reply Reply Quote 0
                    • oskarshO
                      oskarsh @ccbl
                      last edited by

                      @ccbl when using toggle buttons make sure to always use if (value) {}

                      if (value) { Settings.setZoomLevel(0.75); }

                      in your case the callback fires for each button and executes the statement even if the button value is false but it should only set the value when its true.

                      that should do the trick.

                      C 1 Reply Last reply Reply Quote 0
                      • C
                        ccbl @oskarsh
                        last edited by

                        @oskarsh how would that look in context?

                        inline function onFiftyControl(component, value)
                        {
                        	Settings.setZoomLevel(0.5);
                        };
                        Content.getComponent("Fifty").setControlCallback(onFiftyControl)
                        

                        Do you define the value as 1.0?

                        I really don't know coding very well.

                        d.healeyD LindonL 2 Replies Last reply Reply Quote 0
                        • MorphoiceM
                          Morphoice @d.healey
                          last edited by Morphoice

                          @d-healey just out of interest, is there a way to detect the screen resolution by any chance? it would be a nice way to set a default zoom level accordingly so the user doesn't have to. e.g. I'm always having a hard time on a 5k monitor with plugins being microscopic and many manufacturers aren't even bothered to make the GUI sizable at all... those are the plugins I ususally don't buy because they are unusable for me. I have a ruptured retina and very poor eyesight so I'm naturally paying attention to usability and visibility a lot

                          https://instagram.com/morphoice - 80s inspired Synthwave Music, Arcade & Gameboy homebrew!

                          ustkU 1 Reply Last reply Reply Quote 0
                          • ustkU
                            ustk @Morphoice
                            last edited by ustk

                            @Morphoice Settings.getUserDesktopSize() might help you

                            Hise made me an F5 dude, browser just suffers...

                            1 Reply Last reply Reply Quote 0
                            • d.healeyD
                              d.healey @ccbl
                              last edited by

                              @ccbl Setting it in on init won't work because the button callbacks are triggered after on init so it will overwrite it.

                              Just as a test, what happens if you disable saveInPreset on all the buttons, except the one you want?

                              Free HISE Bootcamp Full Course for beginners.
                              YouTube Channel - Public HISE tutorials
                              My Patreon - HISE tutorials

                              MorphoiceM 1 Reply Last reply Reply Quote 0
                              • MorphoiceM
                                Morphoice @d.healey
                                last edited by

                                @d-healey saving the gui size in a preset doesn't make much sense though, so disabling that shouldn't be a problem

                                https://instagram.com/morphoice - 80s inspired Synthwave Music, Arcade & Gameboy homebrew!

                                d.healeyD 1 Reply Last reply Reply Quote 0
                                • d.healeyD
                                  d.healey @Morphoice
                                  last edited by

                                  @Morphoice said in Plugin doesn't respect UI Zoom Factor onInit:

                                  saving the gui size in a preset doesn't make much sense though, so disabling that shouldn't be a problem

                                  I'm just suggesting this as a test to figure out the source of the issue. But you don't want it to always open at 50% so we need to find a better solution after.

                                  Free HISE Bootcamp Full Course for beginners.
                                  YouTube Channel - Public HISE tutorials
                                  My Patreon - HISE tutorials

                                  ustkU 1 Reply Last reply Reply Quote 1
                                  • ustkU
                                    ustk @d.healey
                                    last edited by ustk

                                    @d-healey but the zoom level is always restored to the last state right? So why bother with all that? You just need to read what is the current zoom to reflect this to the right button, at least this is how I see it...

                                    Hise made me an F5 dude, browser just suffers...

                                    d.healeyD 1 Reply Last reply Reply Quote 0
                                    • d.healeyD
                                      d.healey @ustk
                                      last edited by

                                      @ustk said in Plugin doesn't respect UI Zoom Factor onInit:

                                      but the zoom level is always restored to the last state right?

                                      Only if you use the built in custom settings floating tile which saves it to the generalSettings.xml file.

                                      Free HISE Bootcamp Full Course for beginners.
                                      YouTube Channel - Public HISE tutorials
                                      My Patreon - HISE tutorials

                                      ustkU 1 Reply Last reply Reply Quote 0
                                      • ustkU
                                        ustk @d.healey
                                        last edited by ustk

                                        @d-healey Hmm... should be the same thing no? I thought it was always saved in the xml no matter where the call is coming from (when the plugin/standalone is closed)

                                        Hise made me an F5 dude, browser just suffers...

                                        d.healeyD 1 Reply Last reply Reply Quote 0
                                        • d.healeyD
                                          d.healey @ustk
                                          last edited by

                                          @ustk Yeah just tested and seems you are correct.

                                          Free HISE Bootcamp Full Course for beginners.
                                          YouTube Channel - Public HISE tutorials
                                          My Patreon - HISE tutorials

                                          1 Reply Last reply Reply Quote 0
                                          • LindonL
                                            Lindon @ccbl
                                            last edited by

                                            @ccbl said in Plugin doesn't respect UI Zoom Factor onInit:

                                            @oskarsh how would that look in context?

                                            inline function onFiftyControl(component, value)
                                            {
                                            	Settings.setZoomLevel(0.5);
                                            };
                                            Content.getComponent("Fifty").setControlCallback(onFiftyControl)
                                            

                                            Do you define the value as 1.0?

                                            I really don't know coding very well.

                                            so like this:

                                            inline function onFiftyControl(component, value)
                                            {
                                                if(value)
                                                    Settings.setZoomLevel(0.5);
                                            };
                                            Content.getComponent("Fifty").setControlCallback(onFiftyControl)
                                            

                                            HISE Development for hire.
                                            www.channelrobot.com

                                            d.healeyD oskarshO C 3 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            19

                                            Online

                                            2.0k

                                            Users

                                            12.7k

                                            Topics

                                            110.6k

                                            Posts