diff --git a/openvidu-browser/src/OpenVidu/Session.ts b/openvidu-browser/src/OpenVidu/Session.ts index 5fdfb579..d9aa3343 100644 --- a/openvidu-browser/src/OpenVidu/Session.ts +++ b/openvidu-browser/src/OpenVidu/Session.ts @@ -1376,8 +1376,8 @@ export class Session extends EventDispatcher { webrtcStatsInterval: queryParams['webrtcStatsInterval'], sendBrowserLogs: queryParams['sendBrowserLogs'], edition: queryParams['edition'], - wsUri = 'wss://' + url.host + '/openvidu', - httpUri = 'https://' + url.host + wsUri: 'wss://' + url.host + '/openvidu', + httpUri: 'https://' + url.host }; } else { diff --git a/openvidu-components-angular/projects/openvidu-angular/src/lib/directives/api/internals.directive.ts b/openvidu-components-angular/projects/openvidu-angular/src/lib/directives/api/internals.directive.ts new file mode 100644 index 00000000..cae6b33d --- /dev/null +++ b/openvidu-components-angular/projects/openvidu-angular/src/lib/directives/api/internals.directive.ts @@ -0,0 +1,47 @@ +// * Private directives * + +import { Directive, ElementRef, HostListener, Input } from '@angular/core'; + +/** + * Load default OpenVidu logo if custom one is not exist + * @internal + */ + @Directive({ + selector: 'img[ovLogo]' +}) +export class LogoDirective { + defaultLogo = + ''; + @Input() ovLogo: string; + constructor(public elementRef: ElementRef) {} + + @HostListener('error') + loadDefaultLogo() { + const element = this.elementRef.nativeElement; + element.src = this.ovLogo || this.defaultLogo; + } +} + +/** + * Load default OpenVidu logo if custom one is not exist + * @internal + */ + @Directive({ + selector: 'img[ovBackgroundImage]' +}) +export class BackgroundImageDirective { + defaultImages = + ''; + @Input() ovBakcgroundImage: string; + + private imgNumber: number = 0; + constructor(public elementRef: ElementRef) {} + + @HostListener('error') + loadDefaultLogo() { + console.log('number: ', this.imgNumber++); + // const element = this.elementRef.nativeElement; + // element.src = this.ovLogo || this.defaultLogo; + } +} + diff --git a/openvidu-components-angular/projects/openvidu-angular/src/lib/models/background-effect.model.ts b/openvidu-components-angular/projects/openvidu-angular/src/lib/models/background-effect.model.ts new file mode 100644 index 00000000..bb89036a --- /dev/null +++ b/openvidu-components-angular/projects/openvidu-angular/src/lib/models/background-effect.model.ts @@ -0,0 +1,13 @@ +export enum EffectType { + NONE = 'NONE', + BLUR = 'BLUR', + IMAGE = 'IMAGE' +} + +export interface BackgroundEffect { + id: string; + type: EffectType; + thumbnail: string; + src?: string; + description?: string; +} diff --git a/openvidu-components-angular/projects/openvidu-angular/src/lib/services/virtual-background/virtual-background.service.spec.ts b/openvidu-components-angular/projects/openvidu-angular/src/lib/services/virtual-background/virtual-background.service.spec.ts new file mode 100644 index 00000000..4a6573f8 --- /dev/null +++ b/openvidu-components-angular/projects/openvidu-angular/src/lib/services/virtual-background/virtual-background.service.spec.ts @@ -0,0 +1,16 @@ +import { TestBed } from '@angular/core/testing'; + +import { VirtualBackgroundService } from './virtual-background.service'; + +describe('VirtualBackgroundService', () => { + let service: VirtualBackgroundService; + + beforeEach(() => { + TestBed.configureTestingModule({}); + service = TestBed.inject(VirtualBackgroundService); + }); + + it('should be created', () => { + expect(service).toBeTruthy(); + }); +}); diff --git a/openvidu-components-angular/projects/openvidu-angular/src/lib/services/virtual-background/virtual-background.service.ts b/openvidu-components-angular/projects/openvidu-angular/src/lib/services/virtual-background/virtual-background.service.ts new file mode 100644 index 00000000..dbc5e1c9 --- /dev/null +++ b/openvidu-components-angular/projects/openvidu-angular/src/lib/services/virtual-background/virtual-background.service.ts @@ -0,0 +1,52 @@ +import { Injectable } from '@angular/core'; +import { BehaviorSubject, Observable } from 'rxjs'; +import { BackgroundEffect, EffectType } from '../../models/background-effect.model'; +import { ParticipantService } from '../participant/participant.service'; +import { TokenService } from '../token/token.service'; + +@Injectable({ + providedIn: 'root' +}) +export class VirtualBackgroundService { + backgroundSelected = >new BehaviorSubject(''); + backgroundSelectedObs: Observable; + backgrounds: BackgroundEffect[] = [ + { id: 'no_effect', type: EffectType.NONE, thumbnail: 'block', description: 'No background effect' }, + { id: 'soft_blur', type: EffectType.BLUR, thumbnail: 'blur_on', description: 'Blur effect' }, + { id: '1', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-1.jpg', src: 'assets/backgrounds/bg-1.jpg' }, + { id: '2', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-2.jpg', src: 'assets/backgrounds/bg-2.jpg' }, + { id: '3', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-3.jpg', src: 'assets/backgrounds/bg-3.png' }, + { id: '4', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-4.jpg', src: 'assets/backgrounds/bg-4.png' }, + { id: '5', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-5.jpg', src: 'assets/backgrounds/bg-5.png' }, + { id: '6', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-6.jpg', src: 'assets/backgrounds/bg-6.png' }, + { id: '7', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-7.jpg', src: 'assets/backgrounds/bg-7.png' }, + { id: '8', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-8.jpg', src: 'assets/backgrounds/bg-8.png' }, + { id: '9', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-9.jpg', src: 'assets/backgrounds/bg-9.png' }, + { id: '10', type: EffectType.IMAGE, thumbnail: 'assets/backgrounds/thumbnails/bg-10.jpg', src: 'assets/backgrounds/bg-10.png' } + ]; + + constructor(private participantService: ParticipantService, private tokenService: TokenService) { + this.backgroundSelectedObs = this.backgroundSelected.asObservable(); + } + + getBackgrounds(): any[] { + return this.backgrounds; + } + async applyBackground(effect: BackgroundEffect) { + this.backgroundSelected.next(effect.id); + + let options = { token: this.tokenService.getWebcamToken(), url: '' }; + if (effect.type === EffectType.IMAGE) { + options.url = effect.src; + } + + console.log(`VB:${effect.type.toLowerCase()}`); + console.log(options) + await this.participantService.getMyCameraPublisher().stream.applyFilter(`VB:${effect.type.toLowerCase()}`, options); + } + + async removeBackground() { + this.backgroundSelected.next('no_effect'); + await this.participantService.getMyCameraPublisher().stream.removeFilter(); + } +} diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-1.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-1.jpg new file mode 100644 index 00000000..4dfb09b9 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-1.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-10.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-10.jpg new file mode 100644 index 00000000..ec652955 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-10.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-2.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-2.jpg new file mode 100644 index 00000000..8d31a159 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-2.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-3.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-3.jpg new file mode 100644 index 00000000..16bafaf6 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-3.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-4.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-4.jpg new file mode 100644 index 00000000..621a343a Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-4.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-5.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-5.jpg new file mode 100644 index 00000000..d78fbe00 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-5.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-6.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-6.jpg new file mode 100644 index 00000000..9d3911c2 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-6.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-7.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-7.jpg new file mode 100644 index 00000000..0b15d7ee Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-7.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-8.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-8.jpg new file mode 100644 index 00000000..5c4f3155 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-8.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/bg-9.jpg b/openvidu-components-angular/src/assets/backgrounds/bg-9.jpg new file mode 100644 index 00000000..110c46e6 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/bg-9.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-1.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-1.jpg new file mode 100644 index 00000000..d6017e43 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-1.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-10.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-10.jpg new file mode 100644 index 00000000..3bcbd945 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-10.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-2.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-2.jpg new file mode 100644 index 00000000..42cfa7f6 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-2.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-3.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-3.jpg new file mode 100644 index 00000000..5b4c3273 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-3.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-4.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-4.jpg new file mode 100644 index 00000000..43bfade5 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-4.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-5.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-5.jpg new file mode 100644 index 00000000..a2c7bda1 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-5.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-6.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-6.jpg new file mode 100644 index 00000000..87f4dbbc Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-6.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-7.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-7.jpg new file mode 100644 index 00000000..8bb8b8fb Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-7.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-8.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-8.jpg new file mode 100644 index 00000000..d0f498e6 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-8.jpg differ diff --git a/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-9.jpg b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-9.jpg new file mode 100644 index 00000000..24d844d3 Binary files /dev/null and b/openvidu-components-angular/src/assets/backgrounds/thumbnails/bg-9.jpg differ diff --git a/openvidu-components-angular/src/assets/images/logo2.png b/openvidu-components-angular/src/assets/images/logo2.png new file mode 100644 index 00000000..4c2bfc85 Binary files /dev/null and b/openvidu-components-angular/src/assets/images/logo2.png differ