-
-
Notifications
You must be signed in to change notification settings - Fork 1k
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
Beats and Basslines patterns look off when the height of their track is increased #3683
Comments
But increasing the height of bb tracks is obsolete at all. |
@BaraMGB What do you mean exactly? Currently it's possible to increase the height of Beats and Basslines tracks in In #3674 it was discussed that it might make sense to increase the default height of tracks to make them look less minuscule. Of course we might consider to keep the beats and bassline tracks at their current height. On the other hand, with regards to the problems reported for HDPI displays it might make sense to render the Beats and Basslines tracks in a different manner where they adjust to different sizes dynamically. |
If we are going to increase the height of the tracks in the song editor, I can see why we might want to keep the sizes consistent throughout the program. Regardless of whether or not we want to increase the height, the way that we are currently rendering the patterns with pixmaps is not ideal for horizontal scaling either. |
@RebeccaLaVie I have experimented with using SVGs as the image source for the beats and basslines buttons. This is the result of a rather quick attempt (recorded at 10 frames per second for a smaller video size, please click on the image to see it in full size and better quality): The buttons for that prototype are obviously developer art. :) It would be great if you could provide me with nicer looking SVGs that would replace |
The nice thing about using SVG images is that elements can still be customized for themes while still being rendered in great quality at different sizes. Rendering in code would make everything scalable to different sizes while sacrificing customization. Rendering with pixmaps as is done now keeps customization but does not scale to bigger sizes nicely. So using SVGs would offer the best of both worlds. |
@michaelgregorius 👏 👏 👏 Here is the .svg for the design we are currently using, but this might need to be simplified depending on how small we want to allow users to scale the window. I believe I remember @liushuyu mentioning that there were problems with how Qt renders .svg files so it may be important to get their input on this. |
@RebeccaLaVie Thanks for the file! It only contains one image though. I guess this image contains all groups that are needed to compose the four different aforementioned images. However, I have no idea which ones these exactly are. Can you provide me with four SVGs that correspond to Then we could also quickly check if there are some differences between the SVGs rendered by Qt and the PNGs. |
@michaelgregorius The file is organized in layers. Here is a new version of the file that includes the 0 velocity step. I also updated the names for each layer to correlate with the names of the pixmaps. |
@RebeccaLaVie Thanks for the new file! I am already using it in my local branch. However, I have noticed that I need to change the way the resizing works because with my current implementation the steps would not align when different sizes for the tracks are used. I assume that this is something the users want to get an immediate overview of how the beats relate to each other. |
Related #2636 |
If the steps scale in X and Y freely without a locked ratio, I believe it will fix your alignment problem. (Very rough mockup of my idea above) The downside to this is that the design will look stretched/squished depending on how the window is sized whether we use raster images or .svg graphics. I already want to simplify the step designs which will help, but not entirely solve that issue. |
@RebeccaLaVie I have also thought about implementing it like this and will give do a test implementation. Depending on how the user scales the tracks and sizes the window the buttons might indeed look stretched and squished but if we use SVGs they will always be rendered without any artefacts and in good quality. Also if we implement it like this it is up to the user how he wants it to look. |
Using several differently aligned svgs/pngs would give maximum
customization and perfectly scaleable tiles at the cost of complexity.
Could be as simple as "corner, border, center" (assuming we can rotate the
images) or as complex as "top left corner, top border, top right corner,
...".
EDIT: It seems these are called 9-Patches, at least on Android, although those are one image with regions marked rather than several, the conceptis the same. I'm assuming the svg standard doesn't support this though.
Unless I'm mistaken there's no way to do that with a single image, so the
border will get thicker/thinner as the tile changes size, on both x and y
axes independently.
Alternatively drawing the tiles in code should be able to fix that problem
at the cost of flexibility. Allowing different border and fill colors as
well as maybe border thickness via CSS isn't that restrictive though, imo.
Apologies if this is all obvious or late to the conversation.
|
Beats and Basslines patterns look off when their height is increased via shift click drag:
data:image/s3,"s3://crabby-images/f9810/f981065acd68eee6626d922f144f633d0532a99b" alt="beatsandbacklinesresized"
Because the implementation is based on images which become pixelated when being resized I propose to always render the steps at the top so that they always align with the left hand side:
data:image/s3,"s3://crabby-images/61c09/61c099d9f25191b36c47784557d71072b83d35cd" alt="beatsandbasslinesresizedfixed"
The fix that you can see in the image above also places the steps more in the middle of the track compared to the current implementation which looks like this:
data:image/s3,"s3://crabby-images/101ae/101aedddfd8a73314d7b7b4a37c2c6c800b3bd2b" alt="beatsandbasslinesbottomheavy"
The text was updated successfully, but these errors were encountered: