
Recherche avancée
Médias (91)
-
Chuck D with Fine Arts Militia - No Meaning No
15 septembre 2011, par
Mis à jour : Septembre 2011
Langue : English
Type : Audio
-
Paul Westerberg - Looking Up in Heaven
15 septembre 2011, par
Mis à jour : Septembre 2011
Langue : English
Type : Audio
-
Le Tigre - Fake French
15 septembre 2011, par
Mis à jour : Septembre 2011
Langue : English
Type : Audio
-
Thievery Corporation - DC 3000
15 septembre 2011, par
Mis à jour : Septembre 2011
Langue : English
Type : Audio
-
Dan the Automator - Relaxation Spa Treatment
15 septembre 2011, par
Mis à jour : Septembre 2011
Langue : English
Type : Audio
-
Gilberto Gil - Oslodum
15 septembre 2011, par
Mis à jour : Septembre 2011
Langue : English
Type : Audio
Autres articles (73)
-
Gestion des droits de création et d’édition des objets
8 février 2011, parPar défaut, beaucoup de fonctionnalités sont limitées aux administrateurs mais restent configurables indépendamment pour modifier leur statut minimal d’utilisation notamment : la rédaction de contenus sur le site modifiables dans la gestion des templates de formulaires ; l’ajout de notes aux articles ; l’ajout de légendes et d’annotations sur les images ;
-
Dépôt de média et thèmes par FTP
31 mai 2013, parL’outil MédiaSPIP traite aussi les média transférés par la voie FTP. Si vous préférez déposer par cette voie, récupérez les identifiants d’accès vers votre site MédiaSPIP et utilisez votre client FTP favori.
Vous trouverez dès le départ les dossiers suivants dans votre espace FTP : config/ : dossier de configuration du site IMG/ : dossier des média déjà traités et en ligne sur le site local/ : répertoire cache du site web themes/ : les thèmes ou les feuilles de style personnalisées tmp/ : dossier de travail (...) -
Keeping control of your media in your hands
13 avril 2011, parThe vocabulary used on this site and around MediaSPIP in general, aims to avoid reference to Web 2.0 and the companies that profit from media-sharing.
While using MediaSPIP, you are invited to avoid using words like "Brand", "Cloud" and "Market".
MediaSPIP is designed to facilitate the sharing of creative media online, while allowing authors to retain complete control of their work.
MediaSPIP aims to be accessible to as many people as possible and development is based on expanding the (...)
Sur d’autres sites (6168)
-
ffmpeg : error while loading shared libraries : libvpx.so.6 : cannot open shared object file : No such file or directory
16 avril 2021, par PanosI am building a multi tool discord bot in Python rewrite.


So I decided to add music to it as well. When I completed the bot and tried it on my local pc it worked perfectly. However when I uploaded to Heroku I got some errors for ffmpeg.


Initially I thought Heroku is Linux based so I downloaded ffmpeg for Linux. Still didn't work. Then i added a apt buildpack and downloaded it that way. It worked however now a get a different error. It finds the ffmpeg but the song is not played and this is displayed in the console :




[ffmpeg : error while loading shared libraries : libvpx.so.6 : cannot
open shared object file : No such file or directory]




How can I resolve this issue ?


Here is the whole code :


import discord
from discord.ext import commands

import asyncio
import itertools
import sys
import traceback
from async_timeout import timeout
from functools import partial
from youtube_dl import YoutubeDL
import ctypes
import ctypes.util

@commands.Cog.listener()
async def on_ready(self):

 print("ctypes - Find opus:")
 a = ctypes.util.find_library('opus')
 print(a)
 
 print("Discord - Load Opus:")
 b = discord.opus.load_opus(a)
 print(b)
 
 print("Discord - Is loaded:")
 c = discord.opus.is_loaded()
 print(c)



ytdlopts = {
 'format': 'bestaudio/best',
 'outtmpl': 'downloads/%(extractor)s-%(id)s-%(title)s.%(ext)s',
 'restrictfilenames': True,
 'noplaylist': True,
 'nocheckcertificate': True,
 'ignoreerrors': False,
 'logtostderr': False,
 'quiet': True,
 'no_warnings': True,
 'default_search': 'auto',
 'source_address': '0.0.0.0'
}

ffmpegopts = {
 'before_options': '-nostdin',
 'options': '-vn'
}

ytdl = YoutubeDL(ytdlopts)


class VoiceConnectionError(commands.CommandError):


class InvalidVoiceChannel(VoiceConnectionError):



class YTDLSource(discord.PCMVolumeTransformer):

 def __init__(self, source, *, data, requester):
 super().__init__(source)
 self.requester = requester

 self.title = data.get('title')
 self.web_url = data.get('webpage_url')


 def __getitem__(self, item: str):
 return self.__getattribute__(item)

 @classmethod
 async def create_source(cls, ctx, search: str, *, loop, download=False):
 loop = loop or asyncio.get_event_loop()

 to_run = partial(ytdl.extract_info, url=search, download=download)
 data = await loop.run_in_executor(None, to_run)

 if 'entries' in data:
 data = data['entries'][0]

 await ctx.send(f'```ini\n[Added {data["title"]} to the Queue.]\n```')

 if download:
 source = ytdl.prepare_filename(data)
 else:
 return {'webpage_url': data['webpage_url'], 'requester': ctx.author, 'title': data['title']}

 return cls(discord.FFmpegPCMAudio(source), data=data, requester=ctx.author)

 @classmethod
 async def regather_stream(cls, data, *, loop):
 """Used for preparing a stream, instead of downloading.
 Since Youtube Streaming links expire."""
 loop = loop or asyncio.get_event_loop()
 requester = data['requester']

 to_run = partial(ytdl.extract_info, url=data['webpage_url'], download=False)
 data = await loop.run_in_executor(None, to_run)

 return cls(discord.FFmpegPCMAudio(data['url']), data=data, requester=requester)


class MusicPlayer(commands.Cog):

 __slots__ = ('bot', '_guild', '_channel', '_cog', 'queue', 'next', 'current', 'np', 'volume')

 def __init__(self, ctx):
 self.bot = ctx.bot
 self._guild = ctx.guild
 self._channel = ctx.channel
 self._cog = ctx.cog

 self.queue = asyncio.Queue()
 self.next = asyncio.Event()

 self.np = None
 self.volume = .5
 self.current = None

 ctx.bot.loop.create_task(self.player_loop())

 async def player_loop(self):
 """Our main player loop."""
 await self.bot.wait_until_ready()

 while not self.bot.is_closed():
 self.next.clear()

 try:
 source = await self.queue.get()
 except asyncio.TimeoutError:
 return self.destroy(self._guild)

 if not isinstance(source, YTDLSource):
 try:
 source = await YTDLSource.regather_stream(source, loop=self.bot.loop)
 except Exception as e:
 await self._channel.send(f'There was an error processing your song.\n'
 f'```css\n[{e}]\n```')
 continue

 source.volume = self.volume
 self.current = source

 self._guild.voice_client.play(source, after=lambda _: self.bot.loop.call_soon_threadsafe(self.next.set))
 self.np = await self._channel.send(f'**Now Playing:** `{source.title}` requested by '
 f'`{source.requester}`')
 await self.next.wait()

 source.cleanup()
 self.current = None

 try:
 await self.np.delete()
 except discord.HTTPException:
 pass

 def destroy(self, guild):
 """Disconnect and cleanup the player."""
 return self.bot.loop.create_task(self._cog.cleanup(guild))


class Music(commands.Cog):
 """Music related commands."""

 __slots__ = ('bot', 'players')

 def __init__(self, bot):
 self.bot = bot
 self.players = {}

 async def cleanup(self, guild):
 try:
 await guild.voice_client.disconnect()
 except AttributeError:
 pass

 try:
 del self.players[guild.id]
 except KeyError:
 pass

 async def __local_check(self, ctx):
 """A local check which applies to all commands in this cog."""
 if not ctx.guild:
 raise commands.NoPrivateMessage
 return True

 async def __error(self, ctx, error):
 """A local error handler for all errors arising from commands in this cog."""
 if isinstance(error, commands.NoPrivateMessage):
 try:
 return await ctx.send('This command can not be used in Private Messages.')
 except discord.HTTPException:
 pass
 elif isinstance(error, InvalidVoiceChannel):
 await ctx.send('Error connecting to Voice Channel. '
 'Please make sure you are in a valid channel or provide me with one')

 print('Ignoring exception in command {}:'.format(ctx.command), file=sys.stderr)
 traceback.print_exception(type(error), error, error.__traceback__, file=sys.stderr)

 def get_player(self, ctx):
 """Retrieve the guild player, or generate one."""
 try:
 player = self.players[ctx.guild.id]
 except KeyError:
 player = MusicPlayer(ctx)
 self.players[ctx.guild.id] = player

 return player

 @commands.command(name='connect', aliases=['join'])
 async def connect_(self, ctx):
 try:
 channel = ctx.author.voice.channel
 except AttributeError:
 raise InvalidVoiceChannel('No channel to join.')

 vc = ctx.voice_client

 if vc:
 if vc.channel.id == channel.id:
 return
 try:
 await vc.move_to(channel)
 except asyncio.TimeoutError:
 raise VoiceConnectionError(f'Moving to channel: <{channel}> timed out.')
 else:
 try:
 await channel.connect()
 except asyncio.TimeoutError:
 raise VoiceConnectionError(f'Connecting to channel: <{channel}> timed out.')

 await ctx.send(f'Connected to: **{channel}**', )

 @commands.command(name='play', aliases=['sing'])
 async def play_(self, ctx, *, search: str):
 await ctx.trigger_typing()

 vc = ctx.voice_client

 if not vc:
 await ctx.invoke(self.connect_)

 player = self.get_player(ctx)
 source = await YTDLSource.create_source(ctx, search, loop=self.bot.loop, download=False)

 await player.queue.put(source)

 @commands.command(name='pause')
 async def pause_(self, ctx):
 """Pause the currently playing song."""
 vc = ctx.voice_client

 if not vc or not vc.is_playing():
 return await ctx.send('I am not currently playing anything!')
 elif vc.is_paused():
 return

 vc.pause()
 await ctx.send(f'**`{ctx.author}`**: Paused the song!')

 @commands.command(name='resume')
 async def resume_(self, ctx):
 """Resume the currently paused song."""
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently playing anything!', )
 elif not vc.is_paused():
 return

 vc.resume()
 await ctx.send(f'**`{ctx.author}`**: Resumed the song!')

 @commands.command(name='skip')
 async def skip_(self, ctx):
 """Skip the song."""
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently playing anything!')

 if vc.is_paused():
 pass
 elif not vc.is_playing():
 return

 vc.stop()
 await ctx.send(f'**`{ctx.author}`**: Skipped the song!')

 @commands.command(name='queue', aliases=['q', 'playlist'])
 async def queue_info(self, ctx):
 """Retrieve a basic queue of upcoming songs."""
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently connected to voice!')

 player = self.get_player(ctx)
 if player.queue.empty():
 return await ctx.send('There are currently no more queued songs.')

 upcoming = list(itertools.islice(player.queue._queue, 0, 5))

 fmt = '\n'.join(f'**`{_["title"]}`**' for _ in upcoming)
 embed = discord.Embed(title=f'Upcoming - Next {len(upcoming)}', description=fmt)

 await ctx.send(embed=embed)

 @commands.command(name='now_playing', aliases=['np', 'current', 'currentsong', 'playing'])
 async def now_playing_(self, ctx):
 """Display information about the currently playing song."""
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently connected to voice!', )

 player = self.get_player(ctx)
 if not player.current:
 return await ctx.send('I am not currently playing anything!')

 try:
 await player.np.delete()
 except discord.HTTPException:
 pass

 player.np = await ctx.send(f'**Now Playing:** `{vc.source.title}` '
 f'requested by `{vc.source.requester}`')

 @commands.command(name='volume', aliases=['vol'])
 async def change_volume(self, ctx, *, vol: float):
 """Change the player volume.
 Parameters
 ------------
 volume: float or int [Required]
 The volume to set the player to in percentage. This must be between 1 and 100.
 """
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently connected to voice!', )

 if not 0 < vol < 101:
 return await ctx.send('Please enter a value between 1 and 100.')

 player = self.get_player(ctx)

 if vc.source:
 vc.source.volume = vol / 100

 player.volume = vol / 100
 await ctx.send(f'**`{ctx.author}`**: Set the volume to **{vol}%**')

 @commands.command(name='stop', aliases=['leave'])
 async def stop_(self, ctx):
 vc = ctx.voice_client

 if not vc or not vc.is_connected():
 return await ctx.send('I am not currently playing anything!')

 await self.cleanup(ctx.guild)


def setup(client):
 client.add_cog(Music(client))



-
ffmpeg doesn't show download progress [closed]
10 mars 2013, par Siddharth RamakrishnanI run a mp3 site which converts video to mp3 from youtube and i have working script which works well on my another server. Recently changed my server and found that it is not showing download progress when downloading song from youtube instead it shows white page untill in downloads and then display the conversion progress. Confirmed with my site coder and he said that it is not php error. Error with ur server.
You can check it here http://mp3world.mobi/details.php?code=jVl5s1e0Oo4&name=Chester+See+-+God+Damn+You%27re+Beautiful+%28Official+Music+Video%29
I am unable to figure it out. Can anyone help me in this.
-
electron app fluent-ffmpeg " Error while opening encoder for output stream #0:0 - maybe incorrect parameters such as bit_rate, rate, width or height"
27 juillet 2020, par MartinI am trying to run an ffmpeg command in my electron app. I have created the function ffmpegTest() based off instructions for setting up ffmpeg here :


https://alexandercleasby.dev/blog/use-ffmpeg-electron


and the example query for ffmpeg-fluent here :


https://github.com/fluent-ffmpeg/node-fluent-ffmpeg/blob/master/examples/image2video.js


function ffmpegTest(){
 console.log('ffmpeg-test')
 //require the ffmpeg package so we can use ffmpeg using JS
 const ffmpeg = require('fluent-ffmpeg');
 //Get the paths to the packaged versions of the binaries we want to use
 const ffmpegPath = require('ffmpeg-static').replace(
 'app.asar',
 'app.asar.unpacked'
 );
 const ffprobePath = require('ffprobe-static').path.replace(
 'app.asar',
 'app.asar.unpacked'
 );
 //tell the ffmpeg package where it can find the needed binaries.
 ffmpeg.setFfmpegPath(ffmpegPath);
 ffmpeg.setFfprobePath(ffprobePath);
 
 var imgPath = "C:\\Users\\marti\\Documents\\martinradio\\uploads\\israel song festival 1979\\front.jpg"
 var outputPath = "C:\\Users\\marti\\Documents\\martinradio\\uploads\\israel song festival 1979\\output.m4v"

 // make sure you set the correct path to your video file
 var proc = ffmpeg(imgPath)
 // loop for 5 seconds
 .loop(5)
 // using 25 fps
 .fps(25)
 // setup event handlers
 .on('end', function() {
 console.log('file has been converted succesfully');
 })
 .on('error', function(err) {
 console.log('an error happened: ' + err.message);
 })
 // save to file
 .save(outputPath);

 console.log("end of ffmpeg-test")
}



it is trying to convert an image to a video, my filepaths are accurate, but when I run this function, I get this output in console :


ffmpeg-test
index.js:137 end of ffmpeg-test
index.js:132 an error happened: ffmpeg exited with code 1: Error initializing output stream 0:0 -- Error while opening encoder for output stream #0:0 - maybe incorrect parameters such as bit_rate, rate, width or height
Conversion failed!



After the error prints out, I can see my output.m4v file inside my output folder, but it is 0KB in size and wont open. Is there some way I can specify my bit_rate / rate / width / height in my fluent-ffmpeg command so I can run this simple ffmpeg command ?


thanks