티스토리 뷰
canvas를 이용하여 base64 이미지 만들기
pilot376 2019. 6. 13. 09:561) canvas 태그에 이미지 그리기
drawImage() 메소드를 사용하여 이미지를 그린다.
<img id="source" src="/path/file.png">
<canvas id="canvas"></canvas>
const canvas = document.getElementById('canvas');
const ctx = canvas.getContext('2d');
const image = document.getElementById('source');
ctx.drawImage(image, 0, 0);
2) base64 문자열로 변환
canvas에 그린 이미지를 toDataURL() 메서드를 활용하여 base64 문자열로 받을 수 있다.
console.log(canvas.toDataURL());
console.log 결과

문법
canvas.toDataURL(type, encoderOptions);
type (Optional)
- 이미지 포맷 스트링 입력
- "image/png"가 디폴트
encoderOptions (Optional)
- 이미지 퀄리티 지정
- 0과 1사이 값 입력 (예 : 0.3)
※ toDataURL() 메서드는 웹 소스와 같은 서버에 위치한 이미지만 적용됨
예제
- 데모 : https://pilot376.github.io/canvas-base64/
- 전체 코드 : https://github.com/pilot376/pilot376.github.io/blob/master/canvas-base64/index.html
참고
- https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/drawImage
- https://developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/toDataURL
관련 포스트
- Base64 이미지 사용하기 : https://pilot376.tistory.com/3
- Android
- jekyll
- JavaScript
- TDD
- Git
- html
- 파이어폭스
- JSON.stringify
- 앱링크
- javascipt
- JSONPlaceholder
- dev tools
- BASE64
- AWS
- chrome
- axios-mock-adapter
- 풋볼매니저 터치 2018
- 렌더링 이슈
- css
- 유닛테스트
- vue.js
- ubuntu
- nginx
- Total
- Today
- Yesterday