Mestring af maskerede billedkanter i JavaScript Canvas
Sammensmeltning af flere billeder er et almindeligt trin i skabelsen af visuelle JavaScript-effekter. At definere de synlige områder af et billede med en maske er en hyppig teknik. Selvom dette er nyttigt til at skabe unikke former, kan det være udfordrende at tilføje en kant omkring disse maskerede former. Selvom element i JavaScript tilbyder omfattende billedmanipulation, er det ikke nemt at justere grænsen omkring et billede, der er blevet maskeret.
Udviklere kan anvende masker og klippe billeder på fantasifulde måder med , selvom enhver generet ramme som standard har en tendens til at matche lærredets rektangulære form. Når du ønsker at skabe en kant, der matcher kanterne af en kompliceret form, der er defineret af en maske, giver dette et problem. Målet er at følge maskens præcise rejse ud over den ligefremme rektangulære grænse.
Dette indlæg vil forklare, hvordan man anvender en billedmaske i JavaScript, og mere afgørende, hvordan man sikrer, at den distinkte form af det maskerede billede er omgivet af en kant. Derudover vil vi gennemgå en funktion, der fuldender maskeringen, men som endnu ikke har en defineret grænseløsning.
Du kan finjustere grænsens udseende ved at lære at arbejde med sammensatte operationer i lærred. Lad os komme i gang og se, hvordan du bruger JavaScripts lærredsfunktioner til at tilføje den nødvendige kant omkring et maskeret billede.
Kommando | Eksempel på brug |
---|---|
globalCompositeOperation | Sammensætningen af tegnehandlinger på lærredet er defineret af denne funktion. GlobalCompositeOperation ='source-in' i eksemplet sørger for, at maskebilledet klipper hovedbilledet, så kun de områder, der skærer hinanden, ses. |
toDataURL() | Transformerer informationen på lærredet til et billede kodet med Base64. Dette gør det muligt at bruge det færdige billede som en PNG efter påføring af masken og rammen. Eksemplets billedoutput produceres ved hjælp af canvas.toDataURL('image/png'). |
crossOrigin | Denne funktion respekterer sikkerhedsbegrænsninger ved at muliggøre brugen af billeder indlæst fra et andet domæne i lærredet. MaskImg.crossOrigin = 'anonym' garanterer, at adgang til maskebilledet kan foretages uden at forårsage CORS-problemer. |
beginPath() | På lærredet kan en ny sti startes ved hjælp af denne metode. Den anden metode kalder ctx.beginPath() for at sikre, at stien overholder maskens kontur, når den tegner en brugerdefineret kant rundt om det maskerede billede. |
moveTo() | Med denne procedure laves ingen tegninger; i stedet flyttes "pennen" til et nyt begyndelsessted. Grænsens begyndelsespunkt er placeret i eksemplet ved hjælp af ctx.moveTo(0, 0), hvilket er vigtigt for at tegne grænsen nøjagtigt rundt om maskens grænser. |
lineTo() | Ved at bruge de givne koordinater som udgangspunkt tegner denne teknik en lige linje. Grænsen for det maskerede billede er defineret af linjerne tegnet i løsningen ved hjælp af ctx.lineTo(maskImg.width, 0). |
stroke() | Langs den udpegede sti, tegner grænser eller linjer. For eksempel bruges moveTo() og lineTo() til at definere maskeformen, og derefter bruges ctx.stroke() til at anvende rammen omkring det maskerede billede. |
lineWidth | Bestemmer, hvor tykke linjerne er malet på lærredet. Scriptet etablerer en 5-pixel tyk kant rundt om maskens form ved hjælp af ctx.lineWidth = 5. |
strokeStyle | Angiver kantens farve eller stil. Kantfarven i eksemplet er sat til rød ved at bruge ctx.strokeStyle ='red'. |
Genkendelse af, hvordan man anvender en kant på et maskeret billede
Formålet med de scripts, der leveres, er at bruge et andet billede som en maske for et billede og derefter bruge for at tilføje en brugerdefineret kant rundt om den maskerede form. To nye billedobjekter oprettes i starten af funktionen for masken og hovedbilledet. Når du indlæser fotos fra eksterne kilder, er indstillingen for krydsoprindelse afgørende for at forhindre problemer på grund af CORS. Der dannes et lærred, og dets proportioner justeres, så det passer til maskebilledet, når begge billeder er blevet indlæst. Dette undgår problemer med størrelsesændring under billedtegning og garanterer, at lærredet er forberedt til arbejde med det passende område.
Scriptet bruger derefter funktion til at tegne maskebilledet på lærredet. Derved påføres masken på lærredet, der fungerer som fundamentet for maskeringsproceduren. Den globale sammensatte handling skal indstilles til "kilde-ind" for at anvende masken korrekt. Lærredet instrueres i kun at beholde de områder af det primære billede, der falder sammen med maskebilledet. I det væsentlige definerer masken den form, som hovedbilledet klippes til. Den sammensatte handling nulstilles til "kilde-over", når hovedbilledet tegnes inde i dette klippeområde, hvilket muliggør yderligere handlinger som kantmaling uden at påvirke det tidligere klippede indhold.
Anvendelse af en kant på den maskerede form involverer brug af teknik. Den angivne sti eller formular på lærredet er angivet med denne kommando. I den anden løsning kombineres moveTo() og lineTo() for manuelt at generere lærredsstien og spore maskens grænser. Ved at bruge disse teknikker kan du manuelt specificere kantens form og sikre dig, at den klæber til maskens form i stedet for den rektangulære lærredsgrænse. Du har fuldstændig kontrol over grænsens udseende, fordi egenskab sætter grænsens tykkelse og egenskaben sætter sin farve.
Til sidst bruges toDataURL()-funktionen til at transformere lærredet til en Base64-streng. Ved at gøre dette omdannes det færdige billede - maske og kant inkluderet - til et format, der let kan bruges i andre områder af programmet eller uploades til en server. For at undgå timingfejl sikrer løftet, at denne operation først slutter, når begge billeder er fuldt indlæst. Disse scripts viser, hvordan sofistikerede billedmodifikationsteknikker, herunder maskering og anvendelse af en dynamisk kant, der matcher maskens konturer, kan opnås med JavaScripts lærredselement.
Metode 1: Brug af metoden lærred og streg til at tilføje en brugerdefineret kant til et maskeret billede
For at bygge en grænse omkring det maskerede billede bruger denne tilgang JavaScript og Canvas API. Stroke() bruges til at skitsere den maskerede form.
function applyFiltersAndConvertToBase64(imageUrl, materialImage) {
return new Promise((resolve, reject) => {
const maskImg = new Image();
const mainImg = new Image();
maskImg.crossOrigin = "anonymous";
mainImg.crossOrigin = "anonymous";
let imagesLoaded = 0;
const onLoad = () => {
imagesLoaded++;
if (imagesLoaded === 2) {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
canvas.width = maskImg.width;
canvas.height = maskImg.height;
ctx.drawImage(maskImg, 0, 0);
ctx.globalCompositeOperation = 'source-in';
ctx.drawImage(mainImg, 0, 0, maskImg.width, maskImg.height);
ctx.globalCompositeOperation = 'source-over';
ctx.lineWidth = 5; // Border thickness
ctx.strokeStyle = 'red'; // Border color
ctx.stroke(); // Draw border around mask
const base64Image = canvas.toDataURL('image/png');
resolve(base64Image);
}
};
maskImg.onload = onLoad;
mainImg.onload = onLoad;
maskImg.onerror = reject;
mainImg.onerror = reject;
maskImg.src = imageUrl;
mainImg.src = materialImage;
});
}
Mulighed 2: Opret en brugerdefineret kant rundt om maskeformen ved hjælp af lærredssti
Denne metode sikrer, at grænsen nøje følger den maskerede form ved at følge billedmaskestien ved hjælp af Canvas API med JavaScript.
function applyFiltersAndConvertToBase64(imageUrl, materialImage) {
return new Promise((resolve, reject) => {
const maskImg = new Image();
const mainImg = new Image();
maskImg.crossOrigin = "anonymous";
mainImg.crossOrigin = "anonymous";
let imagesLoaded = 0;
const onLoad = () => {
imagesLoaded++;
if (imagesLoaded === 2) {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
canvas.width = maskImg.width;
canvas.height = maskImg.height;
ctx.drawImage(maskImg, 0, 0);
ctx.globalCompositeOperation = 'source-in';
ctx.drawImage(mainImg, 0, 0, maskImg.width, maskImg.height);
ctx.globalCompositeOperation = 'source-over';
// Create path for the mask shape
ctx.beginPath();
ctx.moveTo(0, 0);
ctx.lineTo(maskImg.width, 0);
ctx.lineTo(maskImg.width, maskImg.height);
ctx.lineTo(0, maskImg.height);
ctx.closePath();
ctx.lineWidth = 5; // Border thickness
ctx.strokeStyle = 'blue'; // Border color
ctx.stroke(); // Apply the border along the path
const base64Image = canvas.toDataURL('image/png');
resolve(base64Image);
}
};
maskImg.onload = onLoad;
mainImg.onload = onLoad;
maskImg.onerror = reject;
mainImg.onerror = reject;
maskImg.src = imageUrl;
mainImg.src = materialImage;
});
}
Forbedring af maskerede billeder med brugerdefinerede rammer i JavaScript
Brugeroplevelsen af din JavaScript-applikation kan forbedres betydeligt af evnen til at maskere billeder og indstille brugerdefinerede rammer, når du håndterer . Ved hjælp af maskering kan du bestemme, hvilke områder af et billede, der er synlige, afhængigt af et andet billede, kendt som masken. Tilføjelse af en kant omkring den maskerede zone er et problem, som mange udviklere støder på, især når masken ikke har en ligetil rektangulær form. Projekter med kanter, der præcist matcher maskens omrids, vil fremstå mere polerede og eksperter.
En nyttig løsning på dette problem er at bruge Canvas API objekt. Du kan bruge Path2D til at designe indviklede ruter, der passer til din maskes konturer og derefter omgive dem med en kant. Denne metode giver dig mulighed for at generere grænser, der præcist matcher hjørnerne af din brugerdefinerede maske, der går ud over konventionelle rektangler. Bruger og sammen gør det lettere at spore maskens omrids og garanterer en kant, der er præcist justeret.
Ydeevne er en anden vigtig faktor at tage højde for, især når du arbejder med større billeder eller anvender grænser dynamisk i realtid. Din applikations hastighed kan forbedres ved at anvende strategier som caching af det maskerede billede, skære ned på tegneoperationer og strømline lærredsgengivelsesprocessen. Selv i indviklede eller højtydende indstillinger kan du garantere, at maskerings- og grænsetegningsprocedurerne går glat ved at reducere meningsløse handlinger.
- Hvordan kan jeg bruge et andet billede til at maskere et i JavaScript?
- Bruger indstillet til , tegn masken på lærredet for at maskere et billede ved hjælp af . For at matche masken vil dette beskære det primære billede.
- Hvordan kan jeg oprette en kant til et maskeret billede, der passer til dets form?
- Efter at have etableret maskens rute med og , brug teknik. Dette giver dig mulighed for at omkranse maskens form med en personlig kant.
- Hvad er formålet med i lærredsmanipulation?
- Indholdet af lærredet omdannes til et Base64-kodet billede via funktion, hvilket gør det nemt at bruge eller distribuere som et PNG-billede.
- Hvordan kan jeg optimere lærredsoperationer til ydeevne?
- Reducer mængden af tegneoperationer, og tænk på at gemme almindeligt anvendte elementer for at maksimere lærredets hastighed. Dette holder din applikation i gang, og reducerer antallet af gentegninger.
- Kan jeg indlæse billeder med krydsoprindelse i et lærred?
- Ja, men for at gøre billedet tilgængeligt uden at forårsage CORS-problemer, skal du indstille ejendom til .
I JavaScript-apps er maskering af billeder og anvendelse af brugerdefinerede rammer i lærredet en effektiv måde at skabe polerede visuelle elementer på. Udviklere har evnen til at manipulere gengivelsen og stylingen af billeder ved at bruge og sofistikerede tegnekommandoer som f.eks og stidefinitioner.
Jævn ydeevne sikres ved omhyggeligt at optimere kant- og maskeringsoperationerne, især for større fotos. Denne vejledning giver en nyttig metode til dynamisk at male grænser omkring ikke-rektangulære billeder, hvilket er nyttigt, når du udvikler online-apps, der både er æstetisk tiltalende og responsive.
- Detaljeret vejledning om brug at manipulere billeder og masker, herunder tegneoperationer som og : MDN Web Docs .
- Omfattende forklaring af, hvordan man anvender billedmaskering og håndtering af krydsoprindelsesressourcer i JavaScript: HTML5 Canvas Tutorials .
- Ydeevnetips til lærredsbaserede applikationer med fokus på optimering af billedgengivelse og tegning: Smashing Magazine .