Yep, it seems to have built up a fair bit of traction, mostly thanks to the Reddit crowd. There’s an API of sorts too. If Discourse did its automatic grab-the-file-and-self-host-it I suppose this might work in the short term.
I really think this kind of workaround ought to be open source though. A lot of articles I’ve read describe Gfy as a new format, which is very misleading. There’s only one way to make a “Gfy”, and that’s through Gfycat.com. Gfy is a service.
Some communities would benefit from such functionality.
Especially ones with download remote images to local setting enabled , but faster page loads alone is a good reason to think about it.
Quick hack would be to just use gfycat.com API.
Assuming one does not mirror remote images, I think it is achievable even with pure Javascript which you can add via /admin/customize/css_html. Lets say JS iterates over posts and if it finds .gif image. HTTP GET is performed: http://upload.gfycat.com/transcode?fetchUrl=i.imgur.com/jGMtJIb.gif
It downloads&converts remote image (if not already present) and returns JSON with video details. At this point you replace .gif with video in post (see section “How can I embed these or link to them?”)
Custom plugin which bakes .webm into posts via background job would be of course more elegant.
Anyway,
I don’t think they (gfycat) do anything magical beside handling hight traffic quite well.
We can replicate functionality with ffmpeg alone (see 4chan’s guide to converting GIF to WebM).
If we plan to self-host .webm it would be just an extension to already existing download remote images to local feature. We would have an additional setting replace .gifs with optimized .webm versions (we could add another setting: convert only .gifs bigger than…).
Such native functionality requires ffmpeg as a dependency and comes with additional security risks.
It does not sound like a good default for Discourse: maybe it is possible to create it as a plugin?
The cornerstone of Project GIFV is a platform-wide upgrade to automatically convert uploaded GIF files on the fly into the MP4 video format. […]
The .GIFV Extension: With all these improvements, Imgur will now denote converted MP4s with a “.gifv” extension. The intention is to signal to users throughout the Internet that these links will feature a GIF experience that incorporates all the current and future enhancements made through Project GIFV. Imgur plans to submit an accompanying specification to relevant standards organizations before the end of the year.
Exactly!
Discourse already has onebox for MP4 files.
So the only missing piece is some kind of a sidekick job that does the conversion and slight modification to the onebox to loop by default (if mp4 was created from gif).
It works for imgur.
For example something like https://i.imgur.com/mYNXTPw.gif can be requested as https://i.imgur.com/mYNXTPw.webm which gives:
It would be nice if Discourse detected .gif URLs from common providers such as imgur/gfycat
and just replaced image with looped video (already provided by site), as it saves a lot of bandwidth.
That sounds like something that could easily be done using the onebox, adding a white list either in the image or video engine. I am happy to build that, if such a PR is wanted (could also be behind a configuration setting, if needed).
Chrome does a terrible job with huge gif files, they can choke the web browser and cause all sorts of nasties not to mention mobile paying a hefty price on traffic and blowing data plans.
It’s really just a video element with a bunch of fallbacks.
I see a few actionable things we can do here:
If people hotlink anything larger than say 10mb force a “click” to actually download the image and hide it behind a preview
get ffmpeg into our base image and do the webm and mp4 conversion for all animated gifs, don’t worry about the flash fallback.
Offer an integration piece with imgur that uses imgur to do this … any gif larger than X gets sent to imgur for recompression. (or use a different service)
One thing to consider is how Slack deals with this:
http://img0.joyreactor.cc/pics/post/%D0%B3%D0%B8%D1%84%D0%BA%D0%B8-superjail-%D0%BC%D1%83%D0%BB%D1%8C%D1%82%D1%81%D0%B5%D1%80%D0%B8%D0%B0%D0%BB-%D0%A1%D0%B2%D0%BE%D1%8F-%D0%B0%D1%82%D0%BC%D0%BE%D1%81%D1%84%D0%B5%D1%80%D0%B0-1886210.gif (Not automatically expanded because 30MB is too large. You can expand it anyway or open it in a new window. You can also change your preferences to allow images of any file size to auto expand.)
Mais aucun de ces éléments ne précise si la solution a été mise en œuvre.
La raison de ma question est que, sauf erreur de ma part, l’effet lightbox ne semble pas compatible avec les GIF. Autrement dit, je ne peux pas cliquer sur un GIF pour le passer en plein écran. Lorsque le GIF contient du texte détaillé, l’utilisateur ne peut pas zoomer sans ouvrir l’image dans un autre onglet.
Cependant, si le GIF est converti en MP4 lors du téléchargement, nous bénéficions alors de la fonctionnalité plein écran du lecteur vidéo existant, ainsi que de la barre de progression — des avantages considérables lorsque vous regardez un court clip tutoriel !
Cette possibilité de conversion est-elle déjà disponible ? J’ai également recherché « gif » dans les paramètres et j’ai trouvé :
Lors de la comparaison de différents styles de documentation – tout texte, uniquement vidéo, texte + gifs – l’option texte + gifs s’est avérée largement supérieure. Par conséquent, nous prévoyons d’utiliser des gifs pour démontrer des choses dans les articles de tutoriel. Cependant, si nous ne pouvons pas passer en plein écran ou en lightbox le gif, le texte écrit peut souvent être difficile à voir
Et comme vous le voyez lorsque vous survolez, vous n’avez que l’option de mettre en pause
Mais ce dont nous avons vraiment besoin, c’est de pouvoir agrandir le gif. La solution de contournement consiste à faire un clic droit et à ouvrir dans un nouvel onglet, ce qui convient à nos utilisateurs les plus expérimentés, mais on ne peut pas s’attendre à ce que les 90 % restants s’adaptent à cela. Nous avons donc besoin soit d’un moyen de faire en sorte que les gifs téléchargés utilisent la mise en lumière afin qu’ils s’affichent en taille réelle lorsqu’ils sont cliqués, soit simplement de les convertir en mp4 afin que Discourse fournisse la fonctionnalité plein écran.
De plus, la fonctionnalité des tableaux développés est