Skip to content
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

{select,osc}.lua: add a miscellaneous menu #15499

Draft
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

guidocella
Copy link
Contributor

Add a generic menu to bar layouts to provide discoverability for the select menus to users who don't realize you can right click OSC buttons.

There's no space to add it in box layout.

screenshot

We just gotta figure out how to add a proper icon instead of ☰. Maybe we can extract this from Symbola like in db3754d. Also we could add more entries later like Open file or Edit config file.

@@ -427,3 +427,29 @@ mp.add_key_binding(nil, "show-properties", function ()
end,
})
end)

mp.add_key_binding(nil, "menu", function ()
local menu = {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't this list all select? Especially why vid select is hidden?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Because I saw uosc doesn't have it so I didn't if it's worth adding.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Because I saw uosc doesn't have it so I didn't if it's worth adding.

Of course they has it. In UOSC each button is dynamic and show only when needed. See https://github.com/tomasklaen/uosc/blob/6a1c0e9c6e7e9e43cda1c1ea3e44a911fae45927/src/uosc.conf#L83C1-L83C211 specifically, <has_many_video>video.

This menu could do this too, to not show items that goes nowhere.

Copy link

github-actions bot commented Dec 12, 2024

Download the artifacts for this pull request:

Windows
macOS

@@ -0,0 +1,16 @@
Steps to add new icons:

- Install `fontforge`
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
- Install `fontforge`
- Install [FontForge](https://fontforge.org/en-US/)

Steps to add new icons:

- Install `fontforge`
- Install the last freely licensed version of symbola (`ttf-symbola-free` in the
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would remove this step from readme, source font for symbols can be different. You can mention in separate paragraph, that some glyphs in are extracted from symbola font.

- Install `fontforge`
- Install the last freely licensed version of symbola (`ttf-symbola-free` in the
AUR)
- `fontforge /usr/share/fonts/TTF/Symbola.ttf TOOLS/mpv-osd-symbols.sfdir`
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Load a font and the project directory, for example: fontforge Symbola.ttf TOOLS/mpv-osd-symbols.sfdir

- Install the last freely licensed version of symbola (`ttf-symbola-free` in the
AUR)
- `fontforge /usr/share/fonts/TTF/Symbola.ttf TOOLS/mpv-osd-symbols.sfdir`
- Check the Unicode hex value of the desired character (`g-a` in vim)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Aren't there symbol table in FontForge? I think I've seen it.

- `fontforge /usr/share/fonts/TTF/Symbola.ttf TOOLS/mpv-osd-symbols.sfdir`
- Check the Unicode hex value of the desired character (`g-a` in vim)
- Scroll until that value in the Symbola window and click it
- Press Ctrl+c
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Describe the action, for example. Not only "press".

- Copy selected glyph (Ctrl+C)

- Press Ctrl+c
- Focus the window with TOOLS/mpv-osd-symbols.sfdir
- Click an unused character slot
- Press Ctrl+v
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
- Press Ctrl+v
- Paste the glyph (Ctrl+v)

- Focus the window with TOOLS/mpv-osd-symbols.sfdir
- Click an unused character slot
- Press Ctrl+v
- Press Ctrl+s
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Save

- Click an unused character slot
- Press Ctrl+v
- Press Ctrl+s
- Close fontforge
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This step is probably not really needed to explain

- Press Ctrl+v
- Press Ctrl+s
- Close fontforge
- Figure out the Lua sequence of the new character by copying that of the
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Instruction unclear. Either don't say anything and expect it is clear, or make it explicit.

I think what you are saying here, is to convert Unicode code point to utf-8 chars.

- Press Ctrl+s
- Close fontforge
- Figure out the Lua sequence of the new character by copying that of the
previous character and incrementing the last 3 digits
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You could also mention TOOLS/gen-osd-font.sh which is used to generate osd_font.otf. I understand that you did that in GUI?

@guidocella
Copy link
Contributor Author

Oh whoops I did not intend to push the README commit at all I just wanted to update the edition-list check and forgot I did those other commits before. The instructions are broken, even if you follow them the character is completely misaligned and of different size from the others. Rather I am trying to completely replace the font with the one from ModernZ as it both looks better and lets us easily add new characters from it without dealing with fontforge.

@kasper93 kasper93 marked this pull request as draft January 4, 2025 23:54
Taken from the last freely licensed version of Symbola and manually
adjusted the number in the glyph file to match the adjacent arrows.

Saving sfdir with fontforge also automatically removed the O flag from 2
existing glyphs. According to
https://fontforge.org/docs/techref/sfdformat.html "O" just meant "the
character was open when last saved", so it doesn't change anything
visible.
Add the generic menu to bar layouts to provide discoverability for the
select menus to users who don't realize you can right click OSC buttons.

There's no space to add it in box layout.
@guidocella
Copy link
Contributor Author

So switching to fluent icons turned out to be even harder because it doesn't have some of the icons we use, some are only available as an outline with empty interior, and some are misaligned. So I manually edited the numbers in the menu glyph until it matched the adjacent arrows as I'd like to get the menu done first. It would still be good to switch to fluent icons eventually since they look way better than the current ones (https://0x0.st/8imI.avif was a prototype).

I also think the menu should be in the idle screen too so you can select history and watch later, and open file in the future, but that is hard because osc_init has not been called yet at that point, so there is no button system.

@Samillion
Copy link
Contributor

It would still be good to switch to fluent icons eventually since they look way better than the current ones

Hear, hear.

I also think the menu should be in the idle screen too so you can select history and watch later, and open file in the future, but that is hard because osc_init has not been called yet at that point, so there is no button system.

Indeed, which also prevents point 1 in #13167

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants