Skip to content
View nilostolte's full-sized avatar
🏠
Working from home
🏠
Working from home

Block or report nilostolte

Block user

Prevent this user from interacting with your repositories and sending you notifications. Learn more about blocking users.

You must be logged in to block users.

Please don't include any personal information such as legal names or email addresses. Maximum 100 characters, markdown supported. This note will be visible to only you.
Report abuse

Contact GitHub support about this user’s behavior. Learn more about reporting abuse.

Report abuse
nilostolte/README.md
Β  Β  Β 

Β Β Β Β Β Β Β Β Β 


Summary

β˜… Β Open Letter: this letter is a foreword to the work I have been doing lately in terms of research and development.

β˜… Β Prefered dishes

Sashimi

image

β˜… Β Preferred game

image

β˜… Β Activities
Β Β Β Β Β β–» Current Activities
Β Β Β Β Β Β Β Β Β Β  Simple, scalable, and portable front-end web solution
Β Β Β Β Β Β Β Β Β Β  GitHub web site
Β Β Β Β Β Β Β Β Β Β  𝝅 desktop calculator
Β Β Β Β Β β–» Future Activities
Β Β Β Β Β Β Β Β Β Β  thinking about it
Β Β Β Β Β β–» Previous Activities
Β Β Β Β Β Β Β Β Β Β  Sudoku solver using binary representation of digits
Β Β Β Β Β Β Β Β Β Β  Examples of vector graphics in Java
Β Β Β Β Β Β Β Β Β Β  Functionalities using PDFBox
Β Β Β Β Β Β Β Β Β Β  Functionalities using FreeHEP
Β Β Β Β Β Β Β Β Β Β  Major recent projects

β˜… Β Introduction
Β Β Β Β Β β–» Vector graphics as a portable solution for GUIs
Β Β Β Β Β β–» Graphics designers as vector graphics GUI creators.
Β Β Β Β Β β–» Future high resolution screens
Β Β Β Β Β β–» Java Android, AWT, JavaFX, and Swing
Β Β Β Β Β β–» Google did it: Dart and Flutter
Β Β Β Β Β β–» FLutter is just Skia disguised behind the scenes. Could Dart survive?
Β Β Β Β Β β–» Qt - The vector graphics GUI framework for C++ and other languages
Β Β Β Β Β β–» The problem of vector graphics on the web
Β Β Β Β Β Β Β Β Β Β  The problem of typography on the web
Β Β Β Β Β Β Β Β Β Β  Vaadin - How to not use Java on the web
Β Β Β Β Β Β Β Β Β Β  Figma - The Ultimate Solution
Β Β Β Β Β Β Β Β Β Β  What can we learn from Figma?
Β Β Β Β Β Β Β Β Β Β  HTML 5 Canvas vector Graphics API
Β Β Β Β Β Β Β Β Β Β  Why All Frontend Frameworks Suck?
Β Β Β Β Β β–» Vector GUI Everywhere

β˜… Β Interesting Articles
Β Β Β Β Β β–» We’re not prepared for the end of Moore’s Law

β˜… Β Hints and programming hacks
Β Β Β Β Β β–» Classification in GUIs and 2D graphics
Β Β Β Β Β β–» Java SIMD Vector API supports ARM SVE!
Β Β Β Β Β β–» Visualization of the execution of a JVM function
Β Β Β Β Β β–» Java Graphics2D: you don't need double buffering
Β Β Β Β Β β–» UTF-8 the ultimate standard for UNICODE texts

β˜… Β Art
Β Β Β Β Β β–» Art-Vector: Vector Art portfolio showing several vector graphics designs I have developed for different reasons.
Β Β Β Β Β β–» Memes: some humor to start with?


Introduction

Citizen of Canada and France, I am creative, autonomous, experienced, self-motivated, and after an entire career of software engineer, researcher in Computer Science, and university professor, having extensive experience in C++ and Java programming (desktop and Android), in enterprise management, and in research, I am nowadays focusing in innovative graphics user interfaces (GUIs) using vector graphics in Java desktop applications as well as in Android, now using inline SVG with Javascript and other languages, with impressive results in appearance, performance and display independence. This work has a tremendous reach in terms of longevity as well as in reduction of costs of graphics user interfaces. The vector graphics paradigm is almost universal and has been available in some languages and it has been recently migrating to hardware in the form of standard APIs.

Vector graphics as a portable solution for GUIs

Since vector graphics paths are very high level abstractions, although able to define complex low level shapes, they can also be seen as part of a generic metalanguage which is platform, operating system and language independent. In other words, one can define GUIs using vector graphics primitives which are at the same time efficient (since we are actually dealing with the lowest level layer of vector graphics pipeline) and portable, since these primitives are practically universal, having only tiny differences between different languages and platforms. This means that it is very easy to port a vector graphics GUI from one language to another, or from a platform to another, or an operating system to another. Not only that but the automatization of these transformations is not at all rocket science and actually not very complex. These transcompilers, though, may be quite labor intensive depending on the level of details of their implementation.

Graphics designers as vector graphics GUI creators.

The main advantage of using vector graphics primitives for GUI construction on the other hand, are neither one cited above. The actual quite important consequence of such choice is to be able to use vector graphics art conceaved by graphics designers to define the GUI shapes and their appearence. For a long time GUIs were exclusively designed by programmers, not artists, and had terrible appearences and no appeal. Not only that but frameworks for GUI construction, which are basically designed by programmers, are extremely standardized, difficult to be customized and complex to learn and use.

But now web development enthusiasts are trying to convince artists that programming is easy and JavaScript is seen like a panacea. Artists had already a hard time to adapt to Illustrator, but now we are telling them to go a step further and submit to a totally abstract way of producing their art.

Only a small amount of graphics designers would be interested in doing design and programming, and few will have both skills at reasonable level. In average one side could be good but the other sacrified. We have already forced artists to learn vector graphics production. Even though interactive tools make this task easier to them, artists had to adapt to all idiosyncrasies of vector graphics, particularly using Bezier curves. All mathematical aspects of Bezier curves are hidden to them, but some practical aspects are often missed, like setting control points touching the curve in minimal and maximal points. These aspects come as an option, and they generally only improve with the experience.

With the possibility to use artwork from graphics designers this whole perspective radically changes. In addition to that graphics designers are much cheaper and more creative than programmers. It looks obvious that vector graphics is definitely the solution for modern and fancy GUIs.

Future high resolution screens

But these are not the only advantages of using vector graphics for GUI creation. Its known intrinsic characteristic is of being insensitive to the screen resolution. One can for example zoom any part of the interface without any loss of quality. This not only means that one can design far different GUIs having zooming as part of its interactive process but also that the same interface can run in a variety of different screen resolutions. With the advent of 4K and 8K monitors and panels, and maybe even higher resolutions in the future, this is a fundamental feature for the portability of the same interface in different screen resolutions. With screen technology growing faster than the hardware to display the information, vector graphics can be seen as the graal for solving this kind of problem. What's amazing is that barely no one is using it nowadays, and we will eventually have a problem where all applications will need to migrate to vector GUIs anyway.

Java Android, AWT, JavaFX, and Swing

Java does supply vector graphics primitives, either in Java Core or Java Android. In Java Core this is mostly done using AWT, Graphics2D in particular, and using Path2D (most often Path2D.Float) to define shapes. Android has a similar feature: Path. Analysing the code in the link one realizes that Android implements these primitives as native functions, that is, in machine language, thus, more efficient than AWT. A common ground between Path and Path2D.Float is that both deal with coordinates in float intead of double, even though AWT also offers Path2D.Double. The use of float is clearly more efficient.

It is possible to contruct GUIs in Java Core exclusively using AWT and also only using a JFrame and buffering, thus, completely avoiding double buffering (JPanel), which most people agree is slower. This is discussed here. The main point of using only AWT is that it falls into the frame of the whole discussion in this page, as opposed to using Swing or JavaFX, for example.

Swing is a GUI framework in Java Core that supplies a high level solution to construct GUIs. It is a very popular framework, but it is only portable within the context of Java Core applications. The main problem with Swing is the problem of every GUI framework, that is, it pratically forces one to construct GUIs in a certain way. The approach is to offer predefined widgets that can be used to build the interface and some internal structuring of the interface. The goal is to accelerate GUI construction, but one often start spending considerable time into the idiosyncrasies of the framework instead of doing actual real work. On the other hand, without predefined widgets or internal structuring, one is obliged to code them oneself, which is often considered as cumbersome or extra work. The advantage of doing that, though, is that the code is free from that particular framework dependency and it can be often reused in other contexts within the same language (as in Java Android, for example) or even outside of the context of the initial language (as in other programming languages supporting vector graphics). This extra work is seen here as the price to pay to have a highly decoupled code. A decoupled code is much easier to port and to be reused elsewehere, and most times it is simpler and easier to understand.

JavaFX is also a GUI framework now offered separately of Java Core, but it also supplies a Path feature, which would in normal ciscunstances be considered a quite interesting feature. Differently than Android's Path and AWT's Path.Float, though, it not only exclusively uses double values, but also its internal code is considerably more cumbersome and intrincate, indulging maybe far too much in object oriented design and transforming something that was once simple, into a bloated and difficult to understand piece of code. This is a classical problem of high granularity that many other codes in any OOP language might have. It's characterized by an exagerated amount of quite small classes. Since in Java each class has to be defined in a different file, it will result in a code that has too many files. This obfuscates the code since each file will have only a few number of lines of code, making it difficult to grasp its overall logic. JavaFX has been also the target of critics for its unusual usage of CSS (which in itself has already a quite awkward syntax), its low performance, its lack of many features and of being difficult to use or to accomplish desired effects. We recognize in some of these criticisms the "footprint" of many other GUI frameworks such as GTK, Motif and many others. The common ground of all of them is that the resulting interface is often considered ugly, outdated, and the framework itself bloated, not well documented, too many useless features, and so on.

Google did it: Dart and Flutter

Not everybody ignored all the vector graphics advantages in GUI construction. Google didn't. That's the reason Google created Flutter and the language Dart. Dart can be seen as an enhanced revamped version of a vector graphics programming language and Flutter is cross-platform application development framework. Dart and Flutter seem to be the solution for constructing GUIs and GUI-based applications. Despite its growing popularity, Dart and Flutter have caveats. The main one is the fact of that Flutter is bulky and quite complex.

But Google just didn't fall in the trap of imposing a framework desguised behind a programming language. Dart is a real programing language that also allows the use vector graphics primitives through the class Path in the painting library, similarly than in Java. The only inconvenient is that it only offers parameters in double, instead of Java that also offers float parameters. The language has many similarities with JavaScript and Java.

The whole marketing behind Flutter seems to actually hide that and rather stresses how easy it is to produce applications. Therefore the whole thing is sold as just like another framework, although we are actually in the presence of a new programming language that is supposed to be portable with portable GUIs.

Flutter is just Skia disguised behind the scenes. Could Dart survive?

What is behind Flutter is Skia, a vector graphics library for C++. It is a quite complex and heavy library but it can be seen as a very good alternative for building vector graphics GUIs in C++ instead of Qt, even though Qt has QPainterPath that also gives access to vector graphics primitives. This bring us to the fundamental limitation of Flutter and Dart for this score. It is designed to generate machine language, not high level and portable building blocks like vector graphics primitives.

This also brings us to the ultimate conclusion that there is probably no way to escape from vector graphics primitives to produce applications that have really portable GUIs. Does that mean that Dart is a dead end? The answer is no. We know Flutter and Dart are open source. Dart doesn't limit any vector graphics primitives for being accessed directly. The final cut of Dart is that it is a language of great importance for Google, since it is part of Fushia operating system as indicated below:



Fuchsia could be the answer for an efficient desktop operating system as well as for smaller embedded platforms. Future versions of Android operating system will accept Fuchsia archive format (FAR). This alone is quite telling and might indicate that the new operating system will substitute Android. All this might also indicate that Google is probably developing something similar to what Apple did with iOS, but completely open source. This is apparently a completely new universe that Google is creating, although the plans for this new OS still remain mysterious nowadays.

Qt - The vector graphics GUI framework for C++ and other languages

Qt is a vector graphics framework that allows creating portable GUIs across different platforms, having biddings for C++, Python, JavaScript, C#, Rust, and other languages.

Qt gives access to vector graphics primitives through its class QPainterPath as illustrated below.

The real inconvenience of Qt is that it is far too bulky, similarly to what happens with Skia and Flutter, but it's undobtably a very popular framework, particularly for C++.

The problem of vector graphics on the web

Vector graphics on the web exists for a very long time with SVG (Scalable Vector Graphics). SVG, however, was approriate for static designs but not for active and live features such as in animations and widgets, until now. The problem is that it was not efficient enough for real time interactivity. But this changed a lot with JIT JavaScript compilation. Now, animation is possible as explained in this video:



Even though one can easily see the value of building animations using standard CSS and SVG (which is great), there is a much better alternative: Bodymovin. One would argue why a proprietary standard would be better than such an open and proper way of doing things. There are many reasons for that, but probably the main ones are portability and versatility.

Bodymovin uses a JSON string to represent the vector models and the animation. It's far more compact and portable because the Bodymovin viewer exists not only in JavaScript, but also in other languages, as, for example, C++. The approach proposed in the video above only works on the web.

The second problem concerns SVG itself. As one can easily notice in this video, SVG is practically dealt as an unreadable format, particularly for paths, and it's hidden behind applications such as Figma or Illustrator, almost as a warning of the type "Danger! Don't even approach it." It's so unfortunate that SVG standard practically sealed it's fate by becoming too complex and unbearable for human users, while initially it was supposed to be exactly the opposite and that's the reason this format has been in text format from the start.

Shape definitions in Bodymovin JSON format are very simple and easy to understand. The JSON is processed by Bodymovin viewer and can be rendered in SVG (but also in a Canvas if one wishes) on the web. The conversion is done dynamically and one doesn't even see it explicitly unless one is using "Inspect."

Here is the most sensational advantage of Bodymovin JSON format, it's metaprogramming paradigm. Adobe cleverly used a simpler and more abstract metalanguage to express the vectors as well as the animations in order to dynamicall convert the format to any possible vector representation. One may argue that its format is intricate and not readable.

At this point the discussion becomes interesting, because indeed one might quickly become overwhelmed by the format structure. The reason for that is that not only the vector models are represented but also the complete animation setting (it's a complete and independent animation script) as opposed to the method exposed in the video above. One might still argue that the file format is proprietary and impenetrable. Not anymore. It became open-source thanks to Lottie and it's growing very quickly as the "new industry standard."

This might be the solution as a metalanguage for representation of vector graphics (and animation), as far as portability, efficiency and flexibility for vector GUIs in general are concerned. See Bodymovin JSON format as a file representation for vector graphics and animation.

Besides active and live contents we also have problems with fonts on the web. Even if the problem of vector fonts is solved as we can see below, it is the structure and the rendering of html itself that became a problem, as far as zooming capabilities are concerned.

The problem of typography on the web

There is no better example of how typography performs badly on the web than this video from Kevin Powell about "responsive typography" on the web:



What is really wrong there? What's wrong is that when one modifies the size of the window the text never scales properly. What they use to try to paliate the problem is a complex animation based scale change of fonts to make it appear similar to actually scaling the page, but that is obviously not what is happening there. Why not scaling the page entirely? Because it requires vector graphics and in the web nowadays it is not enoughly "responsive", unless we are talking about a static design such as shown here. As we can see in this site it is fairly easy to obtain "responsive" zoomable and near WYSIWYG vector typography and vector graphics on the web using conventional web technology, provided the elements are static, not part of animations. However, this panorama has been changing a lot, thanks to JS JIT techonology in general, and Bodymovin and Lottie vector animations, as stated above.

I have seen claims that what Typetura is aiming is size-specific adjustments to type designs as proposed by Tim Ahrens and Shoko Mugikura in "Size-specific adjustments to type designs – An investigation of the principles guiding the design of optical sizes". In this proposal the shapes of the glyphs change with the scale as it has been observed in typography for many centuries and thanks to new psychological research in this subject. Here it is an example of how a metal typography font would change according to the scale:


ATF Garamond, from left to right: 6, 8, 10, 12, 14, 16, 18, 24, 72 pt

If there is a future of typography on the web or in electronic typography in general, this would be it for sure. But this is not what Typetura is doing. Typetura is merely scaling fonts and not changing their shapes according to the scale as proposed by Tim Ahrens and Shoko Mugikura. This is only achieved with a smart use of variable fonts, which is the huge novelty in typography, not only on the web, but especially on the web. Glyphs, a program running on iOS, is probably the responssible for this breakthrough with its new text-based file format.

Threre was a time when WYSIWYG was not applied only on editing contexts that would be printed with the same formatting as while editing. It could also mean that something is displayed as it was meant, it's identical everywhere, but this concept practically disappeared on displaying stuff on the web, except in editing.

However, one can easily see that what you get with the solution in the video is not what you want to see. The solution is a real responsive WYSIWYG experience that scales the text as one increases and decreases the size of the window, that is, actually scaling the whole contents according to the size of the window. This can be easily obtained by rendering the window contents as vector graphics, which are known to be scalable, as seen here. Dynamic and scalable solutions exist thanks to Bodymovin and Lottie, that bring responsive animations in SVG to the web.

If the solution should include not only dynamic contents, but also responsive interactivity it would be probably with an open source library offering to render vector graphics in hardware, directly on the GPU. PixiJS is a partial solution to the problem (see a demo here). It renders vectors using the GPU in HTML Canvas that can be scaled properly according to the viewport. PixiJS unfortunately lacks vector gradients. Using Canvas could also be seen as a limitation, since Bodymovin, for example, can be rendered in SVG quite efficiently. Also, it is not clear if PixiJS scales well in complex GUIs. But the disadvantage of not supporting vector gradients don't actually encourages using it as a complete vector graphics GUI renderer.

It is clear that allowing direct access to vector primitives, allowing animations and real time interactivity with them would be ideally done with hardware support. In addition to that, allowing scripting the GUIs with a proper, device independent, and portable file format, as used in JSON Bodymovin animations definitions, would also be quite desirable. The reality is that one only sees specific solutions for specific problems, and not usually with hardware support. Hardware support for vector graphics is already a problem in many languages, not only on the web. A classical example is in Java, where path rendering in Graphics2D is typically done in software as in many other languages.

Vaadin - How to not use Java on the web

Vaadin is a tentative to use Java on web programming but unfortunately in the wrong way. Vaadin actually tries to imitate UI frameworks such as the one found in Android or Java Core for desktop, but forgetting the most important stuff: awt JRE libraries and vector graphics primitives (Graphics2D). In the video below one can clearly see how Vadiin is not the solution for Java UI on the web, because of its very obscure API and framework oriented structure:



The problem with Vaadin is that exactly the framework aspect is what should be thrown away.

However, when thinking about web applications, web servers, etc., Java is still a good bet and if one thinks about doing it with Springboot, one cannot just ignore Vaddin if one gets the useful advantage of getting rid of REST.


Using Vaadin might be extremely useful to get rid of REST API in Springboot

Thus, Vaadin indeed adds a lot of value by allowing applications to run faster bypassing REST and accessing services or repositories directly. Also, Vaadin main problem with vector UI primitives might be the lack of hardware support for them in Java iself. Thus, a standardized and portable way to access vector primitives with hardware support is definitely what seems to be lacking and what would solve this problem universally, once and for all.

Figma - The Ultimate Solution

Figma is definitely the ultimate solution of vector graphics for the web and the future of GUI/UI on the web is in this kind of solution. Although Figma is very good, their solution is quite expensive, because it offers not only an integrated environment for vector graphics production but also to manage and integrate different designs to construct a whole application without programming.

Nonetheless, Figma's approach is very similar to what I propose, with the difference that Figma allows you to build designs over the web, making it ideal for working in groups, particularly remotely. Although there are a few points where I disagree with Figma's philosophy, I almost entirely agree with it. I believe that designing for the web is a fantastic idea. Figma, on the other hand, does not fully integrate the design into a programming context. The benefit of directly generating code is that it may be readily incorporated and reused in a variety of environments, including the web in WebAssembly.

Security difficulties arise from the use of WebAssembly in closed environments like Figma, because no one knows what a WebAssembly function is doing. Open source programming is the answer to this problem. However, because Figma is not open source, this will be impossible to achieve.

What can we learn from Figma?

Figma, on the other hand, gives us a great deal of useful information. We can benefit from their expertise because we'll already know which points don't work and which do. Here are some of their conclusions:

  • HTML and SVG contain a lot of baggage and are often much slower than the 2D canvas API due to DOM access. These are usually optimized for scrolling, not zooming, and geometry is often re-tessellated after every scale change.
  • There is no guarantee about GPU acceleration and many things are still rendered on the CPU, which can be quite slow in certain cases.
  • Support for masking, blurring, and blend modes in HTML and SVG varies wildly between browsers and is often not anti-aliased or is too low resolution on high-DPI displays.
  • The 2D canvas API is an immediate mode API instead of a retained mode API so all geometry has to be re-uploaded to the graphics card every frame. This is needlessly wasteful and can become a bottleneck.
  • Text layout is inconsistent between browsers and is even inconsistent between the same browser on different platforms.
  • We wanted to be able to add features such as angular gradients which are not supported by any of these rendering APIs.

We resonate a lot with these conclusions and these are points we have already explicitly or implicitly evoked here. But their analysis coincide even more with my observations and longly spoken about in many repositories here:

  • Our biggest pain point is lack of access to glyph outlines and kerning tables which there currently isn’t any way of getting at. One of the primary concerns is fingerprinting, but that battle has already been lost. We’re hoping access to font data can be exposed behind a user permission prompt like other privacy-sensitive APIs. Chrome has come up with a proposal for a fix that’s currently in the works (they’ve been really helpful!) but there’s nothing else on the horizon for other browsers.

I have solved this problem by using fonts directly and reading all the needed information using OpenType.js and by developing my own right justification of texts. In other words I implemented my own font rendering engine. The inconvenient is that the selection of texts must be also handled internally as it is done in PDF viewers and that the text is not searchable, which is a classical problem PDF documents also have. But our goal is not to be searchable but to be portable across every platfrom, including the web.

  • We would love to add support for common clipboard formats (.ai, .pdf, etc.) but the web has no way to do this. The only formats in the spec are text/plain and text/html (our Figma clipboard β€œformat” is text/html with binary data encoded in an HTML comment).

This is a very clever idea of copying a portion of the screen and pasting as text and html with binary content in HTML comments.

Many other ideas of the difficulties found and several solutions are also mentioned in this original document.

We can conclude that GUI tools for the web don't seem to be the solution for portable interfaces basically due to portability issues among different browsers and even among the same browsers in different systems. Figma experience seems to corroborate my views. Interestingly enough, the concerns in Figma, according to their observations shared above, seem strangely similar to my own. As far as GUI design and GUI portability are concerned, the current approach on the web might be actually hinting us that what we are doing is the opposite of what is actually required.

HTML 5 Canvas Vector Graphics API

This API is significantly faster than SVG and it allows (with some clever workaround) to have efficient as well as scalable live vector designs. Some people claim that Canvas is a bitmap feature and not really vectorial. This is not entirely correct. Canvas itself is a bitmap representation, but the vector graphics API allows building scalable graphics by just increasing the size of the Canvas dynamically in the cases when the scale changes. Canvas is a fairly recent addition to W3C standards and it is what allows games to be able to be ported for the web as we have been seeing.

But games are not the only applications that can be done with it. One can also code a whole web application using Canvas and vector graphics API. Even though very powerful, this API is not a panacea. I have found limitations that restrict its use for very complex and more professional applications. For example, clipping doesn't work properly if used more than once. What is missing is a library offering operations to join, subtract and intersect vector objects to generate more complex objects, such as the ones found in Java's awt Area or in Android's Path. These operations can also be found in many vector graphics editors such as Illustrator and Inkscape.

Figma is using such a library, probably in WebAssembly. One of the problems with Figma is that it is a closed environment as cited previously. But such a library as an open source project would not only allow free and general use of these features but also solve any security issues concerning the code since its source code anybody can see. In an industrial environment these libraries can be modified for specific use. For example, the internal representation of objects could be different to avoid having their designs stolen.

Why All Frontend Frameworks Suck?

The video shown below summarizes the reality of frontend frameworks in terms of performance. The benchmarks show that React, Vue, Svelte, and even Rust+WebAssembly frameworks (except maybe Sledghammer) are all slower than vanilla JavaScript.



Video: The Truth about Rust/WebAssembly Performance

Therefore, we not only have a problem that it's difficult to move from one framework to another, and frameworks idiosyncrasies take time to understand and code, but also they significantly degrade the rendering performance.

The solution of Rust+WebAssembly is still not ideal because one needs to pass through JavaScript glue code to access the DOM. What is particularly bad is that Rust works with UTF-8 strings and JavaScript works with UTF-16 strings, which means that everything that passes through the JavaScript glue code needs to be converted from one format to the other all the time.

Vector GUI Everywhere

As we can see, what is proposed here is a coherent and portable way of building GUIs based on code that can be used everywhere including (and particularly) on the web. The best language to code completely portable interfaces is currently not quite clear. What is clear is that there must be a way to do that directly on hardware using GPUs. Therefore shader languages seem to be the most appropriate way to attack this problem. GLSL seems to be the simplest, the most popular, and the most convenient shader language, since it works in practically all platforms and OS, and it's supported by OpenGL which is an open source library and already a standard in graphics for many decennials.

I am currently examining the possibility of using NanoSVG GLSL shader code for displaying paths. The particularity of NanoSVG is that it converts all SVG paths primitives to cubic BΓ©zier curves prior to display them using GLSL.

I have studied and modified NanoSVG path parser to be able to read SVG paths and regenerate them either exclusively using absolute coordinates or relative coordinates, because the paths in SVG can contain a mix between these both kind of coordinates, which is not convenient in many cases. This application can be found here, and can be used to easily assemble and to place SVG paths in a different scene or context by using script files to describe the scene. This parser can be eventually used to generate GLSL code directly from SVG, functioning as a transpiler.

I have been also experimenting with implicitly defined primitives in GLSL to be complementary to vector graphics with the goal of also using implicitly defined shapes in GUIs, thus, enriching the spectrum of possible forms that can be used in GUIs. These experiments were done in C language here using GLFW for user interactions. Notwithstanding this aditional generality, implicit shapes must be coded directly in GLSL, which will unfortunatly discourage many artists and even programmers who are not familiar with GLSL.

And this is exactly the worst disadvantage of GLSL as a language for portable GUIs everywhere. Despite its simplicity, it still is an uncommon way to do things due to GPUs idiosyncrasies. Fortunately, GLSL hides these details but they are still quite obvious since it works quite differently than programming languages designed to run on CPUs.

In addition, font management is inexistent in GLSL. This means that font management must be done by hand, that is, by displaying glyphs as paths, one by one, using the glyphs advance widths as well as kerning information as I have done in Java, and even justifying text by hand as I have done here. In other words, I implemented my own font rendering engine.

This is obviously too much to ask for from an average programmer, even worse in the case of an artist.

Therefore, portability as well as high rendering performance come with a price with nowadays technologies. Once one is willing to pay that price, though, a whole new universe unveils, with huge repercussions.

The question that remains is always the same: why this hasn't been done before and why these tools are not widely available? Probably because we gave priority to other technologies that are easier to use and learn, but that might one day disappear or drastically change, not only because of the limitations they impose, but also because of the specific niche they have been created for, and that for this reason, are not portable.

Reusable code has always been the holy grail in programming, but unfortunately, as far as GUIs are concerned, this concept remained highly elusive, mainly because we developed technologies that actually prevent code reusability.


Activities

Current Activities

  • Simple, scalable, and portable front-end web solution: Using inline and dynamically generated SVG vector primitives as a basic web development tool and as a way to implement simple, scalable, and portable vector GUIs using JavaScript. This allows GUIs with vector definitions almost identical to those used to represent the design in a vector graphics editor such as Illustrator, thus, potentially allowing automatic convertion of the design to JavaScript code. Using metaprogramming thanks to dynamic SVG creation in JavaScript for generating SVG widgets semi-automatically. Also using dynamic inline SVG updates to create animating effects in custom widgets features, such as copy-paste, selections, etc. A demo demonstrating this process is appearing soon.
  • GitHub web site: (paused) this website is a proof of concept of the use of vector graphics on the web using inline SVG and dynamically generated SVG. Nowadays using Javascript to build the shapes and to use the API.
  • 𝝅 desktop calculator: (paused) a revamping of my previous multi-precision scientific calculator for Android known as MaxCalc. This version is a desktop version that is a much more flexible application, not only integrating new features such as complex numbers, parenthesis prioritized operations, new computation calculus libraries, copy-pasting of values, etc., but it also implements a GUI entirely based on vector graphics primitives (previously it used a homemade framework library of widgets as explained here), uses a much more flexible and extensible approach for function implementations using lambda expressions, variable sized and zoomable window,etc. This application is going to be offered as an open source software on GitHub once it is completed. The main idea is to use it as a demo for vector graphics GUI.

Future Activities

  • Zig?

Previous Activities

  • Sudoku solver using binary representation of digits: Simple 9x9 Sudoku brute force solver with intrinsic parallel candidate set processing thanks to the use of bit representation for the 1-9 digits as well as bitwise operations allowing to test all the candidates at once.
  • Examples of vector graphics in Java
    • ClockWidget: analog vector graphics clock in Java that gives the real time on a desktop (wholly developped in Java, but the design was inspired by a vector clock from freepik)
    • ExclamationIcon: static icon used as an error warning (automatically converted to Java from PostScript - process described here).
    • Java Vector GUI
      • MenuInfographics6: example of a complete menu wholly developed in Java inspired from a vector design from freepik. The example contains menu items with an original shape, vector texts and exclusive vector icons, also providing interactions by clicking and rolling mouse wheel.
  • Functionalities using PDFBox
  • Functionalities using FreeHEP
    • Java2PPT: Java vector information shown on the screen, such as a Graphics User interface, is automatically converted to PowerPoint by using an intermediate language, MicroVBA.
    • MicroVBA-PowerPoint: VBA interpreter written in VBA to be used in PowerPoint in order to be able to import large vector graphics files, notably Java vector information from Java2PPT.
  • Major recent projects

Interesting Articles

We’re not prepared for the end of Moore’s Law

This report from David Rotman (MIT) is very interesting. Retracing Moore's law, he exposes the new tendency of nowadays chip technology of not following this "law" (which is more a self-fulfilling prophecy than anything else) anymore. It is all a matter of investments and investment returns and chip manufactories not willing to take risks.

Even though largely declared as dead in the media and by the obvious stagnation of chip's technology growth in the last decade, Moore's law seems still alive thanks to 3D chip manufactury, new transistor designs (particularly vertically build as recently announced by IBM), as well as multi-core architectures that have only started to be exploited.

Here it is an excerpt:

Neil Thompson is an economist, but his office is at CSAIL, MIT’s sprawling AI and computer center, surrounded by roboticists and computer scientists, including his collaborator Leiserson. In a new paper, the two document ample room for improving computational performance through better software, algorithms, and specialized chip architecture.

One opportunity is in slimming down so-called software bloat to wring the most out of existing chips. When chips could always be counted on to get faster and more powerful, programmers didn’t need to worry much about writing more efficient code. And they often failed to take full advantage of changes in hardware architecture, such as the multiple cores, or processors, seen in chips used today.

Thompson and his colleagues showed that they could get a computationally intensive calculation to run some 47 times faster just by switching from Python, a popular general-purpose programming language, to the more efficient C. That’s because C, while it requires more work from the programmer, greatly reduces the required number of operations, making a program run much faster. Further tailoring the code to take full advantage of a chip with 18 processing cores sped things up even more. In just 0.41 seconds, the researchers got a result that took seven hours with Python code.

That sounds like good news for continuing progress, but Thompson worries it also signals the decline of computers as a general purpose technology. Rather than β€œlifting all boats,” as Moore’s Law has, by offering ever faster and cheaper chips that were universally available, advances in software and specialized architecture will now start to selectively target specific problems and business opportunities, favoring those with sufficient money and resources.


Hints and programming hacks

Classification in GUIs and 2D graphics

Useful to enhance picking time (O(log N)) in an unstructured GUI. Binary partition, aka BSP, is the easiest to implement. Using three borders is good to quickly discard empty regions as well (as clearly seen in the picture). One can also partition space regularly in a low resolution grid where each position contains a list of the objects within its borders for a potentially constant time picking in the case no synonyms exist (good for sparcely distrinuted objects).



Java SIMD Vector API supports ARM SVE!

OpenJDK announced that platform agnostic API for SIMD instructions supports ARM SVE!

This example illustrates how this works:

static final VectorSpecies<Float> SPECIES = FloatVector.SPECIES_PREFERRED;

void vectorComputation(float[] a, float[] b, float[] c) {
    int i = 0;
    int upperBound = SPECIES.loopBound(a.length);
    for (; i < upperBound; i += SPECIES.length()) {
        // FloatVector va, vb, vc;
        var va = FloatVector.fromArray(SPECIES, a, i);
        var vb = FloatVector.fromArray(SPECIES, b, i);
        var vc = va.mul(va)
                   .add(vb.mul(vb))
                   .neg();
        vc.intoArray(c, i);
    }
    for (; i < a.length; i++) {
        c[i] = (a[i] * a[i] + b[i] * b[i]) * -1.0f;
    }
}

More details on ARM SVE can be found here.

Visualization of the execution of a JVM function




Java Graphics2D: you don't need double buffering

If you are into Java programming this might sound to you as a big surprise and almost as a huge heresy. No, you just don't need a JPanel and you definitely don't need double buffering.

What you need is just a JFrame and buffering with a BufferedImage, where you save your Graphics2D using createImage. You then use drawImage to display the saved buffer whenever you need to refresh the whole JFrame. Never redisplay your whole JFrame with Graphics2D primitives, but only with the BufferedImage. You can redisplay only parts of the JFrame. In this case your JFrame "paint" method must know what part to update by selective painting (like highlighting a button when clicked).

This is far much faster than double buffering and you will never see any flickering. Thus you will have the best performance with the same result as using a JPanel and double buffering.

But that is not the only advantage. It also allows easily zooming your entire window (by using setSize method) because you are dealing with the JFrame directly. Every time your window changes size (for example, by clicking on a magnifier lens with "+" or "-" icon) you create a new BufferedImage for the redisplay. This concept is a desirable feature when you are dealing with vector graphics interfaces (basically using Shape and Graphics2D), as zooming can become part of the interface.

It might sound weird to talk about vector graphics and a pixelized BufferedImage at the same time. However, a Shape is first scan-converted before being displayed. By using a buffer you are just anticipating and cutting down scan-conversion time. This is extremely useful in complex vector graphics interfaces. It is a know fact that what is deterring the generalized use of vector graphics in GUIs, either in embedded applications, either on the web, is that it is quite time consuming.

This will likely change in the near future when hyper high resolution screens will appear and programs will have to deal with a wide range of screen resolutions. Vector graphics will then be the most elegant solution to this problem. Using lots of photos and images in your web sites? If they are only for decoration you will probably be in trouble when this arrives.

UTF-8 the ultimate standard for UNICODE texts

This project allows to read UTF-8 encoded UNICODE files. It implements an infinite buffer file reader where one can recover the text word by word, which is converted from UTF-8, skipping blanks. The blanks can be recovered since they are all counted (feature used in the test program). By skipping blanks the reader is able to identify the start and the end of the words because they are different than blank. The fact that the text is encoded is totally transparent to the reader. The test program reads an UTF-8 testing file and prints it over the console. A batch file is provided to help running the jar. The source files are also given and they are all for free with no license of any kind.

Art

Vector-Art

Vector-Art repository: Vector Art portfolio showing several vector graphics designs I have developed for different reasons. Samples:

Memes























Pinned Loading

  1. ClockWidget ClockWidget Public

    This application is a vector graphics clock in Java. It contains only 200 lines and it has many clues how to use vector graphics in Java (for constructing GUIs for example). It has a small thread t…

    Java 1

  2. Java-Hacks Java-Hacks Public

    Each directory of this repository contains a program in Java that is shown how to be compiled via CLI with a build.bat for Windows machines (in other machines just copy and paste the individual com…

    Java 1

  3. Java-Vector-GUI Java-Vector-GUI Public

    This repository contains several examples of the use of Vector Graphics in Java to the development of Graphics User Interfaces (GUI), focusing in menus, menu item selection, zooming, etc.

    Java

  4. Projects-Presentations Projects-Presentations Public

    This repository contains the presentation of projects developed or still in development. The goal of these presentations is to give a deep insight in the projects from a high level perspective with…

  5. Vector-Art Vector-Art Public

    Vector Art portfolio showing several vector graphics I have developed for different reasons. If any of this material interests you, please contact me by LinkedIn.

    1

  6. PostScript PostScript Public

    Contains PostScript that can be used with any PostScript interpreter or converter (ex. Acrobat). I made a choice of using Ghostview directly, because one can use some Ghostscript features using sho…

    PostScript 3 2