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

various: define builtin options and key bindings for images #15346

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

guidocella
Copy link
Contributor

@guidocella guidocella commented Nov 21, 2024

This makes mpv usable as an image viewer out of the box, as it is currently hard to setup. Using mpv as an image viewer has several advantages, the biggest one is that it's the best program at browsing directories of mixed videos and images.

It adds a builtin image conditional profile that users can extend in mpv.conf. It is written to not restore and reapply the options on each image change, because that is slow for certain options (e.g. --d3d11-flip=no restarts the VO), and causes visible flicker when options like gamma are unapplied before changing image and reapplied on the next image. But it still restores the previous options after switching to a video or audio file.

etc/image-input.conf defines default key bindings for image, and ~/.config/mpv/image-input.conf can override them.

Files called image-input.conf are added to an input section called image, and builtin.conf enables it for images and disables it for non-images. Because enable-section and disable-section are only called in builtin.conf, they can be replaced with a different mechanism when deprecated input sections are removed without a breaking change.

Alternative to #15344, gives proper builtin support to image-input.conf instead of adding a new command to let user handle it. Input sections are only really useful for images, and it is fine to remove them if we support different image key bindings out of the box, and later disable them with a different mechanism, e.g. delete key bindings whose location contains image-input.conf. We already have many mechanisms to add key bindings anyway, input.conf, load-input-conf, mp.add_key_binding, the keybind command.

Default image key bindings are now defined in the image input section so it's all in one input.conf.

If this approach is considered good we can then actually decide the bindings and options.

Depends on #15314.

Closes #7983, closes #12496.

@guidocella
Copy link
Contributor Author

Added options and bindings since there is no comment. Key bindings are mostly based on sxiv.

I am not sure if space should go the next image because it can be useful to pause slideshows.

DOCS/man/mpv.rst Outdated
Comment on lines 402 to 428
s
Toggle between showing images for 5 seconds in a slideshow and keeping them
open forever.
Copy link
Contributor

Choose a reason for hiding this comment

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

Why is this needed? Just pause the playback.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

It doesn't just pause, it also enables the slideshow at runtime if you started with --image-display-duration=inf. I think this is a common feature in image viewers.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Moved cycle-values image-display-duration 5 inf from s to space, though both are fine. The reasoning is:

  • Space is easier to press than s
  • set image-display-duration inf is the same as pausing for images, so it is simpler to use image-display-duration only
  • Frees up s for users to bind it to something else

DOCS/man/mpv.rst Outdated
P
Go to the previous sub-playlist.

g-g
Copy link
Contributor

Choose a reason for hiding this comment

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

I see what you did here.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

We can also bind HOME and END if desired.

Copy link
Contributor

Choose a reason for hiding this comment

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

Is this really image specific though?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

No, but it is more useful for images than for videos. I also use it for videos and audio and would add it to the regular input.conf, but dunno if that's wanted, up to you. We do have G bound to add sub-scale unfortunately (I bind - and = for that).

Comment on lines +406 to +440
n
Go to the next playlist entry.

p
Go to the previous playlist entry.
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 rebind frame-step to next in image mode. We already have < and > to navigate. We can make them without modifier , . for images.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

, and . seem arbitrary and shoehorned just to mirror video key bindings, they don't specify a direction like < and >, what image viewer uses these key bindings? n and p (taken from sxiv) are also nice because they can be mirrored in shift+n and shift+p to navigate subplaylists. They could also be bound in the default input.conf to always use the same key bindings IMO, we bind p to cycle pause, but I don't see why you wouldn't use space for that, or why you need to hold shift for < > when there are free keys.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

But we can also just bind both, they're all unused keys for images anyway, and they don't override user bindings.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Actually, it should be noted that these do override key bindings added by mp.add_key_binding without forced, because they're both builtin and the ones enabled last win. I did document how to disable these completely though.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Also bound HOME and END.

DOCS/man/mpv.rst Outdated
Comment on lines 424 to 428
]
Skip 10 playlist entries forwards.

[
Skip 10 playlist entries backwards.
Copy link
Contributor

Choose a reason for hiding this comment

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

oddly specific. How does 10 number were decided?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Copied from sxiv key bindings.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Anyone finds these useful? Else I will remove them later, as suggested by llyyr.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Repurposed brackets to control --image-display-duration because brackets control video speed and --image-display-duration is the equivalent of speed for images. This was requested in #12496. In that same issue it was suggested to bind page up to add playlist-pos 10, that is the best option if someone still wants that binding.

DOCS/man/mpv.rst Outdated
Rotate clockwise.

v
Rotate by 180 degrees.
Copy link
Contributor

@kasper93 kasper93 Nov 23, 2024

Choose a reason for hiding this comment

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

Add m for mirror too?

Copy link
Contributor Author

@guidocella guidocella Nov 23, 2024

Choose a reason for hiding this comment

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

Do you mean flip or vflip? By the way, these are sxiv's keybindings if you want to copy the flip bindings (never needed flipping personally):

< Rotate image counter-clockwise by 90 degrees.
> Rotate image clockwise by 90 degrees.
? Rotate image by 180 degrees.
| Flip image horizontally.
_ Flip image vertically.

In sxiv r reloads the image, but I don't find that useful, so I bind r to rotate instead so you don't hold shift.

etc/builtin.conf Outdated
profile-cond=(get('current-tracks/video', {}).image and not get('current-tracks/video', {}).albumart) or (not get('current-tracks/video') and get('user-data/mpv/image'))
profile-restore=copy
input-commands=no-osd set user-data/mpv/image 1; enable-section image allow-hide-cursor+allow-vo-dragging
osc=no
Copy link
Contributor

Choose a reason for hiding this comment

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

I don't think this should be disabled.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

osc completely breaks drag to pan from the bottom half of the window. We can also use script-opt=osc-visibility=never if preferred.

Copy link
Contributor

Choose a reason for hiding this comment

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

osc is useful for images, to see a title, playlist position, navigate, pause. I don't think we should make some other program with those settings, it still should be mpv.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

As you wish but then drag to pan is completely broken (it would be nice if it worked like uosc). I didn't even understand why it wasn't working at first. Do you want to use --script-opt=osc-deadzonesize=0.9 at least?

Comment on lines 23 to 38
#LEFT script-binding/positioning pan-x -0.2 # pan left
#DOWN script-binding/positioning pan-y 0.2 # pan down
#UP script-binding/positioning pan-y -0.2 # pan up
#RIGHT script-binding/positioning pan-x 0.2 # pan right
#h script-binding/positioning pan-x -0.2 # pan left
#j script-binding/positioning pan-y 0.2 # pan down
#k script-binding/positioning pan-y -0.2 # pan up
#l script-binding/positioning pan-x 0.2 # pan right
#Shift+LEFT script-binding/positioning pan-x -0.02 # pan left slowly
#Shift+DOWN script-binding/positioning pan-y 0.02 # pan down slowly
#Shift+UP script-binding/positioning pan-y -0.02 # pan up slowly
#Shift+RIGHT script-binding/positioning pan-x 0.02 # pan right slowly
#H script-binding/positioning pan-x -0.02 # pan left slowly
#J script-binding/positioning pan-y 0.02 # pan down slowly
#K script-binding/positioning pan-y -0.02 # pan up slowly
#L script-binding/positioning pan-x 0.02 # pan right slowly
Copy link
Contributor

Choose a reason for hiding this comment

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

0.1 and 0.01 seems better imho.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

It is impossible to predict the majority's preferences here. I will set what you prefer, unless we can get more feedback.

Copy link
Contributor

Choose a reason for hiding this comment

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

It is just consistent with other keybindings.

#WHEEL_UP script-message cursor-centric-zoom 0.1 # zoom in towards the cursor
#WHEEL_DOWN script-message cursor-centric-zoom -0.1 # zoom out towards the cursor

#s cycle-values image-display-duration 5 inf; no-osd set video-zoom 0; no-osd set panscan 0; no-osd set video-unscaled no # toggle slideshow
Copy link
Contributor

Choose a reason for hiding this comment

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

Why it resets zoom and others. This should only affect image duration, no?

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 if you're zoomed in and enable the slideshow, it is assumed that you want to keep viewing images without interaction and thus want to display the entire image fit to the window without having to change the zoom. But it can be removed, if you think it's too opinionated.

etc/builtin.conf Outdated
@@ -97,3 +97,15 @@ sub-shadow-offset=4
[box]
profile=osd-box
profile=sub-box

[image]
Copy link
Contributor

Choose a reason for hiding this comment

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

I'd also add video-aspect-override=0 here because image files are never tagged properly and none of them actually have non-square pixels in most cases even if it claims to do so

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Done, also replaced osc=no with script-opt=osc-deadzonesize=0.9.

Copy link
Contributor

Choose a reason for hiding this comment

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

Might as well go all the way with deadzonesize=1?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Oh I thought 1 was the whole window, but it's the area above the OSC. Done.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I made the deadsonesize 0.9 again as the small slimbottombar layout is hard to see otherwise. Also it was only MBTN_LEFT that gets hijacked by the deadzone, Ctrl+MBTN_LEFT or MBTN_MID dragging still work.

@guidocella guidocella force-pushed the image branch 2 times, most recently from 59ede19 to 1e0cb0a Compare November 23, 2024 14:48
@@ -97,3 +97,16 @@ sub-shadow-offset=4
[box]
profile=osd-box
profile=sub-box

[image]
profile-cond=(get('current-tracks/video', {}).image and not get('current-tracks/video', {}).albumart) or (not get('current-tracks/video') and get('user-data/mpv/image'))
Copy link
Contributor

Choose a reason for hiding this comment

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

How can I disable this auto profile when this is built-in? I don't think this is good behavior, especially it's very confusing when image keybinds are completely different from normal ones. Also it doesn't work if mpv isn't compiled with lua support.

I think it's better to take this out to the documentation instead and let the user apply the image profile when needed. Putting it in the documentation also informs how to write a conditional profile for images.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

You can override options in the profile by defining an image profile in mpv.conf, as is documented.

Already many fundamental things don't work without lua support, osc, console, ytdl_hook. You can still play videos basically without Lua regardless. Without lua you will have to manually apply the profile with a key binding.

Only key bindings already useless for images are different.

The whole point of including a builtin conditional profile is to make mpv a good image viewer out of the box, else we could just put a link to my config. Users can define extra image options without having to deal with this convoluted condition, and without having to recommend them to use enable-section and disable-section, only to remove later them.

Copy link
Contributor

@llyyr llyyr Nov 23, 2024

Choose a reason for hiding this comment

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

How can I disable this auto profile when this is built-in? I don't think this is good behavior, especially it's very confusing when image keybinds are completely different from normal ones.

When would you want to disable this? Most of the video mode keybinds aren't very useful on an image anyway, and as long as playlist-{next,prev} etc. are still the same keybind (I know they aren't right now) it shouldn't inconvenience the user in any way.

I suppose you could allow disabling this by checking for user-data/mpv/disable-image or something, could even map that to an option.

Copy link
Contributor

Choose a reason for hiding this comment

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

You can override options in the profile by defining an image profile in mpv.conf, as is documented.

This is even more problematic because it treats a profile name specially that may cause unexpected behavior. For example if I already have a profile called "image" that I only use when I want (by aliasing image viewer command to mpv --profile=image for example) it will now be loaded no matter what.

Only key bindings already useless for images are different.

The whole point is that these key bindings behaving differently is an issue. When I have a playlist with mixed images and videos I have to know whether an image or video is displayed before determining which keybinds are activated. Silently changing what keys do when I go forwards and backwards in a playlist is confusing because it's easy to carry the keybind "mental model" to the next file played which can result in unexpected behavior.

When would you want to disable this?

  • The mentioned keybind behavior
  • prefetch-playlist is unwanted if the next item in the playlist is a video or on network
  • video-aspect-override=0 briefly affects next video item in the playlist because conditional profiles are applied asynchronously

Copy link
Contributor Author

Choose a reason for hiding this comment

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

If you already have a profile named image that you enable manually enabling it automatically is an intended upgrade, it is a feature not an issue. And if you don't want certain options, you can override them.

The key bindings behaving differently when changing between images and videos is again the intended feature and not an issue, because changed key bindings are useless for images, and replaced with useful ones. You don't need to seek within images. And you can disable them in the profile if you want.

I don't understand how prefetch-playlist is unwanted if the next item is a video, or especially if on network, which is exactly when it's most useful. But again, you can disable it in the profile.

I am not sure about video-aspect-override=0, since I never used it, but according to haasn/llyyr/occivink it is useful for certain images, so it should be worth briefly affecting the next video. But again, you can disable it if it bothers you. This is supposed to be useful defaults, we can't handle every edge case.

and as long as playlist-{next,prev} etc. are still the same keybind (I know they aren't right now)

< and > still work for images, these just extend default key bindings. No key binding that is useful for both videos and images (e.g. stats, gamma) is changed.

Copy link
Contributor

Choose a reason for hiding this comment

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

What about holding RIGHT to skim over a video and when EOF has been reached and the player jumps to the next playlist item which is an image, the key suddenly changes its behavior?

What about holding RIGHT to skin over a video and when EOF has been reached and the player jumps to the next playlist item and they accidentally skim through the next file too? This can be a problem even on master itself, what you're asking for an option for mpv to release key presses when switching playlist item. Open an issue tracker so someone can work on it later. I don't see how it's related to this PR.

My point is implementing conditional options intended for one type of files in a way that may have side effects for other types is flawed.

What are these side effects and what is flawed? Please elaborate. Do you mean to say track-list/N/image may be unreliable to detect images?

Copy link
Contributor

@sunpenghao sunpenghao Nov 26, 2024

Choose a reason for hiding this comment

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

What are these side effects and what is flawed? Please elaborate.

Sorry I didn't make myself clear: Profile conditions are evaluated asynchronously, so there is a chance that options meant for images will affect other types of files shortly.

And yes, I see that this is not likely to happen, but again, the possibility is there. If maintainers decide this can be tolerated, that's perfectly fine.

Copy link
Contributor

@sunpenghao sunpenghao Nov 26, 2024

Choose a reason for hiding this comment

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

auto_profiles.lua already evaluates profiles within synchronous hooks, so applying the profile from C wouldn't magically make it more synchronous as far as I know, it just does the same thing with more code and more risk of memory issues.

OK somehow I missed your reply. If that's true then all my concerns have been addressed :) (except maybe for the "profile-cond=" thing, but that's mostly an aesthetic issue)

Copy link
Contributor

@na-na-hi na-na-hi Nov 26, 2024

Choose a reason for hiding this comment

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

auto_profiles.lua already evaluates profiles within synchronous hooks, so applying the profile from C wouldn't magically make it more synchronous as far as I know

It only applies profiles for some hooks, and these hooks happen too early for the image file condition that it can only determine its final value after the last file loading hook is handled. So in the end this particular condition is handled asynchronously.

Copy link
Member

@sfan5 sfan5 Nov 27, 2024

Choose a reason for hiding this comment

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

off-topic: why are we discussing this in a sub-thread attached to a single line change? it's inconvenient


libplacebo supports sliced texel uploads on d3d11 and vulkan, and mpv no longer defaults to opengl on any platform so this shouldn't be an issue.

I don't see how that's related since texture limits will still apply, won't they?

neither does any image viewer using imlib2

okay? that just means those other image viewers are also bad

Are you OK with enabling it globally by default?

If it works and has no other undesirable effects: sure why not.

I never saw even one of these images bigger than GL max texture sizes in years of real world usage,

I agree it's not very common but I have wanted to view big images in real usage.

image-input.conf is a workaround to not use deprecated input sections, which let you specify key bindings with {image} in the same input.conf

AFAIK input sections are only deprecated for what users do with mpv. there's no reason we can't add new features inside mpv that rely on them, for example encoding does too.

Or what usefulness does seeking with arrow keys have on an image file with 1 frame?

see sunpenghao's response for this.
Introducing a dynamically switched second set of controls has to be done carefully to avoid confusing situations. Not saying we can't do it.

There would no advantage to make it keep seeking, because seeking images doesn't do anything.

Doesn't it go to the next playlist item when you reach EOF? (it doesn't)

What about holding RIGHT to skin over a video and when EOF has been reached and the player jumps to the next playlist item and they accidentally skim through the next file too?

What? This is literally working as designed, because the RIGHT key has a defined meaning and it keeps getting applied if you hold the key.


anyway:
Personally I think a dedicated image viewing mode is scope creep and I would rather suggest making it an user script and maybe prominently advertising it, but not including it in mpv core.

input/input.c Outdated
@@ -1477,9 +1481,13 @@ static bool parse_config_file(struct input_ctx *ictx, char *file)
bstr data = stream_read_file2(file, tmp, STREAM_ORIGIN_DIRECT | STREAM_READ,
ictx->global, 1000000);
if (data.start) {
bstr section = (bstr){0};
if (!strcmp(mp_basename(file), "image-input.conf"))
Copy link
Contributor

Choose a reason for hiding this comment

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

Add a section parameter to parse_config_file instead of this hard coding.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Done.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Though the advantage of having there was that if you load-input-conf image-input.conf later, it is added to image key bindings.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Added the check in load-input-conf too.

@guidocella guidocella force-pushed the image branch 2 times, most recently from e44d86e to a3bf619 Compare November 24, 2024 07:11
@guidocella guidocella force-pushed the image branch 4 times, most recently from 16b5e00 to f8315df Compare November 24, 2024 16:39
@guidocella guidocella marked this pull request as ready for review November 24, 2024 16:43
@guidocella guidocella force-pushed the image branch 6 times, most recently from 769bd5d to 3d1de9c Compare November 27, 2024 14:20
@guidocella
Copy link
Contributor Author

Added the new slimbottombar OSC layout to the profile.

@guidocella
Copy link
Contributor Author

Added --taskbar-progress=no to not show full green progress rendering for images on Windows' taskbar, as suggested by Samillion. This option is available on every platform so it doesn't cause errors.

@hooke007
Copy link
Contributor

Is there a mpv option to totally disable this mode?

@guidocella
Copy link
Contributor Author

You can override the profile with an empty profile-cond as is documented.

@hooke007
Copy link
Contributor

Not the smart solution...

@llyyr
Copy link
Contributor

llyyr commented Jan 15, 2025

Not the smart solution...

Smart solution is to just not open images with mpv if you don't want to image mode.

@hooke007
Copy link
Contributor

if you don't want to image mode.

But I want to open imgs with no changes?

@guidocella
Copy link
Contributor Author

Default mpv without changes is a terrible image viewer that has no reason to be used over preconfigured ones.

@hooke007
Copy link
Contributor

Why does mpv have to be the image viewer?
I never had the extra expectation for the video players that being the better music player/ img viewer.
Yes I agree it would be cool for some one. But a simple disable option should also be introduced. If everyone really like it, there would be no arguing here.

@Samillion
Copy link
Contributor

Samillion commented Jan 15, 2025

For me personally, mpv is a powerful image viewer. I also integrated an image mode in my osc:
https://github.com/Samillion/ModernZ/blob/main/docs/IMAGE_VIEWER.md

Also, there are image viewers that literally use mpv, like qimgv
https://github.com/easymodo/qimgv

@hooke007
Copy link
Contributor

Also, there are image viewers that literally use mpv, like qimgv

It uses mpv to play videos only...

@Samillion
Copy link
Contributor

Samillion commented Jan 15, 2025

Not sure where the problem is, if you don't want to use it, don't use it as explained. (profile-cond)

Others do want to use it.

@hooke007
Copy link
Contributor

if you don't want to use it, don't use it as explained.

Correct so add an option.
profile-cond is difficult for most users to find.

@Samillion
Copy link
Contributor

I would agree if enabling this by default was obstructing a function. It is not.

Why would anyone need volume, audio, play controls for an image?

The users you're talking about that would find this difficult to find are exactly the ones this PR is aimed for, the novice. Remove needless things and focus on the content.

@guidocella
Copy link
Contributor Author

Why does mpv have to be the image viewer?

Already listed reasons in #15346 (comment)

I never had the extra expectation for the video players that being the better music player/ img viewer.

Then don't use it as a music player or image viewer.

Yes I agree it would be cool for some one. But a simple disable option should also be introduced. If everyone really like it, there would be no arguing here.

The profile can already be modified and disabled by extending it, and if you don't use mpv as an image viewer it doesn't make a difference how it display images.

Correct so add an option. profile-cond is difficult for most users to find.

Because options are easier to find in a manual with over 1000 of them? Then why do we get asked which options to use on IRC and issues every day? You have to read the docs to see how to modify it anyway. And still no valid use case has been provided for disabling the whole profile, other than irrational fear of change, since it is clearly just more useful defaults for images. It is more realistic to override individual options and keybindings, which users are invited to do since it documents how to.

@hooke007
Copy link
Contributor

I reviewed the hidden comments. It seems my views was duplicated with others.
Profiles is the bad solution. No consensus reached.

@Samillion
Copy link
Contributor

other than irrational fear of change

It's not even change, it's enhancement by addition that can be disabled easily. I genuinely don't understand the objection(s).

The statements are all over the place, from "why mpv is image viewer", when the answer is "then don't use it as an image viewer", the reply is "I just want it with play controls", then disable the profile.

The consensus is that they want volume, seek, play, audio for images? How is that logical? and if it is to you, you can have it that way. Nothing is removed.

@llyyr
Copy link
Contributor

llyyr commented Jan 15, 2025

But I want to open imgs with no changes?

This profile doesn't change anything except useless keybinds for images (subtitle positioning, volume, seek etc.) and better zoom/pan.

I don't see why there should be an option to provide a worse experience with no upside. This profile isn't a sidegrade or conditional upgrade in any way. It is objectively a better experience with absolutely no downsides for the end user, I don't see why this needs an option to disable it.

The worst experience you can have is you don't care about it and you never use any of these features. The best experience you can have is mpv is now your favorite image viewer. It's a neutral-positive. There's no negative here.

Also suggest checking --panscan docs from its key bindings.
@sunpenghao
Copy link
Contributor

Now that discussion has been picked up again, I think it is at least worth making the profile's name a bit less generic (maybe builtin-image-viewer). I'm sure there are abundant user configs out there with a profile named image that is activated either manually or with another set of profile-cond, and these may not even be meant for using mpv as an image viewer.

This makes mpv usable as an image viewer out of the box, as it is
currently hard to setup. Using mpv as an image viewer has several
advantages, the biggest one is that it's the best program at browsing
directories of mixed videos and images.

This adds a builtin image conditional profile that users can extend in
mpv.conf. It is written to not restore and reapply the options on each
image change, because that is slow for certain options (e.g.
--d3d11-flip=no restarts the VO), and causes visible flicker when
options like gamma are unapplied before changing image and reapplied on
the next image. But it still restores the previous options after
switching to a video or audio file.

Default image key bindings are defined in the image input section. sxiv
is their main inspiration.

Closes mpv-player#7983, closes mpv-player#12496.
@guidocella
Copy link
Contributor Author

Renamed the profile to builtin-image.

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.

Playback speed should affect --image-display-duration MPV is a great image viewer - let's make it official.
10 participants