Skip to content

Haxe library for native video support on HaxeFlixel.

License

Notifications You must be signed in to change notification settings

EliteMasterEric/hxCodec

 
 

Repository files navigation

hxCodec

A library which adds native video support for OpenFL and HaxeFlixel.

Using libVLC, hxCodec allows to play hundreds of video codecs.

Original repository
Click here to check the roadmap


Instructions for Friday Night Funkin'

  1. Install the Haxelib You can install it through haxelib:
haxelib install hxCodec

You can also install it through Git for the latest updates:

haxelib git hxCodec https://github.com/polybiusproxy/hxCodec
  1. Add this code in Project.xml
<haxelib name="hxCodec" if="desktop || android" />

OPTIONAL: If you want debug traces in your console, add this code:

<!-- Show debug traces for hxCodec -->
<haxedef name="HXC_DEBUG_TRACE" if="debug" />
  1. Create a folder called videos in your assets/preload folder.

  2. Add this code in Paths.hx:

inline static public function video(key:String)
{
	return 'assets/videos/$key';
}

Playing videos

  1. Put your video in the videos folder.

Note: hxCodec supports all the video formats VLC can play!

  1. Add somewhere in PlayState:
function playCutscene(name:String, atEndOfSong:Bool = false)
{
	inCutscene = true;
	FlxG.sound.music.stop();

	var video:VideoHandler = new VideoHandler();
	video.finishCallback = function()
	{
		if (atEndOfSong)
		{
			if (storyPlaylist.length <= 0)
				FlxG.switchState(new StoryMenuState());
			else
			{
				SONG = Song.loadFromJson(storyPlaylist[0].toLowerCase());
				FlxG.switchState(new PlayState());
			}
		}
		else
			startCountdown();
	}
	video.playVideo(Paths.video(name));
}

Examples

At the PlayState "create()" function:

switch (curSong.toLowerCase())
{
	case 'song1':
		playCutscene('song1scene.asf');
	case 'song2':
		playCutscene('song2scene.avi');
	default:
		startCountdown();
}

At the PlayState "endSong()" function:

if (SONG.song.toLowerCase() == 'song1')
	playCutscene('song1scene.mjpeg', true);

Examples for Kade Engine 1.8

At the PlayState "create()" function:

generateSong(SONG.songId);

switch (curSong.toLowerCase())
{
	case 'song1':
		playCutscene('song1scene.mp4');
	default:
		startCountdown();
}

At the PlayState "endSong()" function:

PlayState.SONG = Song.loadFromJson(PlayState.storyPlaylist[0], diff);
FlxG.sound.music.stop();

switch (curSong.toLowerCase())
{
	case 'song1':
		playCutscene('song1scene.ogg', true);
	case 'song2':
		playCutscene('song2scene.wav', true);
}

Building

Windows and MacOS

You don't need any special instructions in order to build for Windows or MacOS. Just pull the lime build windows / lime build mac command and the library will be building with your game.

Linux

In order to make your game work with the library, you have to install libvlc-dev and libvlccore-dev from your distro's package manager.

Example with APT:

sudo apt-get install libvlc-dev
sudo apt-get install libvlccore-dev
sudo apt-get install glibc-source
sudo apt-get install libidn12
sudo apt-get install libidn-dev

Android

Currently, hxCodec can load videos only from internal / external storage (not on the application storage).

In order this method for hxCodec to work on Android, you will need a library called extension-androidtools.

To install it, enter the following in a terminal:

haxelib git extension-androidtools https://github.com/MAJigsaw77/extension-androidtools.git

Next, add this into Project.xml

<haxelib name="extension-androidtools" if="android" />

You can can choose whether you want to use after you inport this in your code.

import android.content.Context;
  • From internal storage, Context.getFilesDir() or Context.getCacheDir()

  • From external storage, Context.getExternalFilesDir() or Context.getExternalCacheDir().

You will also have to put the location manually in the paths and to copy that video to the respective path.


Credits

About

Haxe library for native video support on HaxeFlixel.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 91.2%
  • C++ 5.2%
  • Haxe 3.6%