ID.nl logo
GitHub Codespaces: altijd de juiste tools bij de hand
Huis

GitHub Codespaces: altijd de juiste tools bij de hand

Als je aan een softwareproject wilt bijdragen, dien je vaak eerst een volledige ontwikkelomgeving op te zetten op je computer. GitHub Codespaces neemt je dat uit handen: je zet eenvoudig een ontwikkelomgeving in de cloud op, met toegang vanaf elke computer. Zo weet je zeker dat je overal dezelfde configuratie hebt en onmiddellijk aan de slag kunt.

Na het lezen van dit artikel weet jij hoe je zelf met GitHub Codespaces een ontwikkelomgeving op kunt zetten:

  • Codespace aanmaken en beheren voor een GitHub-repository
  • Codespace beheren via webinterface en GitHub CLI
  • Microsoft Visual Studio Code gebruiken
  • Devcontainers configureren voor aangepaste ontwikkelomgevingen

Ook interessant: Python: zo bouw je er webapplicaties mee

Als je meehelpt met de ontwikkeling van een of meer softwareprojecten, dan herken je zeker de uitdaging van altijd de juiste ontwikkeltools voorhanden te hebben. Het ene project werkt bijvoorbeeld met Python 3.12, terwijl het andere nog niet compatibel is met Python 3.12. En dan hebben we het nog niet over verschillen in versies van allerlei softwarebibliotheken. Bovendien vragen sommige projecten een nogal omslachtige of complexe installatie van de nodige ontwikkeltools.

Nu kun je als oplossing voor dit probleem deze hele ontwikkelomgeving per project waaraan je meewerkt met Docker in een container draaien. Die container draai je dan lokaal op je computer of in de cloud, waarmee je een consistente ontwikkelomgeving hebt. Je hoeft daardoor zelf niets meer te installeren of up-to-date te houden. Dit principe is uitgewerkt in een specificatie met instellingen voor zogenoemde ontwikkelcontainers, Development Containers, of kortweg devcontainers.

1 GitHub Codespaces

Voor projecten die hun broncode in een repository op GitHub publiceren, is het heel eenvoudig om een devcontainer in de cloud te gebruiken. GitHub biedt deze functionaliteit aan onder de naam GitHub Codespaces. Je start een devcontainer op de servers van GitHub en betaalt per uur dat je die draait en per gigabyte opslag die je gebruikt.

Standaard krijg je 15 GB opslag per maand gratis. Voor een dualcoresysteem geeft GitHub 60 uur gratis per maand weg, wat voor niet-professioneel gebruik zeker moet volstaan.

Verbinden met de codespace doe je of in je browser of in een code-editor, zoals Visual Studio Code. Je stopt een codespace eenvoudig wanneer je 'm niet meer nodig hebt en GitHub stopt ze ook automatisch na een half uur inactiviteit. Je data hierin blijven overigens behouden. Pas na dertig dagen inactiviteit verwijdert GitHub je codespace.

2 Codespace voor een repository

Als je een repository op GitHub in je browser bezoekt, zie je rechts boven de middelste kolom een groene knop Code. Klik je daarop, dan krijg je standaard in het eerste tabblad Local de url’s te zien om de code te ‘klonen’ met Git via https of ssh en de opdracht om hetzelfde te doen met het opdrachtregelprogramma GitHub CLI. Onderaan heb je ook een klassieke downloadlink naar een zip-bestand van de code. Zodra je de code op een van deze manieren op je computer hebt gedownload, sta je dus voor de taak om de ontwikkelomgeving hiervoor te installeren en te configureren.

Maar als je op het tweede tabblad onder Code klikt, met de naam Codespaces, kun je een nieuwe codespace voor de repository aanmaken. Je moet hiervoor wel een (gratis) GitHub-account hebben en ingelogd zijn. We laten in dit artikel zien hoe je een codespace aanmaakt en ermee werkt voor de repository Home Assistant Core. Open hier dus het tabblad Codespaces en klik op de groene knop Create codespace on dev. Die dev staat voor de standaard Git-branch van de repository.

3 Je eerste codespace

GitHub Codespaces maakt nu een codespace voor de repository op basis van de configuratie, doorgaans in de directory .devcontainer. Je krijgt nu een webgebaseerde versie van de code-editor Visual Studio Code in je browser te zien. Helemaal links staat een zijbalk met icoontjes voor de belangrijkste onderdelen van de code-editor, zoals de bestandsverkenner (die standaard open staat), de zoekfunctie en extensies.

Rechts vind je de editor, die standaard het README-bestand van de repository opent. Onderaan zie je de terminal, waarin in het begin een opdracht wordt uitgevoerd om de devcontainer te configureren en alle vereiste ontwikkeltools te installeren. Zodra dat is voltooid, toont de terminal een prompt met je GitHub-gebruikersnaam, de huidige directory en de Git-branch waarin je momenteel werkt, zoals dev. Met een klik op de drie horizontale lijnen linksboven kun je altijd het menu van Visual Studio Code openen.

4 Configuratie van de devcontainer

Als je wilt weten wat de devcontainer op de achtergrond precies opstart, open dan de configuratie. Die staat of in het bestand devcontainer.json in de directory .devcontainer, of in het bestand .devcontainer.json in de bovenste directory van het project. Dit is een JSON-bestand volgens de eerder in dit artikel genoemde specificatie.

In de configuratie vind je onder meer een verwijzing naar het Docker-bestand voor de container, en de opdrachten (vaak shellscripts) die worden uitgevoerd na het maken en starten van de container. Er staat ook in welke poorten de applicatie gebruikt.

Verder vind je in het configuratiebestand een lijst van extensies voor Visual Studio Code die automatisch worden geïnstalleerd bij het aanmaken van de codespace, evenals aangepaste instellingen voor de code-editor.

5 Werken in een codespace

Hoe werk je nu in zo’n codespace? De meeste projecten zijn zodanig geconfigureerd dat je in de zijbalk op het icoontje van het driehoekje met de kever (Run and Debug) kunt klikken en vervolgens bovenaan op het driehoekje (Run). Het programma start dan, met de wijzigingen die je eventueel in de code hebt aangebracht. In de terminal rechtsonder verschijnt de uitvoer van het programma, met eventuele foutmeldingen. Bovenaan in het midden staat een kleine balk met icoontjes om onder meer het programma te herstarten of te stoppen.

Als het gaat om een programma dat netwerkpoorten opent, krijg je deze te zien als je onderaan in plaats van het tabblad Terminal het tabblad Ports kiest. GitHub Codespaces stuurt deze poorten automatisch door naar een domein waarop je ze kunt bezoeken. Ctrl-klik in de lijst met poorten op een url bij de betreffende poort om ze te bezoeken. Mogelijk moet je de applicatie nog wel configureren om met een reverse proxy te werken.

Je verbruik volgen Hoewel GitHub Codespaces automatisch een codespace stopt na een half uur inactiviteit, houd je toch het best in de gaten hoeveel uren per maand je al hebt verbruikt om het aantal gratis uren niet te overschrijden. Dat is helaas niet vanuit de codespace zelf zichtbaar. Klik als je bent ingelogd op GitHub in een willekeurige pagina op je profielfoto rechts bovenaan en dan op Settings. Klik vervolgens in de linkerzijbalk op Billing and plans / Plans and usage. Scrol door naar Codespaces. Daar krijg je te zien hoeveel core-uren van de processor en hoeveel opslag je hebt verbruikt in de afgelopen dertig dagen.

6 Visual Studio Code

Voor wie liever niet in een browser werkt, biedt GitHub Codespaces nog andere mogelijkheden. Gebruik je bijvoorbeeld Microsofts code-editor Visual Studio Code op je computer, installeer daarin dan de extensie GitHub Codespaces. Dat doe je door in Visual Studio Code in de linkerzijbalk op het icoontje van de blokjes (Extensions) te klikken, dan te zoeken naar de extensie GitHub Codespaces en daarbij op Install te klikken.

Klik na de installatie in de zijbalk op het icoontje van het beeldscherm (Remote Explorer), klik bovenaan op het uitklapmenu en kies GitHub Codespaces. Klik daarna op de knop Sign in to GitHub en bevestig in de webpagina die in je browser wordt geopend dat je Visual Studio Code toegang tot je GitHub-account wilt geven. Je krijgt nu in de Remote Explorer al je codespaces te zien. Blijf er even met je muiscursor over hangen en klik dan op het icoontje van de stekker dat verschijnt om met de codespace te verbinden. Dit start de codespace ook op indien deze al is gestopt.

7 Codespaces in Visual Studio Code

Hoewel het in Visual Studio Code lijkt alsof je lokaal werkt, moet je je er goed van bewust zijn dat alle code die je ziet wanneer je met een codespace bent verbonden zich op GitHub Codespaces bevindt. Ook het uitvoeren van de code gebeurt in de cloud en niet op je eigen computer. Bovendien worden alle opdrachten die je in de terminal van Visual Studio Code intypt in de codespace uitgevoerd en niet op je eigen computer.

Om de verbinding met je codespace te verbreken, klik je links weer op het icoontje Remote Explorer en dan op het icoontje van de twee stekkers. Vanaf dat moment werk je weer op je lokale bestandssysteem met Visual Studio Code. Je kunt overigens in Remote Explorer wanneer je met je muiscursor over je codespace blijft hangen de codespace stoppen met een klik op het stopicoontje. Verwijderen kan ook: klik er met rechts op en kies dan Delete Codespace.

Interessant om ook te lezen: Kasm: experimenteren en veilig werken in een geïsoleerde omgeving

8 Op de opdrachtregel

GitHub heeft ook een opdrachtregelprogramma waarmee je in de terminal met je codespaces kunt werken. Volg de installatie-instructies van GitHub CLI en open een nieuw terminalvenster. Log in op je GitHub-account met de opdracht:

gh auth login

Volg de instructies en bevestig in je browser dat je GitHub CLI toegang wilt geven tot je GitHub-account.

Je kunt een lijst opvragen van je huidige codespaces met de opdracht:

gh codespace list

Dit toont voor al je codespaces de naam, de repository, de branch en de toestand (actief of gestopt). Je kunt ook met ssh (Secure SHell) op een codespace inloggen. Voer daarvoor deze opdracht uit en selecteer de gewenste codespace uit de lijst:

gh codespace ssh

Indien de codespace niet actief is, wordt deze eerst gestart. Dit werkt alleen als de codespace een ssh-server draait. Je kunt ook een codespace stoppen met deze opdracht (waarbij je achter de optie -c de naam van de codespace opneemt):

gh codespace stop -c redesigned-space-system-w95xvgv9gcwpr

9 Standaard devcontainer

Ook voor repository’s die geen configuratie voor een devcontainer hebben, kun je een codespace starten. We illustreren dit met de repository Bluetooth Numbers Database van Nordic Semiconductor. Maak op dezelfde manier als in stap 2 een codespace met een klik op Create codespace on master. De standaardbranch is hier namelijk master.

Omdat de repository geen devcontainer heeft geconfigureerd, start GitHub Codespaces een virtuele machine op met een standaardimage van het besturingssysteem. Daarin zijn de nodige ontwikkeltools voor Python, Node.js, JavaScript, TypeScript, C++, Java, C#, F#, .NET Core, PHP, Go, Ruby en Conda geïnstalleerd. Voor de meeste repository’s kun je dus direct aan de slag om eraan te werken in de cloud.

10 Je eigen devcontainer definiëren

Voor je eigen projecten kun je ook zelf een devcontainer definiëren, waarmee je dan een codespace aanmaakt. De eenvoudigste manier daarvoor is dat je je repository in Visual Studio Code opent, lokaal of terwijl je in een codespace werkt. Doe je dat lokaal, dan moet je eerst de extensie Dev Containers in Visual Studio Code installeren.

Open het opdrachtpalet met Ctrl+Shift+P (of F1 in de browser) en zoek op dev container. Als je lokaal werkt, klik je op Dev Containers: Add Dev Container Configuration Files. Als je in een codespace werkt, klik je op Codespaces: Add Dev Container Configuration Files. Klik op Create a new configuration, waarna je een lijst met enkele voorgedefinieerde devcontainers krijgt. Klik op Show All Definitions om ze allemaal te bekijken. Nu kun je beginnen met typen om te filteren op de gewenste container. Voor een Python-project typ je bijvoorbeeld python, waarna je een van de Python-containers uit de lijst kiest of op het icoontje met de i klikt voor documentatie over de betreffende container.

11 Devcontainer aanmaken

We kiezen hier voor de devcontainer Python 3 devcontainers van het devcontainers-project. Als je erop klikt, kun je nog de versie kiezen. De standaardversie 3.12-bullseye draait Debian 11 (codenaam bullseye) met Python 3.12. Nadat je een keuze hebt gemaakt, kun je nog extra pakketten aanvinken om te installeren. Klik op OK, waarna Visual Studio Code een bestand devcontainer.json in de map .devcontainer aanmaakt.

Als je de repository lokaal in Visual Studio Code hebt geopend, krijg je de vraag om het project opnieuw te openen om het te ontwikkelen in een container. Daarvoor heb je Docker op je computer nodig. Heb je de repository in een codespace geopend, dan zal Visual Studio Code vragen om je container opnieuw te bouwen met de nieuwe configuratie. Klik dan op Rebuild now. Daarna draait je codespace niet meer het standaardimage, maar jouw gekozen image.

12 Aangepaste configuratie

Je kunt het configuratiebestand devcontainer.json nog uitgebreid aanpassen. Voor de documentatie van de mogelijkheden bezoek je het best de specificatie van Development Containers. Met forwardPorts kun je poorten waarop je programma luistert, forwarden naar lokale poorten op je computer. En met postCreateCommand definieer je welke opdrachten er na het aanmaken van de devcontainer moeten worden uitgevoerd. Hierin handel je bijvoorbeeld de installatie van Python-pakketten af die je project nodig heeft.

In customizations kun je instellingen voor een code-editor aanpassen. Voor Visual Studio Code stel je hier bijvoorbeeld in welke extensies je in de codespace wilt installeren. Maar ook instellingen voor de editor zelf zijn hier mogelijk, zoals welke formatter er voor code gebruikt wordt en of die automatisch wordt opgeroepen wanneer je bestanden opslaat.

Codespaces beheren Op de webpagina Your codespaces van GitHub krijg je een overzicht van alle codespaces die je hebt aangemaakt. Je ziet er welke codespaces bij welke repository horen, of ze nog actief zijn en of er nog wijzigingen in de code staan die je nog niet hebt ‘gecommit’ met Git. Met een klik op de drie puntjes naast een codespace open je een menu. Hiermee kun je het type machine aanpassen als je meer processorkracht nodig hebt, de codespace stoppen of je nog niet gecommitte (niet-vastgelegde) wijzigingen naar een fork van de repository exporteren. Je kunt hier ook eenvoudig de codespace openen in je browser of in Visual Studio Code. Overigens kun je je codespaces ook op de opdrachtregel beheren met GitHub CLI, zoals in stap 8 staat.

Watch on YouTube
▼ Volgende artikel
Review LG 65QNED91T6A - Kan hij  tippen aan de concurrentie?
Huis

Review LG 65QNED91T6A - Kan hij tippen aan de concurrentie?

QNED, het antwoord van LG op quantum dots, wordt toegepast in deze miniled lcd-tv. Dit type televisie is inmiddels erg populair geworden, ook in het subtop- en middensegment van het tv-aanbod. Heeft deze LG 65QNED91T6A genoeg in huis om de concurrentie de baas te blijven?

Uitstekend
Conclusie

De 65QNED91T6A kan zijn miniled-beloftes niet echt waarmaken. Het aantal zones in de achtergrondverlichting is vrij laag, waardoor er maar een beperkte verbetering van het contrast is. Ook op het gebied van piekhelderheid scoort hij niet overdreven goed. Als we naar concurrenten in deze categorie kijken, zoals Hisense of TCL, dan bieden die meer zones, beter contrast en meer piekhelderheid. LG slaat de plank verder ook mis door reclame op het Home-scherm toe te laten, dat zetten we onverbiddelijk uit. Ondanks die beperking levert de tv nog voldoende contrast en piekhelderheid, en gecombineerd met een ruim kleurbereik en zeer goede beeldverwerking levert dat alsnog erg mooie beelden. De tv is op zijn best in verlichtte woonkamer. Hij ondersteunt Dolby Vision, maar geen HDR10+. LG vangt dat uitstekend op door zijn eigen dynamische tonemapping. Dat illustreert dat goede beeldverwerking net zo belangrijk als puur contrast of piekhelderheid. WebOS is een prima smart tv-systeem met ruim aanbod apps en functies en nu ook met de garantie voor vijf jaar nieuwe versies voor het OS. De prijs is wat ons betreft echter nog iets te hoog.

Plus- en minpunten
  • Voldoende piekhelderheid en goed contrast
  • Mooie HDR-beelden in HDR10 en Dolby Vision
  • Te weinig zones voor een miniled
  • Advertenties op het Home-scherm
  • Beperkte kijkhoek

OVER DIT TOESTEL

  • Adviesprijs: 1.799 euro
  • Wat: Ultra HD 4K 120 Hz Full Array miniled QNED LCD-tv met lokale dimming
  • Schermformaat: 65 inch (164 cm)
  • Aansluitingen: 4x HDMI (4x v2.1 (48 Gbps), ARC/eARC, ALLM, VRR, QMS), 2x USB, 1x optisch digitaal uit, 2x antenne, WiFi 5 (802.11ac), ethernet, Bluetooth 5.1, WiSA
  • Extra’s: HDR10, HLG, Dolby Vision IQ, Dolby Atmos, WebOS 24, AirPlay 2, USB/DLNA-mediaspeler, DVB-T2/C/S2, CI+-slot, Alpha 8 processor
  • Afmetingen: 1452 x 907 x 285 mm (incl. voet)
  • Gewicht: 35,0 kg (incl. voet)
  • Verbruik (per 1000 uur): SDR 84 kWh (E) / HDR 167 kWh (G)

ENERGIELABEL

MEER INFORMATIE

Deze LG-televisie past perfect in het rijtje van moderne, prima afgewerkte televisies die we dit jaar al vaker voorbij zagen komen. Het toestel is vrij slank dankzij het profiel van slechts 45mm, heeft een mooie metaalkleurige rand rondom en een vlakke rug. Aan de zijdes is de rug zoals bij de meeste toestellen wat afgeschuind. De centrale voet biedt geen verschillende draaiposities, maar het scherm staat desondanks toch 7cm hoog boven het tv-meubel, zodat een soundbar goed onder het scherm past. Het enige echt opvallende kenmerk? Het toestel is relatief zwaar, namelijk 35kg inclusief voet.

De tv beschikt over vier HDMI-poorten die allemaal de maximale HDMI 2.1-bandbreedte van 48Gbps bieden. Dat is nog steeds vrij zeldzaam, maar is wel goed nieuws voor gamers met meerdere high-end gaming-bronnen. Er is ondersteuning voor ALLM, 4K120 en VRR (AMD FreeSync en NVIDIA G-Sync) en op één poort kun je ARC/eARC gebruiken. De input-lag is iets hoger dan bij de oled-modellen, maar blijft zeer goed, 17,0ms (4K60) en 7,6ms (2K120). Wie de tv wil uitbreiden met draadloze luidsprekers, kan gebruik maken van het WiSA-protocol (Wireless Speaker and Audio Association). Je bent wel beperkt tot 2.1-configuraties, een WiSA surround-opstelling is dan helaas niet mogelijk.

Niet alle minileds zijn gelijk

Het gebruik van minileds voor de achtergrondverlichting is iets waar fabrikanten graag mee uitpakken, maar het resultaat per merk en model kan sterk uiteenlopen. Minileds verdelen de achtergrondverlichting in meer segmenten dan wanneer er gewone leds worden toegepast. Het aantal zones kan sterk verschillen, van 100 tot meer dan 1.000. Dat heeft uiteraard impact op de prestaties wat betreft contrast en helderheid.

Deze LG heeft een achtergrondverlichting met 16x10 (160) zones, en dat is vandaag de dag toch redelijk weinig. Concurrenten zitten in dit segment al op 1.500 zones. Het eigen contrast van het VA-paneel is goed, 4.800:1, maar met dat beperkt aantal zones stijgt dat nauwelijks naar 5.000:1, en dat is vooral ook omdat LG erg voorzichtig is met de dimming. Op eenvoudigere testen kan dit wel naar 35.000:1 stijgen. Naar een reden hoeven we niet ver te zoeken, agressief dimmen met zo weinig zones maakt de zonegrenzen zichtbaar, ook omdat ze soms wat traag reageren. Dat stoort erg en hierdoor is een vage halo rond heldere voorwerpen op een donkere achtergrond dan ook onvermijdelijk.

©LG Electronics

Ook op het vlak van helderheid doet de LG op veel vlakken onder voor de concurrentie. Op een 10% venster meten we in de goed gekalibreerde HDR Filmmaker mode 1.099 nits, en op het volledig wit beeld haalt hij nog 644 nits. Dat was twee jaar geleden weliswaar nog acceptabel, maar nu concurrenten vlot over de 2.000 nits gaan, is dat toch wat te beperkt. Het kleurbereik scoort wel uitstekend, daar meten we 95% P3.

Toch heeft LG nog een sterke troef in handen, namelijk de uitstekende kalibratie af fabriek. De Filmmaker mode is zowel in SDR als HDR bijzonder goed gekalibreerd. Dat betekent dat je kunt rekenen op veel schaduwnuances, een neutrale grijsschaal en mooie, natuurlijke kleurweergave. Met HDR10-beeld kan LG’s dynamische tone mapping prachtige resultaten opleveren en daarmee maakt de tv het beste van zijn kleurbereik en helderheid. Witnuances en intense kleuren worden uitstekend bewaard. Alleen heel donkere HDR10-scènes lijden wat onder het beperkte aantal zones, die beelden worden iets té donker. De QNED91 ondersteunt ook Dolby Vision, maar geen Dolby Vision IQ zoals bij de oled-modellen.

Uitstekende beeldverwerking

Naast een uitstekende kalibratie toont deze LG ook sterke prestaties voor beeldverwerking. Dat dankt de tv aan zijn Alpha 8-processor die verbeterd werd met eigenschappen en functies die vorig jaar nog exclusief voor de Alpha 9-processor waren. We kunnen zelfs zeggen dat de LG geen echte zwakke plekken meer heeft. Deinterlacen van 1080i-beelden zoals die van live tv, doet hij prima zodat je zelden nog een gekartelde rand ziet. Upscaling en ruisonderdrukking maken van oudere content mooie 4K-beelden, al kun je van oudere videocontent zoals dvd’s geen wonderen verwachten. Via een superresolutie-bewerking kan de tv wat fijn extra detail toevoegen, dat werkt goed voor HD-materiaal, maar kan bij dvd’s bijvoorbeeld wel voor een wat overbewerkt resultaat zorgen. De ruisonderdrukking kan ook kleurstroken in zachte gradiënten wegnemen.

©LG Electronics

Een lcd-paneel heeft minder bewegingsscherpte dan een oled-paneel, en dus maskeert het fijn detail in snelle actiescènes. Bewegende voorwerpen hebben soms een wazige rand of tonen een beperkt sleepspoor. LG biedt met Motion Pro verschillende opties om dat te elimineren, maar introduceren op hun beurt juist weer andere problemen, dus deze functie kun je beter uit laten staan. Heb je een hekel aan schokken in het beeld wanneer de camera snel beweegt, activeer dan de Trumotion-functie. Zeker voor sport is dat prettig, maar voor film blijft het vaak een kwestie van smaak.

Degelijke audio

De QNED91 is uitgerust met een 2.2-systeem van 40 watt, en ondersteuning voor Dolby Atmos en DTS:X. Onze filmfragmenten klonken prima met een aangename warme klank en een vleugje ruimtelijkheid. Die echte surround sound-ervaring kan je uit dit soort systeem niet halen, zelfs niet met ondersteuning voor de modernste audioformaten. Dat AI niet altijd de juiste resultaten geeft, werd hier bevestigd. De tv heeft een AI-Pro mode voor geluid, maar die klonk erg slecht, zeker voor muziek. In de muziek audiomode konden we het resultaat wél waarderingen, als loop je daar wel tegen beperkingen aan wanneer je voor hardere muziekgenres zoals metal kiest. Met het volume op ongeveer driekwart hoor je de woofer trillen in het chassis en gaat de bas uit de bocht. Al bij al een degelijk resultaat, in lijn met deze categorie. 

WebOS 24, helaas met reclame

De smart tv-omgeving van LG, WebOS, heeft veel goede punten. Zo vind je nagenoeg alle streaming-apps op dit platform, zowel internationaal als lokaal. Daarnaast heeft LG op de 2024-versie van webOS naast Airplay 2 ook Google Cast geïmplementeerd zodat je vanaf je smartphone, Android of iOS, moeiteloos content naar de tv kunt streamen. Apps en andere functies zijn gegroepeerd in zogeheten Quick Cards, zodat je gemakkelijk bepaalde functies kunt terugvinden.

©Eric Beeckmans | ID.nl

Er zijn Quick Cards voor Thuis-hub, Sport, Thuiskantoor, Games, Muziek, Toegankelijkheid en sinds kort ook voor Leren en Groeien. De lay-out van WebOS zelf is vrij eenvoudig en ook redelijk compact zodat je niet nodeloos hoeft te scrollen om iets te vinden. De Magic Remote van LG waarmee je een cursor bestuurt door naar het scherm te wijzen blijft ook een belangrijke factor in het gebruiksgemak. Aangezien smart tv-platformen nog steeds evolueren is het ook erg fijn om te weten dat LG nu vijf jaar lang de nieuwste versie van WebOS op je tv belooft te plaatsen. In dit overzichtsartikel vind je alle info over webOS.

Toch heeft LG wat ons betreft een foute beslissing genomen. De fabrikant toont namelijk nu reclame op het Home-scherm, en die reclame is in tegenstelling tot bij andere fabrikanten niet beperkt tot content, maar kan bijvoorbeeld ook een sportwinkel of automerk tonen. Dat is echt wel het laatste wat we willen. Zelfs de screensaver kan reclame tonen (al zagen daar gelukkig alleen LG’s eigen LG Channel-dienst). Je kunt de reclame uitschakelen via de instellingen, iets dat we dan ook van harte aanraden.

Conclusie

De 65QNED91T6A kan zijn miniled-beloftes niet echt waarmaken. Het aantal zones in de achtergrondverlichting is vrij laag, waardoor er maar een beperkte verbetering van het contrast is. Ook op het gebied van piekhelderheid scoort hij niet overdreven goed. Als we naar concurrenten in deze categorie kijken, zoals Hisense of TCL, dan bieden die meer zones, beter contrast en meer piekhelderheid. LG slaat de plank verder ook mis door reclame op het Home-scherm toe te laten, dat zetten we onverbiddelijk uit.

Ondanks die beperking levert de tv nog voldoende contrast en piekhelderheid, en gecombineerd met een ruim kleurbereik en zeer goede beeldverwerking levert dat alsnog erg mooie beelden. De tv is op zijn best in verlichtte woonkamer. Hij ondersteunt Dolby Vision, maar geen HDR10+. LG vangt dat uitstekend op door zijn eigen dynamische tone mapping. Dat illustreert dat goede beeldverwerking net zo belangrijk als puur contrast of piekhelderheid. WebOS is een prima smart tv-systeem met ruim aanbod apps en functies en nu ook met de garantie voor vijf jaar nieuwe versies voor het OS. De prijs is wat ons betreft echter nog iets te hoog.

▼ Volgende artikel
Virtuele webcams: special effects voor je videogesprekken
Huis

Virtuele webcams: special effects voor je videogesprekken

Je bent aan het videobellen, maar de achtergrond ziet er slordig uit. Of misschien wil je tussendoor een kort filmpje tonen, het beeld optimaliseren of opfleuren met enkele effecten. Software die je als virtuele webcam gebruikt, maakt dit en nog veel meer mogelijk.

In dit artikel stellen we enkele virtuele webcam-applicaties aan je voor:

  • FineCam
  • ManyCam
  • OBS Studio

Lees ook: Geen pottenkijkers meer! Zo schakel je de webcam uit

Er zijn al langer applicaties beschikbaar waarmee je filters, effecten en virtuele achtergronden aan je videogesprek toevoegt. De populaire mobiele app Snapchat was een van de eerste. Met uitgebreide filters en lenzen kun je in realtime beelden aanpassen. Je geeft jezelf bijvoorbeeld kattenoren of verandert de omgeving. Snapchat gebruikt Augmented Reality (AR) om digitale elementen over echte beelden te plaatsen.

Inmiddels heeft ook Artificiële Intelligentie (AI) zijn intrede gedaan om effecten nauwkeurig op bewegende gebruikers toe te passen. Videoconferentietools zoals Teams en Zoom, gebruiken AI. Denk aan machinelearning-technologieën en convolutionele neurale netwerken. Daarmee is de gebruiker van zijn achtergrond te scheiden en kan er een virtuele achtergrond worden getoond. Een green screen is niet meer nodig.

In het gratis Microsoft Teams start je bijvoorbeeld een videogesprek via Nu vergaderen / Vergadering starten. Als je op Meer en Achtergrondeffecten klikt, kun je uit tientallen achtergronden kiezen of je achtergrond vervagen. Via Nieuwe toevoegen importeer je een specifieke achtergrond, bijvoorbeeld ontworpen door een AI-beeldgenerator.

Mogelijkheden

Virtuele webcams kun je gebruiken om speciale effecten, filters en grafische overlays aan je live-video toe te voegen, of om de achtergrond te vervagen of te vervangen. Als de gebruikte software dit toelaat, kun je ook afbeeldingen of andere video’s als webcam-uitvoer gebruiken. Zo kun je bijvoorbeeld je computerscherm delen. Tijdens je live-gesprek of -stream wissel je dan tussen video’s, afbeeldingen en zelfs verschillende camera’s, zoals een HDMI-camera die je gebruikelijke videoconferentietool mogelijk niet als (web)camera herkent.

Dit alles maakt dat virtuele webcam-software niet alleen leuk is voor persoonlijk gebruik, maar ook efficiëntere videoconferenties in een zakelijke context, of professionelere videostreams naar platforms als YouTube Live en Twitch mogelijk maakt. Je kunt zelfs de camera van je smartphone als webcam gebruiken. Dat is handig als je een optimaal beeld wilt hebben of als je computer niet over een webcam beschikt.

DroidCam Heb je geen webcam op je pc en wil je alleen je mobiele telefoon als webcam gebruiken tijdens live-videoconferenties? Dan kun je het gratis DroidCam gebruiken, beschikbaar in de officiële appstore van zowel Android als Apple. Op de website van de makers vind je ook een desktopclient voor Linux en Windows. Gebruik eventueel versie 6.x als versie 7.0 nukkig doet, zoals op onze pc.

Start de mobiele app en de desktop-client op. Zorg dat beide apparaten met hetzelfde netwerk zijn verbonden. Op je mobiele app zie je een ip-adres en poortnummer. Beide voer je in op je desktop-app (bijvoorbeeld 192.168.0.165 met standaardpoort 4747). Start daarna je videoconferentie-software en selecteer DroidCam als webcam. In Teams start je bijvoorbeeld een videovergadering, klik je op Meer en kies je Instellingen / Apparaatinstellingen. Bij zowel Microfoon als Camera selecteer je DroidCam (bijvoorbeeld Source 2 of Source 3). Wil je HD-resolutie? Dan heb je de betaalde Pro-versie van DroidCam nodig (ongeveer 5 euro).

Geen webcam? Met Droidcam maak je een virtuele webcam van je mobiele apparaat.

Applicaties

Er zijn verschillende programma’s voor virtuele webcams. In dit artikel focussen we ons op software die onder Windows draait en ook beschikbaar is als mobiele app. Op die manier kun je je smartphone of tablet als webcam gebruiken. Populaire applicaties zijn onder meer FineCam en ManyCam, die we beide kort voorstellen. Daarnaast besteden we aandacht aan een gratis opensource-alternatief: OBS Studio. Met deze tool combineer je meerdere videobronnen en creëer je scènes en overgangen. Dit maakt het bij uitstek geschikt voor live-streaming en schermopnames. OBS Studio ondersteunt bovendien een virtuele webcamfunctie, waardoor je OBS-uitvoer in videoconferentie-apps kunt gebruiken.

FineCam: set-up

Download FineCam. Met een druk op Install zet je de software op je pc. De gratis versie heeft een watermerk in de video. Wil je deze weg hebben? Dan heb je de betaalde Pro-versie nodig. Deze kost eenmalig zo’n 60 euro en ondersteunt ook resoluties van 1080p en hoger.

Na het opstarten kun je via het pijlknopje linksboven je aangesloten webcam selecteren. Een andere optie is om een mobiel Apple- of Android-apparaat te kiezen. Je moet dan wel de mobiele app van FineCam op dit apparaat draaien. Als het apparaat met hetzelfde netwerk is verbonden, druk je op de mobiele app op Connect en bevestig je met Agree in de desktop-app om een verbinding te maken. Het camerabeeld verschijnt dan direct in het applicatievenster.

FineCam: configuratie

FineCam kun je op verschillende manieren aansturen. We beperken ons tot de opties die ook in de gratis versie beschikbaar zijn. Zo kun je bijvoorbeeld het camerabeeld verplaatsen over de achtergrond, maar niet schalen. Bovenaan vind je knoppen om in- en uit te zoomen, het beeld te keren of te roteren en de vorm in te stellen, zoals Rectangle of Circle. Met Adjustment onderaan optimaliseer je de licht- en kleurinstellingen met schuifregelaars, zoals Brightness, Contrast, Saturation en White Balance.

Je kunt ook op Filter klikken om een van de ruim dertig vooraf ingestelde beeldweergaves te selecteren. Is je eigen fysieke achtergrond niet geschikt voor videobellen? Kies dan via Background uit twintig virtuele achtergronden. Of ontwerp je eigen achtergrond door bij AI Generated Background een prompt voor de AI-beeldgenerator in te voeren.

Kies je via Theme een lay-out waarbij je eigen webcambeeld niet het volledige scherm bedekt, dan kun je met Content tegelijkertijd andere inhoud tonen. Denk aan een webpagina, applicatievenster, video (ook via een YouTube-url), iPhone-beeld, PowerPoint-presentatie, tekst of eigen foto. In je videoconferentietool selecteer je FineShare FineCam om de virtuele camera te gebruiken. Mogelijk moet je nog bevestigen met de blauwe knop Virtual Camera rechtsonder in FineCam.

ManyCam: set-up

FineCam bevat ook de knop Multi-scenes waarmee je meerdere virtuele opzetten klaarzet en snel schakelt. Helaas is deze functie alleen beschikbaar in de Pro-versie. Een goed alternatief is dan ManyCam voor Windows en macOS. De betaalde versies zijn er vanaf ongeveer 45 euro per jaar. Je hebt dan geen watermerk en meer effecten, hogere resoluties (full HD tot 4K) en meerdere simultane videobronnen.

We beperken ons hier tot de gratis versie mét watermerk. Start de tool en klik op de plusknop in het hoofdvenster. In het uitklapvenster bij Camera’s selecteer je de gewenste (web)cam. In het rechtervenster kun je allerlei beeldinstellingen aanpassen, zoals Zoomen, Corner Radius, Ondoorzichtigheid en diverse opties bij Color Adjustment.

ManyCam: configuratie

In de gratis versie van ManyCam kun je maximaal twee presets klaarzetten, elk met verschillende beelden en instellingen. Klik op de plusknop in het tweede vakje onderaan het camerabeeld. Je kunt nu een andere camera selecteren of kiezen uit diverse opties, zoals Afbeeldingen en video’s, PowerPoint, PDF, YouTube URL en Desktop. Bij meerdere beeldschermen kun je zelf aangeven welk scherm je live wilt tonen. Andere opties zijn hier onder meer Gebied onder cursors (handig voor het volgen van je muisbewegingen) en App-venster. Net als bij FineCam kun je hier ook een mobiel apparaat gebruiken, waarmee je smartphone of tablet als webcam werkt.

Een preset verwijder je eenvoudig via het prullenbakicoon. Met het knopje met de drie puntjes stel je een visueel overgangseffect in bij het schakelen tussen presets. Er zijn nog vele andere effecten beschikbaar via de toverstaf bovenaan. Kies uit verschillende rubrieken, zoals GIFS (druk op het plusknopje om eigen afbeeldingen te gebruiken), Animals, Emojis en Face Accessories. Via Asset Store download je extra items.

OBS Studio: set-up

Zowel FineCam als ManyCam zijn gebruiksvriendelijke programma’s, maar helaas zijn de mogelijkheden in de gratis versies beperkt en wordt je video ontsierd door een watermerk. Een volledig gratis alternatief is OBS Studio. Download de tool (beschikbaar voor Windows, macOS en Linux) en installeer deze. Bij de opstart merk je al snel dat er veel functies zijn. We beperken ons hier tot enkele leuke opties voor het gebruik van een virtuele camera.

Allereerst controleer je de videoresolutie. Klik rechtsonder op Instellingen en open de rubriek Video. Stel de Basisresolutie bij voorkeur in op die van je monitor (bijvoorbeeld 1920x1080 en 16:9). De Uitvoerresolutie stel je normaal gesproken op dezelfde waarden in, tenzij je videoconferentietool andere waarden voorstelt. Bevestig met OK.

Linksonder in het hoofdvenster merk je dat OBS Studio al één scène heeft aangemaakt. Rechtsklik op deze scène en noem deze bijvoorbeeld Virtuele webcam. Nu moet je natuurlijk nog de gewenste bronnen aan je virtuele webcambeeld toevoegen.

OBS Studio: bronnen

Standaard heeft OBS Studio al één bron toegevoegd: Vensteropname. Je mag deze selecteren en met het prullenbakicoon verwijderen. Druk vervolgens op de plusknop en kies Video opname-apparaat om je fysieke webcam toe te voegen. Kies Nieuwe maken en geef deze als naam bijvoorbeeld Mijn webcam. Bevestig met OK en kies de juiste webcam bij Apparaat. Resolutie/FPS Type staat standaard op die van het apparaat, maar je kunt hier ook Aangepast kiezen. Klik op Video Instellen om allerlei beeldinstellingen te optimaliseren.

Na je bevestiging met OK verschijnt het webcambeeld op je canvas en kun je dit met de muis verplaatsen, roteren en schalen. Dit is vooral interessant als je nog andere content (bronnen) wilt toevoegen. Klik op (De)activeren om de video in één keer zichtbaar of onzichtbaar te maken.

Voor extra content klik je op het plusknopje bij Bronnen en voeg je onderdelen toe zoals Afbeelding, Beeldschermopname, Browser, Diashow, Vensteropname (van een nader te bepalen app) of Mediabron (om bijvoorbeeld een eigen videobestand te tonen). Elk van de toegevoegde bronnen kun je vervolgens positioneren en schalen op je canvas.

Wil je snel kunnen afwisselen tussen een beeld waarin je zelf prominent op de voorgrond staat met een applicatievenster verkleind op de achtergrond, en andersom? Maak dan twee scènes aan. Klik met rechts op je eerste scène, kies Dupliceren en noem deze bijvoorbeeld Applicatie (webcam). Vervolgens schaal je de objecten (bronnen) van de andere scène naar wens. Klik ook met rechts op zo’n object, want er zijn nog veel meer opties. Zo kun je bijvoorbeeld via Volgorde / Naar boven verplaatsen een object in één keer naar de voorgrond halen.

OBS Studio: camera

Vanuit ditzelfde contextmenu kun je nog veel andere bewerkingen uitvoeren. Bij Transformeren bijvoorbeeld vind je opties om het geselecteerde beeld te spiegelen of te draaien, en bij Filters kun je via de plusknop allerlei beeldeffecten toepassen.

Hoe krijg je de klaargemaakte scènes uit OBS Studio in je videoconferentie-app? Dit is wellicht eenvoudiger dan je denkt. Druk rechtsonder in OBS Studio op Start virtuele camera en selecteer in de videoconferentie-app OBS Virtual Camera (bij Skype bijvoorbeeld via Instellingen / Audio en Video, in het uitklapmenu bij Camera). De scène die op dat moment binnen OBS Studio actief is, komt nu in beeld. Een scène-wissel is niet moeilijker dan in OBS Studio de gewenste scène te selecteren.

Onder het camerabeeld bij Scène-overgangen kun je bovendien een transitie-effect instellen dat bij een scène-wissel ook binnen je videoconferentie-app te zien zal zijn. Je kunt op elk moment op Stop virtuele camera drukken om de videostream vanuit OBS Studio te onderbreken.