HISE Logo Forum
    • Categories
    • Register
    • Login

    Images in a Viewport

    Scheduled Pinned Locked Moved General Questions
    25 Posts 2 Posters 1.1k 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.
    • DanHD
      DanH
      last edited by

      Apologies if this has been asked already, but are there any examples of displaying images in a viewport?

      DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
      https://dhplugins.com/ | https://dcbreaks.com/
      London, UK

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

        @DanH put panel in viewport, use paint routine

        Libre Wave - Freedom respecting instruments and effects
        My Patreon - HISE tutorials
        YouTube Channel - Public HISE tutorials

        DanHD 2 Replies Last reply Reply Quote 0
        • DanHD
          DanH @d.healey
          last edited by

          @d-healey ok so basically use a panel! I'm using the viewport as a user menu to load table shapes. I'd like to display the shape of the table next to the name of the preset shape. I guess I could insert a panel next to the names perhaps and populate it with the correct images.... Perhaps I should shift this idea into a panel...

          DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
          https://dhplugins.com/ | https://dcbreaks.com/
          London, UK

          1 Reply Last reply Reply Quote 0
          • DanHD
            DanH @d.healey
            last edited by

            @d-healey would a button pack be a good choice for this?

            Link Preview Image
            HISE | Docs

            favicon

            (docs.hise.audio)

            DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
            https://dhplugins.com/ | https://dcbreaks.com/
            London, UK

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

              @DanH I'd use a panel in the viewport and child panels for each list item

              Libre Wave - Freedom respecting instruments and effects
              My Patreon - HISE tutorials
              YouTube Channel - Public HISE tutorials

              DanHD 2 Replies Last reply Reply Quote 0
              • DanHD
                DanH @d.healey
                last edited by

                @d-healey actually maybe there's no need for the names.... just images would be nicer. I'll give it a go but if you know of any examples that would be very welcome!

                DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
                https://dhplugins.com/ | https://dcbreaks.com/
                London, UK

                1 Reply Last reply Reply Quote 0
                • DanHD
                  DanH @d.healey
                  last edited by

                  @d-healey getting somewhere. There's a lot of panel with images in. Can I create a for loop to manage their callbacks rather than writing out one for each panel / image?

                  const var SHAPEARRAY = [Content.getComponent("SHAPE1"), Content.getComponent("SHAPE2")];
                  
                  /// Panel Callbacks
                  SHAPE1.setMouseCallback(function(event)
                  {
                  	if (event.clicked)
                  	{
                  		PresetList.setValue(0);
                  		PresetList.changed();
                  	}
                  
                  });
                  
                  SHAPE2.setMouseCallback(function(event)
                  {
                  	if (event.clicked)
                  	{
                  		PresetList.setValue(1);
                  		PresetList.changed();
                  	}
                  
                  });
                  
                  

                  DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
                  https://dhplugins.com/ | https://dcbreaks.com/
                  London, UK

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

                    @DanH said in Images in a Viewport:

                    Can I create a for loop to manage their callbacks rather than writing out one for each panel / image?

                    You absolutely should do this. Start with 3 in a little test project to get the hang of it. They should all use the same callback function and probably the same paint routine.

                    Libre Wave - Freedom respecting instruments and effects
                    My Patreon - HISE tutorials
                    YouTube Channel - Public HISE tutorials

                    DanHD 1 Reply Last reply Reply Quote 0
                    • DanHD
                      DanH @d.healey
                      last edited by

                      @d-healey any chance of a hand with this please?! 😆

                      Getting confused on how to write the g.loadImage line... Getting the error: Interface:! Image ts[Array] not found... I mean I could be on totally the wrong path 😆

                      const var SHAPE1 = Content.getComponent("SHAPE1");
                      const var SHAPE2 = Content.getComponent("SHAPE2");
                      const var SHAPE3 = Content.getComponent("SHAPE3");
                      
                      const var SHAPESIMAGESARRAY = [
                                                     Content.getComponent("SHAPE1"),
                                                     Content.getComponent("SHAPE2"),
                                                     Content.getComponent("SHAPE3")];
                      
                      SHAPE1.loadImage("{PROJECT_FOLDER}AGAIN.png", "ts1");
                      SHAPE2.loadImage("{PROJECT_FOLDER}AMA.png", "ts2");
                      SHAPE3.loadImage("{PROJECT_FOLDER}ANTIDOTE.png", "ts3");
                      
                      for (i = 0; i < 4; i++)
                      {
                      	SHAPESIMAGESARRAY[i].setPaintRoutine(function(g)
                      	{
                      		g.drawImage(("ts" + [i]), [0, 0, 100, 50], 0, 0);
                      	});
                      }
                      
                      

                      DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
                      https://dhplugins.com/ | https://dcbreaks.com/
                      London, UK

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

                        @DanH I'll put an example together, give me a few minutes

                        Libre Wave - Freedom respecting instruments and effects
                        My Patreon - HISE tutorials
                        YouTube Channel - Public HISE tutorials

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

                          Here's an example project.

                          viewport_image_demo.zip

                          Peek 2024-05-28 17-24.gif

                          Libre Wave - Freedom respecting instruments and effects
                          My Patreon - HISE tutorials
                          YouTube Channel - Public HISE tutorials

                          DanHD 1 Reply Last reply Reply Quote 0
                          • DanHD
                            DanH @d.healey
                            last edited by

                            @d-healey ok this looks good, thanks :)

                            How can I create it so there's 3 columns and set the width of each column?

                            DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
                            https://dhplugins.com/ | https://dcbreaks.com/
                            London, UK

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

                              @DanH said in Images in a Viewport:

                              How can I create it so there's 3 columns and set the width of each column?

                              Any more requirements I should know about before I answer this?

                              Libre Wave - Freedom respecting instruments and effects
                              My Patreon - HISE tutorials
                              YouTube Channel - Public HISE tutorials

                              DanHD 1 Reply Last reply Reply Quote 0
                              • DanHD
                                DanH @d.healey
                                last edited by

                                @d-healey Can I create gaps between each child panel if they look better with them? And each child panel requires a callback. Sorry, haven't used panels and script like this before so not sure what's possible! Many thanks

                                DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
                                https://dhplugins.com/ | https://dcbreaks.com/
                                London, UK

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

                                  @DanH said in Images in a Viewport:

                                  Can I create gaps between each child panel if they look better with them?

                                  Yes - they are just panels, it is no different to what you can do when you manually add panels in the interface designer.

                                  @DanH said in Images in a Viewport:

                                  And each child panel requires a callback

                                  Does the callback need to be different for each child panel? If so, why?

                                  Libre Wave - Freedom respecting instruments and effects
                                  My Patreon - HISE tutorials
                                  YouTube Channel - Public HISE tutorials

                                  DanHD 1 Reply Last reply Reply Quote 0
                                  • DanHD
                                    DanH @d.healey
                                    last edited by

                                    @d-healey the callbacks just need to set the value of another viewport according to their number. So childpanel / img01 should set the other viewport to 1.

                                    +.changed(); of course.

                                    DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
                                    https://dhplugins.com/ | https://dcbreaks.com/
                                    London, UK

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

                                      @DanH So for that you just need one callback that all the child panels will share.

                                      Modify the addListItem function

                                      inline function addListItem(panel, index)
                                      {
                                      	local p = panel.addChildPanel();
                                      	p.data.index = index; // Set the index here so the child panel knows its own index
                                      	p.loadImage("{PROJECT_FOLDER}img" + index + ".jpg", "img");
                                      	p.set("allowCallbacks", "All Callbacks");
                                      	p.setPosition(0, panel.data.rowHeight * index, panel.getWidth(), panel.data.rowHeight);
                                      
                                      	p.setPaintRoutine(function(g)
                                      	{
                                      		var a = this.getLocalBounds(0);
                                      		g.drawImage("img", a, 0, 0);
                                      	});
                                      	
                                      	p.setMouseCallback(function(event)
                                      	{		
                                      		if (!event.clicked)
                                      			return;
                                      
                                      		// Do the thing
                                      		Console.print(this.data.index);
                                      	});	
                                      }
                                      

                                      Libre Wave - Freedom respecting instruments and effects
                                      My Patreon - HISE tutorials
                                      YouTube Channel - Public HISE tutorials

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

                                        @DanH said in Images in a Viewport:

                                        How can I create it so there's 3 columns and set the width of each column?

                                        For this you need to draw a grid of child panels in the container panel (pnlList).

                                        So create a new project and place a grid of panels in the interface designer. Look at their X/Y positions. Now try to come up with a formula that will place the panels in those positions for you (dare I say ChatGPT might be useful here... might).

                                        Then try it with child panels.

                                        Then try it with different widths for each column.

                                        Libre Wave - Freedom respecting instruments and effects
                                        My Patreon - HISE tutorials
                                        YouTube Channel - Public HISE tutorials

                                        1 Reply Last reply Reply Quote 0
                                        • DanHD
                                          DanH @d.healey
                                          last edited by

                                          @d-healey do I need to set the child panels' callbacks to include clicks?

                                          DHPlugins / DC Breaks | Artist / Producer / DJ / Developer
                                          https://dhplugins.com/ | https://dcbreaks.com/
                                          London, UK

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

                                            @DanH

                                            5a93d86e-5690-44bb-9c79-eb0e00013e17-image.png

                                            Libre Wave - Freedom respecting instruments and effects
                                            My Patreon - HISE tutorials
                                            YouTube Channel - Public HISE tutorials

                                            DanHD 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            27

                                            Online

                                            1.7k

                                            Users

                                            11.8k

                                            Topics

                                            102.4k

                                            Posts