-
Notifications
You must be signed in to change notification settings - Fork 1
Canvas API
dannysir edited this page Nov 22, 2024
·
1 revision
우선 canvas 엘리먼트를 보면 다음과 같이 사용한다.
width는 300 height는 150이 기본 값이고 해당 값과 css 넓이를 따로 지정할 수 있는데 만약 비율이 잘못되거나 canvas 엘리먼트에서 지정한 넓이, 높이 속성이 너무 작은 경우 css로 크게 확장하면 화질이 깨져보일 수 있다.
사용법
<canvas id="tutorial" width="150" height="150"></canvas>
기본적으로 아래와 같이 2D 그래픽을 그리기 위해 다음과 같이 드로잉 컨텍스트에 엑세스한다.
var canvas = document.getElementById("tutorial");
var ctx = canvas.getContext("2d");
이후 일반적으로 사용되는 코드와 함께 보면 다음과 같다.
참고로 좌측상단을 기준으로 0,0이다.
사각형 만들기
// 사각형 그리기 (시작X좌표, 시작Y좌표, 넓이, 높이)
ctx.fillRect(25, 25, 100, 100);
// 특정 범위의 사각형 지우기
ctx.clearRect(45, 45, 60, 60);
// 윤곽선 만들기
ctx.strokeRect(50, 50, 50, 50);
점과 선으로 도형 만들기
ctx.beginPath();
// beginPath로 시작하는 것을 알리고 포인터를 이동하는 느낌이다.
ctx.moveTo(75, 50);
// 현재 포인터는 moveTo로 이동한 위치 (75, 50)
// 여기서 lineTo를 통해 (75, 50) 부터 (100, 75)로 라인을 그린다.
ctx.lineTo(100, 75);
ctx.lineTo(100, 25);
// 위에서 라인을 다 그리고 내부를 채우는 것이다.
// 만약 내부를 채우는 것이 아니라면 ctx.stroke()를 이용하면 선을 그냥 그릴 수 있다.
// 택스트를 채우는건 ctx.fillText(text, x, y)로 가능하다.
ctx.fill();
- [FE] 프론트엔드 기술스택
- [FE] 라이브러리 없이 차트 구현 이유
- [FE] Canvas API 사용방법
- [FE] 네비게이션 바 애니메이션 구현
- [FE] Socket.io 사용방법
- [FE] Tanstack Router에 대하여...
- [FE] Intl(Internationalization) API
- [FE] React Suspense 적용
- [FE] 한글 입력 방식의 유연성을 높인 검색 시스템 구현하기
- [BE] 백엔드 기술 스택
- [BE] SSE vs Socket.io
- [BE] Redis를 도입하게 된 계기
- [BE] ACG Rule을 활용한 Secure CI CD 파이프라인 구현
- [BE] Nginx 로드밸런싱을 통해 한국 투자 API 소켓 제한 극복
- [BE] 주가 지수 기능 개발 과정
- [BE] 매수 및 매도 기능 개발 과정
- [BE] 실시간 자산 조회 기능 개발 과정
- [BE] 단위 테스트
- [BE] redis를 이용한 한국투자 Open API 세션 관리
- [BE] 데이터베이스 인덱싱
- [FE] React에서의 DOM 요소 접근 (useRef vs getElementById)
- [FE] Outlet을 활용한 공통 레이아웃 관리
- [FE] react hooks가 특정 조건에서 실행되면 안되는 이유 & useQuery에 query function 매개변수가 undefined일 수도 있을 때 어떻게 해결할까
- [FE] cross‐domain 로컬 환경에서 cookie로 인증 처리하기 with vite proxy
- [FE] 크롬&사파리 Composition 차이
- [FE] useEffect 의존성 배열
- [BE] Naver Cloud Platform HTTPS 무응답 현상
- [BE] 한국투자 Open API에서 access token을 발급받지 못하는 문제
- [BE] 한국투자 Open API와 웹소켓 연결이 되지 않던 문제
- [BE] 한국투자 Open API 웹소켓 연결이 중단되는 문제
- [BE] 같은 주식 주문이 동시에 여러 번 체결되는 문제
- [BE] 한국투자 Open API Websocket 세션을 두 개에서 한 개로 변경하기
- [BE] Nginx 로드 밸런싱 중 Socket bad Request 발생하는 현상
- [BE] 매수/매도 체결 로직에 의해 redis pub/sub이 정상적으로 동작하지 않는 문제