Luo Google Chrome -laajennuksia Netflix-tekstitystylerillä
Lukasz Kolko
Tänään luomme Google Chrome -laajennuksia Netflixin tekstitystyylien reaaliaikaista manipulointia varten. Löydät tietoa laajennusten luomisesta tyhjästä, joitakin käytännön neuvoja ja yleisiä näkemyksiä laajennusten arkkitehtuurista. Jos et ole tyytyväinen saatavilla oleviin Netflix-tekstitysvaihtoehtoihin tai haluat vain luoda nopeasti jonkin laajennuksen helpottamaan elämääsi, tämä artikkeli on sinua varten.
Netflix lähettää API:nsa avulla jokaisen tekstityslauseen erikseen. Se käyttää CSS-tyylejä tekstitysten muotoiluun. Kun meillä on pääsy sivun DOM:iin, voimme muokata näitä vastaanotettuja tyylejä Chrome-laajennuksen avulla.
Ilmiö
Ensin meidän on luotava manifestitiedosto nimeltä manifest.json. Se kertoo selaimelle laajennuksen asetuksista, kuten käyttöliittymätiedostoista, taustaskripteistä ja mahdollisista laajennuksen ominaisuuksista.
Kuten näet, meillä on joitain vakiotietoja, kuten nimi, versio, kuvaus, kotisivu.url ja manifestiversio.
Yksi manifestin tärkeistä osista on käyttöoikeusosio. Tämä on joukko elementtejä, joita laajennuksemme voi käyttää.
Meidän tapauksessamme tarvitsemme pääsyn välilehtiin aktiivisen välilehden löytämiseksi, skriptien suorittamiseksi ja viestien lähettämiseksi käyttöliittymän ja laajennuksen välillä. Tarvitsemme tallennustilaa laajennuksen asetusten tallentamiseen selaimeen ja declarativeContentia välilehden sisällöstä riippuvien toimintojen suorittamiseen. Viimeinen elementti https://*.netflix.com/ sallii laajennuksen pääsyn vain netflix.com-verkkotunnukseen.
Chrome-laajennuksilla on käyttöliittymästä erillinen logiikka, joten tarvitaan background.scripts, joka kertoo laajennukselle, mistä se löytää logiikkansa. persistent: false tarkoittaa, että tätä skriptiä käytetään vain tarvittaessa. page_action on osio, jossa on käyttöliittymäosa. Meillä on tässä yksinkertainen HTML-tiedosto ponnahdusvalikkoa ja laajennuksen PNG-logoa varten.
Laajennuslogiikka
Ensin on määritettävä runtime.onInstalled -käyttäytymistavat, poistettava kaikki nykyiset säännöt (esimerkiksi vanhemmista versioista) ja määritettävä toiminto uusien sääntöjen lisäämiseksi. Käytämme tallennusasetusten tallentamiseen Local Storagea, jotta voimme varata oletusasetukset laajennuksen asennuksen jälkeen.
Sääntömme tavoitteena on poistaa laajennuspainike käytöstä kaikilla muilla verkkotunnuksilla kuin seuraavilla. netflix.com. Luomme uuden säännön PageStateMatcher edellytykset ja julistaa ShowPageAction jossa uusi sääntö määritetään.
Ensin tarkistetaan, että changeInfo.status on tilassa complete. Tämä tarkoittaa, että tämän välilehden verkkosivusto on ladattu. Sitten haemme asetukset paikallisesta tallennustilasta ja ilmoitamme, mikä komentosarja on suoritettava nykyisellä välilehdellä tabId:llä. Lopuksi lähetämme callbackissa viestin asetuksineen käyttöliittymästä skriptille.
Laajennus UI
Luodaksemme ponnahdusvalikon laajennuksen ja lomakkeen, luomme kolme tiedostoa: popup.html ja popup.css visuaalisilla kerroksilla ja popup.js jossa on logiikka valikon ja eristetyn valikon välistä viestintää varten. background.js käsikirjoitus.
UI:n tavoite:
Tässä meillä on yksinkertainen HTML-lomake, jossa on sisäänrakennettu validointi: popup.html:
Yllä olevassa skriptissä lataamme asetukset paikallisesta tallennustilasta ja liitämme ne lomakkeen syötteisiin. Sitten luomme kuuntelijan lähetä tapahtuma, jossa on toimintoja asetusten tallentamiseksi paikalliseen tallennustilaan ja niiden lähettämiseksi viestillä skriptillemme. Kuten näet, käytämme Local Storagea jokaisessa komponentissa. Chrome-laajennuksella ei ole omaa datatilaa, joten yksinkertaisin ratkaisu on käyttää selaimen paikallista tilaa, kuten Local Storagea. Käytämme usein myös sendMessage toiminto. Se johtuu Chromme-laajennusten arkkitehtuurista - niissä on käyttöliittymästä erillinen logiikka.
Käsikirjoitus
Nyt on aika luoda script.js jossa on logiikka Netflix-tekstityylien manipuloimiseksi.
Ensin luodaan onMessage kuuntelija, joka vastaanottaa laajennuksen asetuksia sisältäviä viestejä.
Netflixin kohdalla se vaihtaa joka kerta, kun se vastaanottaa kokonaisia tekstityslauseita, vain tekstitysosan sivun DOM-osasta. Meidän on siis käytettävä tarkkailufunktiota kuten MutationObserver, joka laukaisee meidän changeSubtitlesStyle funktio joka kerta, kun sivun DOM on muuttunut. Vuonna callback funktiossa näemme yksinkertaisen tyylien manipuloinnin. Kommentoiduilla riveillä on tietoa siitä, mistä löydät oikeat tyylit.
Aika juosta
Oletan, että sinulla ei ole kehittäjätiliä Chrome Webstoressa. Joten tämän laajennuksen suorittamiseksi siirry osoitteeseen chrome://extensions/ Chromessa, napsauta Kuormitus pakkaamattomana, valitse kansio, jossa on tiedostopääte, ja se on siinä! Sitten ilmeisesti mene Netflix-sivulle testaamaan sitä.
Päätelmät
Kuten huomaat, on helppo alkaa luoda laajennuksia, jotka helpottavat elämää. Tärkeintä on ymmärtää Google Chromen laajennusten jaettu arkkitehtuuri ja komponenttien välinen viestintä. Tämä tekstitysten tyylittelijä on vain yksinkertainen demo siitä, mitä voit tehdä Chrome Extension API:n avulla.
Kuten huomaat, on helppo alkaa luoda laajennuksia, jotka helpottavat elämää. Tärkeintä on ymmärtää Google Chromen laajennusten jaettu arkkitehtuuri ja komponenttien välinen viestintä. Tämä tekstitysten tyylittelijä on vain yksinkertainen demo siitä, mitä voit tehdä Chrome Extension API:n avulla.
Kuvittele parantaa sinun katselukokemus Netflixin kaltaisilla alustoilla laajennusten avulla. Esimerkiksi suosittu Netflix-juhlat avulla käyttäjät voivat katsoa sisältöä yhdessä synkronoidusti. Osoitteessa laajennuksen kuvake työkalurivilläsi voi tarjota nopean pääsyn ohjausominaisuuksiin, kun Netflixin suoratoisto. Ajatus sellaisten työkalujen takana kuin Netflix laajennettu on lisätä lisää toiminnallisuutta suoraan Netflix-sovellus kautta Netflix-laajennus integroitu Chromeen. Kun selaat Netflixin verkkosivusto, tällaiset laajennukset voivat auttaa käyttäjiä navigoimaan osoitteessa Netflix-kategoriat tehokkaammin tai jopa löytää piilotettuja Netflixin sisältö joihin he eivät ehkä muuten törmäisi.
Kuvittele lisäksi, että voit lisätä mukautettu profiilikuva Netflix-profiiliisi tai tekstityksen ja toistonopeuden parempi hallinta. Kaikki tämä on käytettävissä suoraan Chrome web selaimella, jolloin yleinen Netflix-kokemus räätälöidympää kunkin käyttäjän mieltymysten mukaan. Laajennukset eivät ainoastaan paranna Netflixin kaltaisten verkkosivujen toimintoja, vaan ne myös parantavat yleistä käyttäjävuorovaikutusta ja tekevät siitä entistä vaikuttavamman ja käyttäjäystävällisemmän.