ID.nl logo
Python: zo bouw  je er webapplicaties mee
© Chaosamran_Studio - stock.adobe.
Huis

Python: zo bouw je er webapplicaties mee

JavaScript is de standaard programmeertaal voor webapplicaties. Maar voor liefhebbers van Python is er goed nieuws: dankzij PyScript kun je ook in je favoriete programmeertaal webapplicaties bouwen. Hierdoor krijg je toegang tot een breed scala aan populaire Python-bibliotheken. Bovendien kun je de Python-code moeiteloos communiceren met JavaScript-code.

In dit artikel gaan we dieper in op de mogelijkheden van PyScript voor het ontwikkelen van webapplicaties. Je leert:

  • Hoe je PyScript in het html-bestand verwerkt
  • Hoe je grafieken kunt plotten
  • Hoe je JavaScript als Python-code kunt laten gedragen

Lees ook deze 10-delige cursus over programmeren in Python: Zo kun je programmeren in Python - Deel 1

Code downloaden In deze workshop worden lange voorbeelden van stukken code gegeven. Omdat overtikken van code erg foutgevoelig is, kun je die code beter downloaden en daarna bekijken of kopiëren. Zie het bestand code-pyscript.txt voor de stukken code die in dit artikel genoemd worden.

Webapplicaties maken doorgaans gebruik van een drie-eenheid van (programmeer)talen: HyperText Markup Language (html), Cascading Style Sheets (css) en JavaScript. Html is een opmaaktaal waarmee je de structuur en inhoud van een webpagina definieert. Met css definieer je stijlen die de vormgeving van de pagina beschrijven. En JavaScript is een programmeertaal waarmee je het gedrag van de pagina bepaalt.

Hoewel JavaScript de dominante programmeertaal is in de wereld van webapplicaties, heeft het erbuiten niet dezelfde populariteit kunnen winnen. Python daarentegen is een populaire programmeertaal in diverse domeinen, onder andere voor data-analyse, machine learning, wetenschappelijke projecten, scripting en de serverkant van webapplicaties. Hoe handig zou het zijn als je jouw kennis van Python ook in de webbrowser kunt toepassen?

1 PyScript

Dat is precies wat PyScript mogelijk maakt: Python-toepassingen ontwikkelen die in de webbrowser werken. Net zoals je JavaScript-code in een html-pagina kunt opnemen, kun je dat dankzij PyScript ook met Python-code doen. Bovendien kunnen Python- en JavaScript-objecten probleemloos met elkaar communiceren, zodat je niet gebonden bent aan PyScript, maar je Python-code kunt combineren met bestaande JavaScript-bibliotheken.

Je kunt met PyScript ook gebruikmaken van heel wat populaire Python-pakketten, zoals Beautiful Soup, Matplotlib, NumPy, Pandas of Scikit-learn. Op die manier kun je dus niet alleen je kennis van de programmeertaal Python meenemen naar je webapplicaties, maar ook die van het uitgebreide Python-ecosysteem. Als je dus vertrouwder bent met Python dan met JavaScript en je webapplicaties wilt bouwen, dan is PyScript een logische keuze.

PyScript laat je toe om webapplicaties te ontwikkelen met Python.

2 Hallo wereld

Een PyScript-webapplicatie heeft drie bestanden nodig. Eerst en vooral een html-bestand, bijvoorbeeld index.html, met de structuur van je webpagina, verwijzingen naar PyScript zelf en je eigen Python-script. Een tweede bestand beschrijft de Python-omgeving waarin je applicatie draait. Hierin geef je bijvoorbeeld aan welke extra Python-pakketten je script gebruikt. Dit bestand heet pyscript.toml of pyscript.json. Tot slot is er je Python-script zelf, dat je in een Python-bestand als main.py opslaat.

Een eenvoudig html-bestand voor een PyScript-applicatie ziet er als volgt uit:

De code kun je downloaden van deze pagina en daarna vanuit een programma als Kladblok overnemen.

Je verwijst hier in het element head naar de css-stylesheet en JavaScript-code van PyScript. In het element script van de body verwijs je dan naar je Python-script.

3 Python-script

In de body van de html-pagina vind je het element button met een attribuut py-click dat de waarde "generate_text" heeft. Hiermee geef je aan dat bij een klik op die knop de Python-functie generate_text wordt aangeroepen. In het element script verwijs je vervolgens naar je Python-script main.py. Met type="py" geef je aan dat het om een Python-script gaat in plaats van een JavaScript-bestand. En met het attribuut config verwijs je naar het configuratiebestand waarin je definieert welke Python-pakketten PyScript voor je applicatie moet installeren. Als je bijvoorbeeld het pakket lorem-text wilt gebruiken, dan ziet het bestand pyscript.toml er als volgt uit:

packages = ["lorem-text"]

Het Python-script main.py heeft de volgende inhoud:

De code kun je downloaden van deze pagina en daarna vanuit een programma als Kladblok overnemen.

We importeren hier dus de module lorem uit lorem-text, het pakket dat we hebben geïnstalleerd. Vervolgens importeren we ook document uit PyScript. In de functie generate_text, die wordt aangeroepen wanneer je in de webpagina op de knop klikt, krijg je via document toegang tot het volledige Document Object Model (DOM) van de webpagina. Hiermee selecteer je het element met de id output. De functie roept dan lorem.paragraph() aan om een alinea met willekeurige tekst te genereren en kent die toe aan de tekst van het geselecteerde element.

PyScript geeft je toegang tot het ecosysteem van de Python Package Index (PyPI).

Onder de motorkap Standaard draai je Python in de volledige omgeving van je besturingssysteem. Deze versie van Python, de officiële Python dus, heet CPython. Om Python in de ingeperkte omgeving van je webbrowser te laten draaien, maakt PyScript gebruik van Pyodide. Dit project is op zijn beurt gebaseerd op WebAssembly, dat een virtuele machine biedt om willekeurige software in de omgeving van je webbrowser te laten draaien. Software die voor WebAssembly is gecompileerd, heeft volledige toegang tot alle functionaliteit van je webbrowser en dezelfde web-API’s (application programming interfaces) die voor JavaScript toegankelijk zijn. Pyodide compileert CPython naar WebAssembly. Op die manier slaagt PyScript er dus in om een volwaardig alternatief voor JavaScript te bieden voor webapplicaties.

4 Webserver

Je PyScript-applicatie is nu klaar, maar je kunt het html-bestand niet gewoonweg in je webbrowser openen als een lokaal bestand. Je moet het bestand via een webserver aanbieden. Als je Python lokaal (op je computer) hebt geïnstalleerd, kun je eenvoudig de ingebouwde webserver van Python opstarten. Navigeer in een terminalvenster of opdrachtprompt naar de directory waarin je PyScript-bestanden staan en voer de volgende opdracht uit:

python -m http.server

Dit start een webserver op poort 8000 die de inhoud van de huidige directory aanbiedt. Bezoek vervolgens in je webbrowser de url http://127.0.0.1:8000/, die verwijst naar poort 8000 op je computer zelf. Je krijgt nu een webpagina te zien met als titel Hallo wereld en een knop met als label Lorem ipsum.

Wacht even tot de hele PyScript-omgeving is ingeladen. Klik dan op de knop wanneer die niet meer grijs is. Eronder verschijnt vervolgens een alinea met willekeurige tekst. Elke keer dat je op de knop drukt, verschijnt er een nieuwe tekst omdat de functie generate_text weer wordt aangeroepen.

Eén druk op de knop roept een Python-functie op die willekeurige tekst genereert.

5 Grafieken plotten

Nu kun je ook in je webapplicaties gebruikmaken van het krachtige ecosysteem van Python-pakketten voor bijvoorbeeld datavisualisatie, zoals Matplotlib. Het principe is hetzelfde als het eerste voorbeeld met de lorem ipsum-tekst: je creëert een html-bestand met de structuur van je webpagina, een bestand met de Python-pakketten die je nodig hebt, en uiteindelijk een bestand met je Python-code. Het bestand met de afhankelijkheden, pyscript.toml, vermeldt eenvoudigweg het pakket Matplotlib:

packages = ["matplotlib"]

Het html-bestand index.html ziet er als volgt uit:

De code kun je downloaden van deze pagina en daarna vanuit een programma als Kladblok overnemen.

In dit voorbeeld laten we de gebruiker een amplitude en periode kiezen, om vervolgens een grafiek van de sinusfunctie met die ingestelde amplitude en periode te plotten.

Matplotlib is dé Python-bibliotheek voor visualisaties.

6 Schuifbalken

In de html-code definiëren we twee elementen input van het type range. Je webbrowser toont die als schuifbalken. We stellen voor elk element een minimum en maximum in, een stap (de waarde waarmee de schuifbalk per eenheid wordt verschoven) en een standaardwaarde. We geven beide elementen ook een label, met diezelfde standaardwaarde, zodat de gebruiker niet alleen een bolletje op een schuifbalk ziet, maar ernaast ook de waarde die daardoor wordt ingesteld.

Eronder plaatsen we dan een element div waarin de grafiek komt. We definiëren hier ook een script dat naar het Python-bestand en de configuratie met de te installeren pakketten verwijst. In de elementen input verwijzen we ook naar de in dit Python-bestand gedefinieerde functie plot_sine die wordt uitgevoerd bij elke wijziging van de invoer in het element. De webapplicatie roept de functie daardoor aan telkens als je aan de schuifbalk sleept.

7 Sinus plotten

Dan volgt uiteindelijk de code in main.py om de sinusfunctie te plotten:

De code kun je downloaden van deze pagina en daarna vanuit een programma als Kladblok overnemen.

De functie plot_sine haalt allereerst de waarde op van het element met de id amplitude en wijzigt de tekst van het label voor dat element naar die waarde. Daarna doet de functie hetzelfde voor het element met de id period. Deze eerste regels code synchroniseren dus elke keer de getoonde waarde met de ingestelde waarde, zodat de gebruiker onmiddellijk feedback krijgt bij het schuiven.

Daarna creëren we met NumPy’s functie arange een reeks x-waarden en vervolgens berekenen we voor elk van die x-waarden de sinusfunctie met NumPy’s functie sin. Door het argument van de sinusfunctie te vermenigvuldigen met 2π en te delen door de periode, berekenen we de sinus met de gewenste periode: de kromme wordt zo breder of smaller geplot. Door het resultaat van de sinusfunctie met de amplitude te vermenigvuldigen, wordt de kromme hoger of lager geplot.

Uiteindelijk maken we de huidige figuur leeg, plotten we de x- en y-waardes in het blauw, voegen we een raster toe en stellen we het bereik voor de x- en y-as in. Daarna tonen we de plot in het target sine, dat verwijst naar de id van het desbetreffende element div in het html-bestand. Helemaal op het einde van het Python-bestand roepen we de functie ook expliciet op. Zo wordt de grafiek ook getoond nadat de pagina is geladen, zonder dat de gebruiker eerst met een van de schuifbalken moet schuiven.

Deze grafiek plotten we in Python dankzij Matplotlib.

8 JavaScript in Python aanroepen

Er bestaat uiteraard al een heel ecosysteem van JavaScript-bibliotheken voor webapplicaties. Je hoeft het wiel niet opnieuw uit te vinden in Python of een Python-alternatief te zoeken als je er al een in JavaScript bij de hand hebt. Zoals we eerder al schreven, biedt PyScript volledige interoperabiliteit tussen Python- en JavaScript-code in je webapplicaties. Om JavaScript-functies in je Python-code aan te roepen, importeer je de globale JavaScript-namespace met:

import js

Daarna gedraagt js zich in je Python-code als een Python-module en kun je alle globale JavaScript-functies aanroepen met js.naamvanfunctie.

Als je asynchrone JavaScript-functies wilt aanroepen, moet je ook de module asyncio in je Python-code importeren en de functies aanroepen met await ervoor.

9 Alles in één

Laten we dit eens illustreren met een eenvoudig voorbeeld dat de JavaScript Fetch API gebruikt om je publieke ip-adres via de website ipify op te vragen. We tonen meteen een alternatieve manier om PyScript te gebruiken door de Python-code rechtstreeks in het html-bestand te plaatsen in plaats van een afzonderlijk Python-bestand. Zo heeft onze webapplicatie maar één bestand nodig, het html-bestand:

De code kun je downloaden van deze pagina en daarna vanuit een programma als Kladblok overnemen.

We creëren hier in de body een element py-script met daarin de Python-code. Merk op dat dit element een attribuut async heeft, omdat we in de Python-code een asynchrone functie met await aanroepen. Zonder het attribuut async zou de code niet werken.

De JavaScript Fetch API biedt een eenvoudige manier aan om http-aanroepen in je webapplicatie te doen.

10 Webpagina ophalen

De code roept de globale JavaScript-functie fetch aan met als argument de url van de API van ipify. Dit is een asynchrone JavaScript-functie, vandaar dat we die aanroepen met await js.fetch(url). Van het resultaat vragen we de tekst op. Omdat dit ook een asynchrone JavaScript-functie is, moeten we dit in onze Python-code ook met await aanroepen.

Als dit succesvol is, bevat de variabele public_ip het antwoord van de webserver van ipify, namelijk je publieke ip-adres. We creëren dan een f-string met de boodschap “Mijn publieke IP-adres:” gevolgd door het betreffende ip-adres. Met de functie display (die je niet mag vergeten te importeren uit de module pyscript) toon je deze string in het html-element waarin deze Python-code wordt uitgevoerd, namelijk het paragraaf-element p. En zo krijg je wanneer je deze webpagina laadt na een korte pauze je ip-adres te zien.

11 Python REPL

Met PyScript kun je zelfs een Python REPL (read-eval-print loop) in je webpagina toevoegen: een terminalvenster waarin je Python-opdrachten uitvoert, volledig client-side in je webbrowser. De html-code hiervoor ziet er als volgt uit:

De code kun je downloaden van deze pagina en daarna vanuit een programma als Kladblok overnemen.

De attributen terminal en worker voor het element script zijn hier belangrijk. Het eerste attribuut toont een terminal waarin de uitvoer van de Python-functie print komt, en het tweede attribuut maakt de terminal interactief (bijvoorbeeld om de gebruiker invoer te vragen met de Python-functie input).

Als je deze webapplicatie zo zou uitvoeren, zou je in de JavaScript-console een foutmelding krijgen: “Error: Unable to use SharedArrayBuffer due insecure environment.” Om je webpagina in een veilige context te plaatsen, moet je de HTTP-headers Cross-Origin-Opener-Policy, Cross-Origin-Embedder-Policy en Cross-Origin-Resource-Policy instellen.

De eenvoudige ingebouwde webserver van Python die we in dit artikel gebruiken, doet dat niet. Maar als je het bestand mini-coi.js via deze GitHub-pagina downloadt en in dezelfde directory als je html-bestand opslaat, en in het element head van je html-pagina vóór alle scripts, links en styles hiernaar verwijst met <script src="./mini-coi.js" scope="./"></script>, werkt dit wel. Laad de pagina, wacht even tot de Python-omgeving is opgestart, en je kunt aan de slag in je interactieve Python-terminal.

Een volledige Python-terminal in je webapplicatie? Dat is maar enkele regels PyScript-code.

Fouten in je code oplossen Als je Python-code een syntaxisfout bevat, zal PyScript die in een rood tekstveld tonen zodra je webapplicatie de Python-code laadt. Helaas betekenen de regelnummers die je te zien krijgt niets, maar je krijgt wel de inhoud van de regel code te zien waar het misgaat. Voor niet al te grote programma’s zul je de bron van de fout wel snel vinden. Het gebruik van een code-editor voor je Python-code zal je ook al wel helpen om fouten te vinden. Het is dan ook een nadeel als je Python-code rechtstreeks in je html-bestand opneemt in een element py-script: je kunt dan niet profiteren van syntax highlighting of andere handigheidjes van een Python-ontwikkelomgeving.

Nog een tip: met de Python-functie print kun je informatie in de JavaScript-console van je webbrowser tonen, wat handig is tijdens het testen van je code.

Watch on YouTube
▼ Volgende artikel
Help, de Mail-app op mijn iPhone haalt geen mails meer binnen! En nu?
© Michael J Berlin - stock.adobe.com
Huis

Help, de Mail-app op mijn iPhone haalt geen mails meer binnen! En nu?

Je opent de Mail-app op je iPhone, maar er komen geen nieuwe berichten binnen. Heel vervelend, zeker als je belangrijke mails verwacht. In dit artikel laten we zien wat je kunt doen om dat op te lossen.

Dit kun je doen: Handmatig verversen | iPhone herstarten | Vliegtuigmodus checken | Mail-app opnieuw installeren | Verversen op de achtergrond inschakelen | Meldingen controleren | Netwerkinstellingen resetten | Mobiele data voor Mail inschakelen | Databesparingsmodus uitschakelen
Hóe je dit allemaal precies doet, lees je in het artikel.

Handmatig verversen

Voordat we wat meer gevorderde instellingen en mogelijkheden gaan nalopen, bekijken we eerst een aantal simpele oplossingen die het euvel kunnen verhelpen. Zo kun je de Mail-app openen en kijken of een handmatige refresh helpt. Dat werkt heel simpel: na het openen houd je je duim of vinger op het scherm en trek je het naar beneden totdat je een cirkeltje ziet staan. Zodra het cirkeltje begint te draaien, kun je loslaten. De app maakt dan verbinding met de servers om nieuwe berichten op te halen. Onder in beeld staat ook altijd wanneer de update voor het laatst plaatsvond; daarmee kun je zien of het verversen gelukt is.

iPhone herstarten

Daarnaast kun je de iPhone opnieuw opstarten. Dat verhelpt in de meeste gevallen de problemen. Ontgrendel hiervoor je iPhone en trek het snelmenu vanaf rechtsboven naar beneden (of, als je nog een iPhone met TouchID hebt, van beneden naar boven). Tik nu op het aan/uit-symbool, eveneens rechts bovenin. Zet de schakelaar om naar Uit en zet het toestel daarna aan.

Vliegtuigmodus checken

Helpt dat niet, dan staat de vliegtuigmodus misschien aan. Als dat het geval is, dan worden alle verbindingen met internet- en mobiele netwerken geblokkeerd. Haal opnieuw het snelmenu tevoorschijn en check of het vliegtuigicoontje een kleurtje heeft. Is dat het geval, dan moet je erop tikken om hem uit te schakelen.

Mail-app opnieuw installeren

Verder kun je proberen om de app te verwijderen en opnieuw te installeren. Houd daarvoor je duim of vinger op het appicoon van Mail, zodat het contextuele menu tevoorschijn komt. Selecteer nu Verwijder app (in het rood). Open daarna de App Store om de applicatie te downloaden. Log in met je account en check of de problemen zich nog voordoen.

Verversen op de achtergrond instellen

Helpt dit ook niet, dan wordt het tijd om iets verder de diepte in te gaan. Ga bijvoorbeeld eens naar Instellingen > Algemeen > Ververs op de achtergrond. Selecteer die optie en kies in de (korte) lijst voor Wifi en mobiele data.

Meldingen controleren

Nog steeds geen mail? Dan is de volgende stap het controleren van enkele instellingen. Misschien komen mails wel binnen, maar mis je een notificatie. Check bij Instellingen > Meldingen of Mail wel notificaties mag versturen. Zet naast Sta meldingen toe de regelaar naar rechts.

Netwerkinstellingen resetten

Het kan ook helpen om je netwerkinstellingen te resetten. Ga hiervoor naar Instellingen > Zet over of stel iPhone opnieuw in > Stel opnieuw in > Herstel netwerkinstellingen. Houd er rekening mee dat je daarna handmatig verbinding moet maken met je wifi-netwerk.

Mobiele data voor Mail inschakelen

Als we nog even bij de netwerkinstellingen blijven, kunnen we ook meteen de instellingen voor mobiele data controleren. Het is mogelijk dat je eerder hebt ingesteld dat de Mail-app geen data mag verbruiken via je mobiele netwerk. Ben je onderweg en krijg je geen mails binnen, dan zou dat de oorzaak kunnen zijn. Om dit te controleren ga je naar Instellingen > Mobiel netwerk. Zoek vervolgens de Mail-app op in de lijst met apps die toegang hebben tot je mobiele dataverbinding. Zorg ervoor dat de schuifregelaar naar rechts staat. Alleen dan kan de Mail-app gebruikmaken van je mobiele data wanneer je niet met wifi bent verbonden. Als de schuif naar links staat, werkt de app alleen als er wifi beschikbaar is.

Databesparingsmodus uitschakelen

Tot slot kan de databesparingsmodus roet in het eten gooien. Deze modus kun je geactiveerd hebben voor zowel wifi als het mobiele netwerk. Ga naar Instellingen > Wifi en tik op het informatie-icoon om de Databesparingsmodus te zien staan. Zorg ervoor dat dit uitgeschakeld is (met de regelaar naar links). Dit kun je ook doen voor je mobiele netwerk, via Instellingen > Mobiel netwerk > Opties mobiele data -> Datamodus. Staat daar de Databesparingsmodus aan, dan worden onder automatische updates en achtergrondtaken gepauzeerd – en worden er dus op de achtergrond geen nieuwe mails binnengehaald.

Nog steeds geen e-mail?

Dan zit er maar één ding op ...

▼ Volgende artikel
Samsung tv-nieuws: antireflectie op meer modellen en intrede The Frame Pro
Huis

Samsung tv-nieuws: antireflectie op meer modellen en intrede The Frame Pro

De periode vóór de lente is traditiegetrouw het moment dat veel tv-fabrikanten hun nieuwste modellen lanceren. Welke vernieuwingen kunnen we in 2025 van Samsung verwachten? Een draadloze One Connect Box, meer modellen met anti-reflectie eigenschappen en een verbeterde The Frame staan op stapel.

Samsung introduceerde vorig jaar de Glare Free antireflectielaag op de S95D. En in 2025 zal niet alleen de S95F ermee uitgerust zijn, maar krijgen ook de 8K QN990F en QN900F en de 4K QN90F die antireflectielaag. Glare Free is een mat scherm dat reflecties erg goed tegenhoudt. Vooral scherp afgetekende reflecties zou dan geen hindernis meer moeten zijn. Daar tegenover staat wel dat je wat contrast verliest, maar dat is onvermijdelijk.

Glare Free zorgt voor verdeelde meningen en niet iedereen houdt van deze aanpak. Wij zijn wel overtuigd dat je in een doorsnee woonkamer waar toch vaak lichtinval is, veel voordeel kunt halen uit Glare Free; zeker wanneer de opstelling niet optimaal is.

De One Connect Box, nu draadloos

Met de One Connect Box heeft Samsung al enkele jaren een handige oplossing in huis om kabels uit het zicht te houden. Alle kabels worden aangesloten op een aparte box en en via één kabel breng je niet alleen stroom, maar ook beeld, geluid en data naar de tv. In 2025 brengt Samsung ook een draadloze versie op de markt. Je kunt die tot 10 meter van de televisie plaatsen. Stroom voor de televisie is dan vanzelfsprekend niet draadloos, maar moet je de televisie zelf op het stopcontact aansluiten. Als je alleen via wifi wil streamen dan is de Wireless One Connect Box niet eens nodig.

De Box is alleen beschikbaar op de 8K QN990F en op de Frame Pro, en is dus niet als losse kast voor andere Samsung-tv’s te koop. De bedrade One Connect Box blijft beschikbaar op The Frame en de S95F.

The Frame Pro

The Frame, een tv die eruitziet als een kunst- of schilderijkader, met ingebouwde Art Store, mat scherm en verwisselbare kaders is volgens Samsung erg succesvol. Dit jaar komt er een nieuwe versie die gebruik maakt van een Neo QLED-achtergrondverlichting; dat is een miniled-achtergrondverlichting die gedimd kan worden in verschillende zones.

Daarmee krijgt de beeldkwaliteit een flinke boost, op vlak van contrast, helderheid en kleurbereik. Ook dit model zal voorzien zijn van een mat scherm.  De Art Store is verder uitgebreid en vind je er inmiddels meer dan 3000 kunstwerken. The Frame Pro is beschikbaar in 65, 75 en 85 inch. De ‘oude’ The Frame blijft beschikbaar in 32-, 43-, 50- en 55 inch-formaten.

Andere line-up

In de (Neo) qled-line-up van Samsung zien we twee wijzigingen. De 2025-QN7XF krijgt voor het eerst een Neo qled-achtergrondverlichting en dat is een aanzienlijke upgrade tegenover de 2024 Q70D. De Q60D van dat jaar is niet echt verdwenen, maar kreeg de wat verwarrende naam Q7FX.

In de oled-line-up valt vooral het verdwijnen van een opvolger voor de S85D op. De S95F blijft het topmodel en is beschikbaar in 55, 65, 77 en 83 inch. Het nieuwe qd-oled-paneel moet ongeveer 30% helderder zijn. We moeten daar wel bij opmerken dat de 83inch-versie geen qd-oled-paneel gebruikt maar een w-oled- paneel. De S9XF is 25% helderder dan in 2024 en beschikbaar in 48, 55, 65, 77 en 83 inch, waarbij alleen nog maar het 65inch-model een qd-oled -paneel gebruikt en de andere modellen een w-oled -paneel.

Grote modellen blijven nadrukkelijk aanwezig in de line-up, in verschillende prijscategorieën. Als instapmodel blijft de 98 inch DU9070 beschikbaar. De QN80F, een midrange-model met minileds en local dimming, zal beschikbaar zijn in 100 inch, en het 4K-topmodel QN90F is verkrijgbaar in 98 inch en 115 inch. De 8K QN990F in 98 inch is voor wie echt maximale beeldkwaliteit wenst.

AI, Smart tv updates en gratis content

Ook Samsung biedt nu voor lange tijd smart tv OS-updates. Met zeven jaar is de update-periode bovendien erg lang. We vinden dat een uitstekende ontwikkeling. Het is natuurlijk afwachten of alle features zullen doorstromen naar oudere modellen. In de gevallen waar nieuwe hardware nodig is, is dat niet mogelijk.

Smart tv betekent weinig als er geen content is. Net als vorig jaar heeft Samsung daarom een pakket content voorzien dat bij een aantal tv’s gratis meegeleverd wordt. Het gaat om diensten zoals DAZN, Xbox Game Pass, Rakuten TV en meer. Meer informatie vind je op Made for NL en Made for BE. (Op het moment van schrijven verwezen deze pagina’s nog naar het 2024 aanbod).

Samsung pakt – net als veel fabrikanten - ook graag uit met AI. De oled- en (Neo) qled-modellen zijn dit jaar voorzien van Vision AI. Onder die noemer vallen veel van de features die Samsung al langer aanbiedt. Zoals AI upscalen, AI Game Mode, Q-Symphony enzovoort. De term groepeert alle beeld- en geluidsfuncties die op basis van content en de kijk- en luisteromgeving ingrijpen op de content. Je kunt ook AI-kunst genereren voor je tv, elke dag krijg je tien credits om een beeld te maken op basis van twee sleutelwoorden. Daarnaast kun je nu ook je tv met gebaren besturen als je en Galaxy Watch hebt.

Kantelbare soundbar

Het belangrijkste nieuws bij de soundbars is de introductie van de HW-QS700F en HW-QS750F ‘Convertible Soundbars’. Je kan ze op een tv-meubel zetten, of 90° kantelen en ze aan de muur hangen. Zo hebben ze ook aan de muur een slank profiel. Een sensor detecteert of de soundbar verticaal hangt of horizontaal staat en wisselt de rol van de omhoog en naar voor gerichte luidsprekers zodat je in beide gevallen optimale audiokwaliteit geniet. De HW-QS700F is een 3.1.2-kanaals model en de HW-QS750F is een 5.1.2-kanaals model. Ze ondersteunen allebei Dolby Atmos en DTS:X.