자바스크립트 기반으로 HTML Canvas에 이미지를 그리고 매끄러운 아웃라인을 그리는 예시 코드입니다. 이 코드는 캔버스의 `ctx` 컨텍스트를 사용하며, 이미지 파일 경로를 `imagePath` 변수에 설정해주어야 합니다.
[code]
// 캔버스 요소 가져오기
const canvas = document.getElementById('myCanvas');
const ctx = canvas.getContext('2d');
// 이미지 로드 및 그리기
const image = new Image();
image.onload = function() {
// 캔버스에 이미지 그리기
ctx.drawImage(image, 0, 0);
// 이미지 데이터 가져오기
const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
const data = imageData.data;
// 픽셀 단위로 반복하면서 아웃라인 그리기
for (let i = 0; i < data.length; i += 4) {
const alpha = data[i + 3];
if (alpha !== 0) {
const x = (i / 4) % canvas.width;
const y = Math.floor(i / (4 * canvas.width));
// 일정 거리 내에 매끄러운 아웃라인 그리기
const outlineColor = [255, 0, 255]; // Magenta 색상
const outlineRadius = 5; // 아웃라인 반지름
for (let j = -outlineRadius; j <= outlineRadius; j++) {
for (let k = -outlineRadius; k <= outlineRadius; k++) {
const offsetX = x + j;
const offsetY = y + k;
if (offsetX >= 0 && offsetX < canvas.width && offsetY >= 0 && offsetY < canvas.height) {
const offsetIndex = (offsetY * canvas.width + offsetX) * 4;
const distance = Math.sqrt(j * j + k * k);
const opacity = 1 - distance / outlineRadius;
// 매끄러운 아웃라인 그리기
data[offsetIndex] = outlineColor[0];
data[offsetIndex + 1] = outlineColor[1];
data[offsetIndex + 2] = outlineColor[2];
data[offsetIndex + 3] = Math.round(opacity * alpha);
}
}
}
}
}
// 변경된 이미지 데이터로 캔버스에 다시 그리기
ctx.putImageData(imageData, 0, 0);
};
// 이미지 파일 경로 설정
const imagePath = 'image.png';
// 이미지 로드 시작
image.src = imagePath;
[/code]
위의 코드는 캔버스 요소(`<canvas>`)를 가져와서 `ctx` 컨텍스트를 사용하여 이미지를 그립니다. 이후 `getImageData()` 메소드를 사용하여 이미지 데이터를 가져오고, 픽셀 단위로 반복하면서 알파 값을 확인하여 불투명한 영역에 아웃라인을 그리게 됩니다. 매끄러운 아웃라인을 그리기 위해 지정한 일정 거리 내의 픽셀들에 Magenta 색상을 부여하고, 아웃라인의 투명도를 조절하여 매끄럽게 그려줍니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 17523 | |
| 17516 | |
| 17515 | |
| 17514 |
PHP
PHP 배열순설정
1
|
| 17498 |
PHP
PHP로 PDF파일 다루기
4
|
| 17493 | |
| 17490 | |
| 17487 | |
| 17485 |
JavaScript
jQuery없이 네티브자바스크립트로 서버에 요청보내기 7 - JSONP
5
|
| 17481 |
JavaScript
jQuery없이 네티브자바스크립트로 서버에 요청보내기 6- CORS
1
|
| 17478 |
JavaScript
jQuery없이 네티브자바스크립트로 서버에 요청보내기5- 파일업로드
1
|
| 17477 | |
| 17474 | |
| 17473 |
JavaScript
jQuery없이 네티브자바스크립트로 서버에 요청보내기4 - JSON
|
| 17472 | |
| 17470 |
JavaScript
jQuery없이 네티브자바스크립트로 서버에 요청보내기2 - POST
|
| 17469 |
JavaScript
jQuery없이 네티브자바스크립트로 서버에 요청보내기1 - GET
2
|
| 17463 |
JavaScript
express로 간단한 부트스트랩 내비게이션 메뉴 생성기(아주 쉬움)
|
| 17462 | |
| 17461 |
PHP
PHP로 채트서버 만들기
|
| 17460 |
JavaScript
ThreeJS로 3디 지구 만들기
|
| 17458 | |
| 17457 |
PHP
PHP 랜덤생성하기
|
| 17454 | |
| 17453 |
MySQL
DB백업코드
5
|
| 17448 |
JavaScript
숫자에 천단위로 콤마(,) 찍기
11
|
| 17447 | |
| 17446 | |
| 17445 | |
| 17444 |
node.js
nodejs 에서 CSV파일 파싱하여 배열로 변환하기
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기