Flashphoner implementation for Angular
Using npm:
$ npm install @codeda/flashphoner
Using yarn:
$ yarn add @codeda/flashphoner
- Init
FlashphonerModule
:
@NgModule({
imports: [
...,
FlashphonerModule.forRoot({
session: {
urlServer: ${flashphonerServerUrl}
}
})
]
})
export class AppModule {}
- Create/play stream:
import { FlashphonerService } from '@codeda/flashphoner';
@Component(...)
export class MyComponent {
constructor(flashphonerService: FlashphonerService) {
// Create stream
flashphonerService
.createStream({
name: ${streamName},
display: ${someHTMLElement},
constraints: [MediaStreamConstraints](https://developer.mozilla.org/en-US/docs/Web/API/MediaStreamConstraints)
})
.subscribe(stream => console.log(stream));
// Play stream
flashphonerService
.playStream({
name: ${streamName},
display: ${someHTMLElement}
})
.subscribe(stream => console.log(stream));
}
}
- Requires Flashphoner WebSDK.
- For proper stream playing in iOS you should pass extra params to
FlashphonerModule.forRoot
method:
FlashphonerModule.forRoot({
session: {
flashphoner: {
flashMediaProviderSwfLocation: ${your path to media-provider.swf},
receiverLocation: ${your path to WSReceiver2.js},
decoderLocation: ${your path to video-worker2.js}
},
urlServer: ${flashphonerServerUrl}
}
})
And before calling flashphonerService.createStream
use this code:
if (Flashphoner.getMediaProviders()[0] === 'WSPlayer') {
Flashphoner.playFirstSound();
} else if (
Browser.isSafariWebRTC() ||
Flashphoner.getMediaProviders()[0] === 'MSE'
) {
Flashphoner.playFirstVideo(options.display);
}
Also serve preloader.mp4 at url path /dependencies/preloader.mp4.
utils.js - contains Browser; media-provider.swf WSReceiver2.js video-worker2.js