I finally got all my depencies to build, but now my modules don’t render gradients on the panels. Anyone else ever run into something like that? Any open source plugins I could build that use gradients on the panels?
Your issue is likely that nanoSvg doesn’t support complex gradients.
Here’s a complete blank panel with a gradient that works:
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg width="105" height="380" viewBox="0 0 105 380" 
  xmlns="http://www.w3.org/2000/svg"
  xmlns:svg="http://www.w3.org/2000/svg">
  <defs>
  <linearGradient id="gpanel" x1="0" y1="0" x2="0" y2="380" gradientUnits="userSpaceOnUse" >
     <stop offset=".2" stop-color="#7f1c2b" />
     <stop offset="1" stop-color="#f2ff05" />
  </linearGradient>
  </defs>
  <rect id="panel" fill="url(#gpanel)" x="0" y="0" width="105" height="380" />
</svg>
For reference, reduced from a temporary panel in (#d) CHEM – not yet in the library.
You can find a number of working linear and radial gradients in the svg_theme demo Lean in-memory SVG theming for VCV Rack plugins..
sure, but my modules all look fine in the library, and they all have the same gradient. In my current dev build they don’t show. In this case, you are not correct.
If you’ve synced to current Rack source (or updated the sdk in the CI), I think they took a change to nano recently which could account for a difference between the library and current builds.
Care to share an SVG that demonstrates the issue?
Yeah, the gradients look fine in the theming demo of yours. I’ll have to do more experimenting to see why mine are different.
Happy to take a look at your svg and see what I can find.
I have an idea of where the issue might lie: if the gradient stop doesn’t specify an offset and/or index, you end up with a one-stop gradient with the last one as the color. 100% transparency is the last stop in many gradients (it’s the inkscape default), so you end up with a transparent fill (nothing).
I had to hand edit this SVG when I made it (like two years ago?). I made it in (tool which I am forbidden to mention, but it’s not Inkscape). Like I say, they always worked, and they work in the “real” build of VCV. I’ll get you more info.
Here’s a typical one. Doesn’t look right in the github preview. Also looks wrong in chrome.
I think when I hand tweaked them I reversed the ends or something (x and y values). It’s been so long I don’t really remember.
Could you contact us at VCV Support about this? There was a change in the handling of SVG gradients since Rack 2.5.2, and if there’s a problem with the changes it’d be good to get it into the system so we can look into it.
The image looks wrong for me in Edge, in VSCode preview, and Windows file explorer preview (which is probably all Chrome underneath). Also looks wrong in Inkscape. This suggests to me that nanoVG actually fixed a non-conformance/incompatibility.
If you sort the stops by increasing offset, then it looks right.
    <linearGradient id="linear-gradient" x1="50%" x2="50%" y1="100%" y2="0%" gradientUnits="objectBoundingBox">
      <stop offset="0" stop-color="#200020"/>
      <stop offset="100" stop-color="#500050"/>
    </linearGradient>
    <linearGradient id="linear-gradient-2" x1="50%" x2="50%" y1="100%" y2="0%" gradientUnits="objectBoundingBox">
      <stop offset="0" stop-color="#500050"/>
      <stop offset="100" stop-color="#200020"/>
    </linearGradient>
Interesting. And presumably they still work with the old VCV?
done. thanks.
I did this to some of them, and now they display correctly in browsers and such, but they still look broken in VCV. What version of VCV did you use? I don’t think you need to do anything funny to clear any cache or anything, do you? Oh, never mind. It’s what support said - the offsets need to be 0…1
I wasn’t even looking at VCV, since I saw issues with rendering in every other tool.
I have a gradient where the offsets are .2 and 1 and it’s working fine in VCV and the other tools. The important thing appears to be that they’re in ascending order.
I’m currently building with 2.6.2.
sorry, poor formatting on my parts. I needed to make the offsets be in the range of 0 to 1. Which of course makes sense. My range was 0 to 100, which would only make sense for a percentage.
btw, tx again for the help. I did fix the modules soon after. Just waiting for a new VCV build to come out.
Hey Bruce, @Squinky I don’t know if this would be of any interest, the latest version of nanosvg on GitHub has these additions  made after the version that gitmodules pulls down as a submodule from the Rack repo.
I’ve built my fork of Rack v2.6.4 with this latest version instead of the Rack fork of nanosvg and your modules look like they do in your post here anyone having trouble with gradients in dev build? - #9 by Squinky They also look the same if I build with the usual version of nanosvg that Rack provides.
$ git log -L 155,157:src/nanosvg.h
commit 34a6c493e78105e3900fa59a8946f4e6c120f4fc
Author: wcout <wcout@users.noreply.github.com>
Date:   Sat Dec 3 13:43:31 2022 +0100
    Fix #234 nanosvg doesnt render beautyline icons
    Solution: delay creation of gradients until whole XML has been parsed.
    This also fixes #202
diff --git a/src/nanosvg.h b/src/nanosvg.h
--- a/src/nanosvg.h
+++ b/src/nanosvg.h
@@ -154,0 +155,3 @@
+       char fillGradient[64];          // Optional 'id' of fill gradient
+       char strokeGradient[64];        // Optional 'id' of stroke gradient
+       float xform[6];                         // Root transformation for fill/stroke gradient
$ git log -L 2964,2992:src/nanosvg.h                                                                                                                     
commit 34a6c493e78105e3900fa59a8946f4e6c120f4fc                                                                                                          
Author: wcout <wcout@users.noreply.github.com>                                                                                                           
Date:   Sat Dec 3 13:43:31 2022 +0100                                                                                                                    
                                                                                                                                                         
    Fix #234 nanosvg doesnt render beautyline icons                                                                                                      
                                                                                                                                                         
    Solution: delay creation of gradients until whole XML has been parsed.                                                                               
                                                                                                                                                         
    This also fixes #202                                                                                                                                 
                                                                                                                                                         
diff --git a/src/nanosvg.h b/src/nanosvg.h                                                                                                               
--- a/src/nanosvg.h                                                                                                                                      
+++ b/src/nanosvg.h                                                                                                                                      
@@ -2969,0 +2964,29 @@                                                                                                                                   
+static void nsvg__createGradients(NSVGparser* p)                                                                                                        
+{                                                                                                                                                       
+       NSVGshape* shape;                                                                                                                                
+                                                                                                                                                        
+       for (shape = p->image->shapes; shape != NULL; shape = shape->next) {                                                                             
+               if (shape->fill.type == NSVG_PAINT_UNDEF) {                                                                                              
+                       if (shape->fillGradient[0] != '\0') {                                                                                            
+                               float inv[6], localBounds[4];                                                                                            
+                               nsvg__xformInverse(inv, shape->xform);                                                                                   
+                               nsvg__getLocalBounds(localBounds, shape, inv);                                                                           
+                               shape->fill.gradient = nsvg__createGradient(p, shape->fillGradient, localBounds, shape->xform, &shape->fill.type);       
+                       }                                                                                                                                
+                       if (shape->fill.type == NSVG_PAINT_UNDEF) {                                                                                      
+                               shape->fill.type = NSVG_PAINT_NONE;                                                                                      
+                       }                                                                                                                                
+               }                                                                                                                                        
+               if (shape->stroke.type == NSVG_PAINT_UNDEF) {                                                                                            
+                       if (shape->strokeGradient[0] != '\0') {                                                                                          
+                               float inv[6], localBounds[4];                                                                                            
+                               nsvg__xformInverse(inv, shape->xform);                                                                                   
+                               nsvg__getLocalBounds(localBounds, shape, inv);                                                                           
+                               shape->stroke.gradient = nsvg__createGradient(p, shape->strokeGradient, localBounds, shape->xform, &shape->stroke.type); 
+                       }                                                                                                                                
+                       if (shape->stroke.type == NSVG_PAINT_UNDEF) {                                                                                    
+                               shape->stroke.type = NSVG_PAINT_NONE;                                                                                    
+                       }                                                                                                                                
+               }                                                                                                                                        
+       }                                                                                                                                                
+}                                                                                                                                                       
https://github.com/memononen/nanosvg/commit/34a6c493e78105e3900fa59a8946f4e6c120f4fc
If people are interested the whole DIFF between the Rack fork and the version on GitHub can be seen here (you’ll have to download the HTML page to view it in a browser.)


