-
Notifications
You must be signed in to change notification settings - Fork 0
/
3_canvas_preload.js
47 lines (45 loc) · 1.53 KB
/
3_canvas_preload.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
window.addEventListener("DOMContentLoaded", preload);
/**
* 初期化前に必要な素材を読み込みます。
*/
function preload() {
// JSライブラリ「WebFont」を使って、フォントの読み込み完了を検知
WebFont.load({
custom: {
// フォントファミリーを指定
families: ["FontAwesome"],
// CSS の URL を指定
urls: [
"https://netdna.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.css"
],
// 他のフォントでは不要だが、FontAwesome のフォントを利用するには必要な指定
testStrings: {
// FontAwesome の検証用テキストを指定
FontAwesome: "\uf001" // グラスアイコンを指定 (任意で支障ない)
}
},
// Web Fontが使用可能になったとき
active: init
});
}
/**
* コンテンツを初期化します。
*/
function init() {
// アイコンの Unicode を指定
const iconUnicode = "f26b";
// Unicode から文字コードに変換
const iconInt = parseInt(iconUnicode, 16);
console.log(iconInt); // 「62059」が出力される
// 文字コードから文字列に変換する
const iconStr = String.fromCharCode(iconInt);
console.log(iconStr); // 該当のアイコン文字
// コンテキストを取得
const canvas = document.querySelector("#myCanvas");
const context = canvas.getContext("2d");
// 文字を描く
context.font = "540px FontAwesome";
context.fill = "black";
context.textBaseline = "top";
context.fillText(iconStr, 0, 0);
}