学习通自动重做客观题

超星学习通章节测验自动记录客观题正确答案并在重做时自动做题选择正确答案

目前為 2024-06-26 提交的版本,檢視 最新版本

// ==UserScript==
// @name         学习通自动重做客观题
// @version      0.3.1
// @description  超星学习通章节测验自动记录客观题正确答案并在重做时自动做题选择正确答案
// @author       南省 inspired by Matty
// @run-at       document-end
// @match        https://mooc1.chaoxing.com/work/*
// @match        https://mooc1.chaoxing.com/mooc-ans/work/*
// @grant        GM_getResourceText
// @require      https://cdn.bootcdn.net/ajax/libs/blueimp-md5/2.18.0/js/md5.min.js
// @require      https://cdnjs.cloudflare.com/ajax/libs/blueimp-md5/2.19.0/js/md5.min.js
// @resource     ttf https://www.forestpolice.org/ttf/2.0/table.json
// @namespace https://gf.qytechs.cn/users/1320691
// ==/UserScript==

(() => {
    decode();
    if (document.getElementsByClassName("ZyTop")[0].innerText.indexOf("已完成") != -1) {
        view();
    } else {
        doWork();
    }
})();

function doWork() {
    console.log(getWorkId());
    let allQ1 = document.getElementsByClassName("TiMu singleQuesId");
    let qLength1 = allQ1.length;

    if (!haveAnswers()) {
        for (let i = 0; i < qLength1; i++) {
            let q = allQ1.item(i);
            q.getElementsByClassName("clearfix").item(0).innerText += "\n [未知答案]"
            q.getElementsByTagName("input").item(0).click();
        }
    } else {
        let allA1 = getAnswers();
        let allOK = true;
        for (let i = 0; i < qLength1; i++) {
            let q = allQ1.item(i);
            let originQ = q.innerText.substring(1).replace(/\s/g, "").replace(/\n/g, "");

            for (let j = 0; j < allA1.length; j++) {
                if (similarityPercentage(originQ, allA1[j].questionValue) > 80) {
                    var rightAnswer = allA1[j].rightAnswerValue;
                    // 将正确答案展示在题目下方
                    q.getElementsByClassName("clearfix").item(0).innerText += "\n" + "正确答案: " + rightAnswer;

                    // ASCII 转选项
                    for (var section of rightAnswer) {
                        q.getElementsByTagName("input").item(section.charCodeAt() - 65).click();
                    }
                    break;
                }
            }

            if (originQ == q.innerText.substring(1).replace(/\n/g, "")) {
                q.getElementsByClassName("clearfix").item(0).innerText += "\n" + "[未知答案]";
                q.getElementsByTagName("input").item(0).click();
                allOK = false;
            }

        }
    }

    //if (!allOK) submitCheckTimes(); // 网站原函数: 提交
}

function view() {
    console.log(getWorkId());
    let allQ2 = document.getElementsByClassName("TiMu singleQuesId");
    let qLength2 = allQ2.length;
    let allA2 = new Array();

    for (let i = 0; i < qLength2; i++) {
        let q = allQ2.item(i);
        allA2.push({
            questionValue: q.innerText.substring(1).replace(/\n/g, "").split("正确答案")[0],
            rightAnswerValue: q.getElementsByClassName("Py_answer clearfix").item(0).innerText.split(";")[0].split(" ")[1].split(":")[0].replace(/\n/g, "")
        });
    }

    if (haveAnswers()) { // 合并答案
        let oldData = getAnswers();
        // 创建一个 Set 来存储旧数据的 id
        let existingIds = new Set(oldData.map(item => item.questionValue));
        // 过滤掉新数据中那些在旧数据中已经存在的 id
        let filteredNewData = allA2.filter(item => !existingIds.has(item.questionValue));
        // 将过滤后的新数据添加到旧数据中
        let mergedData = oldData.concat(filteredNewData);
        saveAnswersToLocal(mergedData);
    } else {
        saveAnswersToLocal(allA2);
    }

    let topText = document.getElementsByClassName("ZyTop").item(0).innerText;
    if (!(topText.indexOf("成绩:100") != -1)) retest(); // 网站原函数: 重做
}


// 提取 jobid 作为当前这份学习通作业的唯一id
function getWorkId() {
    let queryVariables = window.location.search.substring(1);
    return queryVariables.match(/[?&]jobid=([^&]*)/)[1];
}

// 将当前这份作业的正确答案保存到本地存储中(对象转换为字符串)
function saveAnswersToLocal(allA) {
    localStorage.setItem(getWorkId(), JSON.stringify(allA));
}

// 检查本地存储中是否已经保存了当前这份作业的正确答案
function haveAnswers() {
    if (localStorage.getItem(getWorkId()) != null) {
        return true;
    } else {
        return false;
    }
}

// 从本地存储中获取当前这份作业的正确答案(字符串转换为对象)
function getAnswers() {
    return JSON.parse(localStorage.getItem(getWorkId())) || [];
}

//检查当前div元素是不是属于判断题
function isPanduanti(questionDiv) {
    if (questionDiv.getAttribute("typename") == "判断题") {
        return true;
    } else {
        return false;
    }
}

// 计算两个字符串的Levenshtein距离
function levenshteinDistance(a, b) {
    const matrix = [];

    // 初始化矩阵
    for (let i = 0; i <= b.length; i++) {
        matrix[i] = [i];
    }
    for (let j = 0; j <= a.length; j++) {
        matrix[0][j] = j;
    }

    // 填充矩阵
    for (let i = 1; i <= b.length; i++) {
        for (let j = 1; j <= a.length; j++) {
            if (b.charAt(i - 1) === a.charAt(j - 1)) {
                matrix[i][j] = matrix[i - 1][j - 1];
            } else {
                matrix[i][j] = Math.min(
                    matrix[i - 1][j - 1] + 1, // 替换
                    matrix[i][j - 1] + 1,     // 插入
                    matrix[i - 1][j] + 1      // 删除
                );
            }
        }
    }

    return matrix[b.length][a.length];
}

// 计算两个字符串的相似度百分比
function similarityPercentage(a, b) {
    const distance = levenshteinDistance(a, b);
    const maxLength = Math.max(a.length, b.length);
    const similarity = (maxLength - distance) / maxLength;

    return (similarity * 100).toFixed(2);
}

/**
 * 解密字体
 * 作者wyn
 * 原地址:https://bbs.tampermonkey.net.cn/forum.php?mod=viewthread&tid=2303&highlight=%E5%AD%97%E4%BD%93%E8%A7%A3%E5%AF%86
 */
function decode() {
    var Typr = {
        parse: function (r) {
            var e = function (r, e, a, t) {
                Typr.B;
                var n = Typr.T, o = {
                    cmap: n.cmap,
                    head: n.head,
                    hhea: n.hhea,
                    maxp: n.maxp,
                    hmtx: n.hmtx,
                    name: n.name,
                    "OS/2": n.OS2,
                    post: n.post,
                    loca: n.loca,
                    kern: n.kern,
                    glyf: n.glyf,
                    "CFF ": n.CFF,
                    "SVG ": n.SVG
                }, i = { _data: r, _index: e, _offset: a };
                for (var s in o) {
                    var d = Typr.findTable(r, s, a);
                    if (d) {
                        var u = d[0], h = t[u];
                        null == h && (h = o[s].parseTab(r, u, d[1], i)), i[s] = t[u] = h
                    }
                }
                return i
            }, a = Typr.B, t = new Uint8Array(r), n = {};
            if ("ttcf" == a.readASCII(t, 0, 4)) {
                var o = 4;
                a.readUshort(t, o);
                o += 2;
                a.readUshort(t, o);
                o += 2;
                var i = a.readUint(t, o);
                o += 4;
                for (var s = [], d = 0; d < i; d++) {
                    var u = a.readUint(t, o);
                    o += 4, s.push(e(t, d, u, n))
                }
                return s
            }
            return [e(t, 0, 0, n)]
        }, findTable: function (r, e, a) {
            for (var t = Typr.B, n = t.readUshort(r, a + 4), o = a + 12, i = 0; i < n; i++) {
                var s = t.readASCII(r, o, 4), d = (t.readUint(r, o + 4), t.readUint(r, o + 8)),
                    u = t.readUint(r, o + 12);
                if (s == e) return [d, u];
                o += 16
            }
            return null
        }, T: {}
    };
    Typr.B = {
        readFixed: function (r, e) {
            return (r[e] << 8 | r[e + 1]) + (r[e + 2] << 8 | r[e + 3]) / 65540
        }, readF2dot14: function (r, e) {
            return Typr.B.readShort(r, e) / 16384
        }, readInt: function (r, e) {
            var a = Typr.B.t.uint8;
            return a[0] = r[e + 3], a[1] = r[e + 2], a[2] = r[e + 1], a[3] = r[e], Typr.B.t.int32[0]
        }, readInt8: function (r, e) {
            return Typr.B.t.uint8[0] = r[e], Typr.B.t.int8[0]
        }, readShort: function (r, e) {
            var a = Typr.B.t.uint8;
            return a[1] = r[e], a[0] = r[e + 1], Typr.B.t.int16[0]
        }, readUshort: function (r, e) {
            return r[e] << 8 | r[e + 1]
        }, writeUshort: function (r, e, a) {
            r[e] = a >> 8 & 255, r[e + 1] = 255 & a
        }, readUshorts: function (r, e, a) {
            for (var t = [], n = 0; n < a; n++) {
                var o = Typr.B.readUshort(r, e + 2 * n);
                t.push(o)
            }
            return t
        }, readUint: function (r, e) {
            var a = Typr.B.t.uint8;
            return a[3] = r[e], a[2] = r[e + 1], a[1] = r[e + 2], a[0] = r[e + 3], Typr.B.t.uint32[0]
        }, writeUint: function (r, e, a) {
            r[e] = a >> 24 & 255, r[e + 1] = a >> 16 & 255, r[e + 2] = a >> 8 & 255, r[e + 3] = a >> 0 & 255
        }, readUint64: function (r, e) {
            return 4294967296 * Typr.B.readUint(r, e) + Typr.B.readUint(r, e + 4)
        }, readASCII: function (r, e, a) {
            for (var t = "", n = 0; n < a; n++) t += String.fromCharCode(r[e + n]);
            return t
        }, writeASCII: function (r, e, a) {
            for (var t = 0; t < a.length; t++) r[e + t] = a.charCodeAt(t)
        }, readUnicode: function (r, e, a) {
            for (var t = "", n = 0; n < a; n++) {
                var o = r[e++] << 8 | r[e++];
                t += String.fromCharCode(o)
            }
            return t
        }, _tdec: window.TextDecoder ? new window.TextDecoder : null, readUTF8: function (r, e, a) {
            var t = Typr.B._tdec;
            return t && 0 == e && a == r.length ? t.decode(r) : Typr.B.readASCII(r, e, a)
        }, readBytes: function (r, e, a) {
            for (var t = [], n = 0; n < a; n++) t.push(r[e + n]);
            return t
        }, readASCIIArray: function (r, e, a) {
            for (var t = [], n = 0; n < a; n++) t.push(String.fromCharCode(r[e + n]));
            return t
        }, t: function () {
            var r = new ArrayBuffer(8);
            return {
                buff: r,
                int8: new Int8Array(r),
                uint8: new Uint8Array(r),
                int16: new Int16Array(r),
                uint16: new Uint16Array(r),
                int32: new Int32Array(r),
                uint32: new Uint32Array(r)
            }
        }()
    }, Typr.T.CFF = {
        parseTab: function (r, e, a) {
            var t = Typr.B, n = Typr.T.CFF;
            (r = new Uint8Array(r.buffer, e, a))[e = 0], r[++e], r[++e], r[++e];
            e++;
            var o = [];
            e = n.readIndex(r, e, o);
            for (var i = [], s = 0; s < o.length - 1; s++) i.push(t.readASCII(r, e + o[s], o[s + 1] - o[s]));
            e += o[o.length - 1];
            var d = [];
            e = n.readIndex(r, e, d);
            var u = [];
            for (s = 0; s < d.length - 1; s++) u.push(n.readDict(r, e + d[s], e + d[s + 1]));
            e += d[d.length - 1];
            var h = u[0], p = [];
            e = n.readIndex(r, e, p);
            var f = [];
            for (s = 0; s < p.length - 1; s++) f.push(t.readASCII(r, e + p[s], p[s + 1] - p[s]));
            if (e += p[p.length - 1], n.readSubrs(r, e, h), h.CharStrings && (h.CharStrings = n.readBytes(r, h.CharStrings)), h.ROS) {
                e = h.FDArray;
                var l = [];
                e = n.readIndex(r, e, l), h.FDArray = [];
                for (s = 0; s < l.length - 1; s++) {
                    var v = n.readDict(r, e + l[s], e + l[s + 1]);
                    n._readFDict(r, v, f), h.FDArray.push(v)
                }
                e += l[l.length - 1], e = h.FDSelect, h.FDSelect = [];
                var y = r[e];
                if (e++, 3 != y) throw y;
                var c = t.readUshort(r, e);
                e += 2;
                for (s = 0; s < c + 1; s++) h.FDSelect.push(t.readUshort(r, e), r[e + 2]), e += 3
            }
            return h.charset && (h.charset = n.readCharset(r, h.charset, h.CharStrings.length)), n._readFDict(r, h, f), h
        },
        _readFDict: function (r, e, a) {
            var t, n = Typr.T.CFF;
            for (var o in e.Private && (t = e.Private[1], e.Private = n.readDict(r, t, t + e.Private[0]), e.Private.Subrs && n.readSubrs(r, t + e.Private.Subrs, e.Private)), e) -1 != ["FamilyName", "FontName", "FullName", "Notice", "version", "Copyright"].indexOf(o) && (e[o] = a[e[o] - 426 + 35])
        },
        readSubrs: function (r, e, a) {
            a.Subrs = Typr.T.CFF.readBytes(r, e);
            var t, n = a.Subrs.length + 1;
            t = n < 1240 ? 107 : n < 33900 ? 1131 : 32768, a.Bias = t
        },
        readBytes: function (r, e) {
            Typr.B;
            var a = [];
            e = Typr.T.CFF.readIndex(r, e, a);
            for (var t = [], n = a.length - 1, o = r.byteOffset + e, i = 0; i < n; i++) {
                var s = a[i];
                t.push(new Uint8Array(r.buffer, o + s, a[i + 1] - s))
            }
            return t
        },
        tableSE: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 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, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 0, 111, 112, 113, 114, 0, 115, 116, 117, 118, 119, 120, 121, 122, 0, 123, 0, 124, 125, 126, 127, 128, 129, 130, 131, 0, 132, 133, 0, 134, 135, 136, 137, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 138, 0, 139, 0, 0, 0, 0, 140, 141, 142, 143, 0, 0, 0, 0, 0, 144, 0, 0, 0, 145, 0, 0, 146, 147, 148, 149, 0, 0, 0, 0],
        glyphByUnicode: function (r, e) {
            for (var a = 0; a < r.charset.length; a++) if (r.charset[a] == e) return a;
            return -1
        },
        glyphBySE: function (r, e) {
            return e < 0 || e > 255 ? -1 : Typr.T.CFF.glyphByUnicode(r, Typr.T.CFF.tableSE[e])
        },
        readCharset: function (r, e, a) {
            var t = Typr.B, n = [".notdef"], o = r[e];
            if (e++, 0 == o) for (var i = 0; i < a; i++) {
                var s = t.readUshort(r, e);
                e += 2, n.push(s)
            } else {
                if (1 != o && 2 != o) throw "error: format: " + o;
                for (; n.length < a;) {
                    s = t.readUshort(r, e);
                    e += 2;
                    var d = 0;
                    1 == o ? (d = r[e], e++) : (d = t.readUshort(r, e), e += 2);
                    for (i = 0; i <= d; i++) n.push(s), s++
                }
            }
            return n
        },
        readIndex: function (r, e, a) {
            var t = Typr.B, n = t.readUshort(r, e) + 1, o = r[e += 2];
            if (e++, 1 == o) for (var i = 0; i < n; i++) a.push(r[e + i]); else if (2 == o) for (i = 0; i < n; i++) a.push(t.readUshort(r, e + 2 * i)); else if (3 == o) for (i = 0; i < n; i++) a.push(16777215 & t.readUint(r, e + 3 * i - 1)); else if (4 == o) for (i = 0; i < n; i++) a.push(t.readUint(r, e + 4 * i)); else if (1 != n) throw "unsupported offset size: " + o + ", count: " + n;
            return (e += n * o) - 1
        },
        getCharString: function (r, e, a) {
            var t = Typr.B, n = r[e], o = r[e + 1], i = (r[e + 2], r[e + 3], r[e + 4], 1), s = null,
                d = null;
            n <= 20 && (s = n, i = 1), 12 == n && (s = 100 * n + o, i = 2), 21 <= n && n <= 27 && (s = n, i = 1), 28 == n && (d = t.readShort(r, e + 1), i = 3), 29 <= n && n <= 31 && (s = n, i = 1), 32 <= n && n <= 246 && (d = n - 139, i = 1), 247 <= n && n <= 250 && (d = 256 * (n - 247) + o + 108, i = 2), 251 <= n && n <= 254 && (d = 256 * -(n - 251) - o - 108, i = 2), 255 == n && (d = t.readInt(r, e + 1) / 65535, i = 5), a.val = null != d ? d : "o" + s, a.size = i
        },
        readCharString: function (r, e, a) {
            for (var t = e + a, n = Typr.B, o = []; e < t;) {
                var i = r[e], s = r[e + 1], d = (r[e + 2], r[e + 3], r[e + 4], 1), u = null, h = null;
                i <= 20 && (u = i, d = 1), 12 == i && (u = 100 * i + s, d = 2), 19 != i && 20 != i || (u = i, d = 2), 21 <= i && i <= 27 && (u = i, d = 1), 28 == i && (h = n.readShort(r, e + 1), d = 3), 29 <= i && i <= 31 && (u = i, d = 1), 32 <= i && i <= 246 && (h = i - 139, d = 1), 247 <= i && i <= 250 && (h = 256 * (i - 247) + s + 108, d = 2), 251 <= i && i <= 254 && (h = 256 * -(i - 251) - s - 108, d = 2), 255 == i && (h = n.readInt(r, e + 1) / 65535, d = 5), o.push(null != h ? h : "o" + u), e += d
            }
            return o
        },
        readDict: function (r, e, a) {
            for (var t = Typr.B, n = {}, o = []; e < a;) {
                var i = r[e], s = r[e + 1], d = (r[e + 2], r[e + 3], r[e + 4], 1), u = null, h = null;
                if (28 == i && (h = t.readShort(r, e + 1), d = 3), 29 == i && (h = t.readInt(r, e + 1), d = 5), 32 <= i && i <= 246 && (h = i - 139, d = 1), 247 <= i && i <= 250 && (h = 256 * (i - 247) + s + 108, d = 2), 251 <= i && i <= 254 && (h = 256 * -(i - 251) - s - 108, d = 2), 255 == i) throw h = t.readInt(r, e + 1) / 65535, d = 5, "unknown number";
                if (30 == i) {
                    var p = [];
                    for (d = 1; ;) {
                        var f = r[e + d];
                        d++;
                        var l = f >> 4, v = 15 & f;
                        if (15 != l && p.push(l), 15 != v && p.push(v), 15 == v) break
                    }
                    for (var y = "", c = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, ".", "e", "e-", "reserved", "-", "endOfNumber"], S = 0; S < p.length; S++) y += c[p[S]];
                    h = parseFloat(y)
                }
                if (i <= 21) if (u = ["version", "Notice", "FullName", "FamilyName", "Weight", "FontBBox", "BlueValues", "OtherBlues", "FamilyBlues", "FamilyOtherBlues", "StdHW", "StdVW", "escape", "UniqueID", "XUID", "charset", "Encoding", "CharStrings", "Private", "Subrs", "defaultWidthX", "nominalWidthX"][i], d = 1, 12 == i) u = ["Copyright", "isFixedPitch", "ItalicAngle", "UnderlinePosition", "UnderlineThickness", "PaintType", "CharstringType", "FontMatrix", "StrokeWidth", "BlueScale", "BlueShift", "BlueFuzz", "StemSnapH", "StemSnapV", "ForceBold", "", "", "LanguageGroup", "ExpansionFactor", "initialRandomSeed", "SyntheticBase", "PostScript", "BaseFontName", "BaseFontBlend", "", "", "", "", "", "", "ROS", "CIDFontVersion", "CIDFontRevision", "CIDFontType", "CIDCount", "UIDBase", "FDArray", "FDSelect", "FontName"][s], d = 2;
                null != u ? (n[u] = 1 == o.length ? o[0] : o, o = []) : o.push(h), e += d
            }
            return n
        }
    }, Typr.T.cmap = {
        parseTab: function (r, e, a) {
            var t = { tables: [], ids: {}, off: e };
            r = new Uint8Array(r.buffer, e, a);
            e = 0;
            var n = Typr.B, o = n.readUshort, i = Typr.T.cmap, s = (o(r, e), o(r, e += 2));
            e += 2;
            for (var d = [], u = 0; u < s; u++) {
                var h = o(r, e), p = o(r, e += 2);
                e += 2;
                var f = n.readUint(r, e);
                e += 4;
                var l = "p" + h + "e" + p, v = d.indexOf(f);
                if (-1 == v) {
                    v = t.tables.length;
                    var y = {};
                    d.push(f);
                    var c = y.format = o(r, f);
                    0 == c ? y = i.parse0(r, f, y) : 4 == c ? y = i.parse4(r, f, y) : 6 == c ? y = i.parse6(r, f, y) : 12 == c && (y = i.parse12(r, f, y)), t.tables.push(y)
                }
                if (null != t.ids[l]) throw "multiple tables for one platform+encoding";
                t.ids[l] = v
            }
            return t
        }, parse0: function (r, e, a) {
            var t = Typr.B;
            e += 2;
            var n = t.readUshort(r, e);
            e += 2;
            t.readUshort(r, e);
            e += 2, a.map = [];
            for (var o = 0; o < n - 6; o++) a.map.push(r[e + o]);
            return a
        }, parse4: function (r, e, a) {
            var t = Typr.B, n = t.readUshort, o = t.readUshorts, i = e, s = n(r, e += 2),
                d = (n(r, e += 2), n(r, e += 2));
            e += 2;
            var u = d >>> 1;
            a.searchRange = n(r, e), e += 2, a.entrySelector = n(r, e), e += 2, a.rangeShift = n(r, e), e += 2, a.endCount = o(r, e, u), e += 2 * u, e += 2, a.startCount = o(r, e, u), e += 2 * u, a.idDelta = [];
            for (var h = 0; h < u; h++) a.idDelta.push(t.readShort(r, e)), e += 2;
            return a.idRangeOffset = o(r, e, u), e += 2 * u, a.glyphIdArray = o(r, e, i + s - e >>> 1), a
        }, parse6: function (r, e, a) {
            var t = Typr.B;
            e += 2;
            t.readUshort(r, e);
            e += 2;
            t.readUshort(r, e);
            e += 2, a.firstCode = t.readUshort(r, e), e += 2;
            var n = t.readUshort(r, e);
            e += 2, a.glyphIdArray = [];
            for (var o = 0; o < n; o++) a.glyphIdArray.push(t.readUshort(r, e)), e += 2;
            return a
        }, parse12: function (r, e, a) {
            var t = Typr.B.readUint, n = (t(r, e += 4), t(r, e += 4), 3 * t(r, e += 4));
            e += 4;
            for (var o = a.groups = new Uint32Array(n), i = 0; i < n; i += 3) o[i] = t(r, e + (i << 2)), o[i + 1] = t(r, e + (i << 2) + 4), o[i + 2] = t(r, e + (i << 2) + 8);
            return a
        }
    }, Typr.T.glyf = {
        parseTab: function (r, e, a, t) {
            for (var n = [], o = t.maxp.numGlyphs, i = 0; i < o; i++) n.push(null);
            return n
        }, _parseGlyf: function (r, e) {
            var a = Typr.B, t = r._data, n = r.loca;
            if (n[e] == n[e + 1]) return null;
            var o = Typr.findTable(t, "glyf", r._offset)[0] + n[e], i = {};
            if (i.noc = a.readShort(t, o), o += 2, i.xMin = a.readShort(t, o), o += 2, i.yMin = a.readShort(t, o), o += 2, i.xMax = a.readShort(t, o), o += 2, i.yMax = a.readShort(t, o), o += 2, i.xMin >= i.xMax || i.yMin >= i.yMax) return null;
            if (i.noc > 0) {
                i.endPts = [];
                for (var s = 0; s < i.noc; s++) i.endPts.push(a.readUshort(t, o)), o += 2;
                var d = a.readUshort(t, o);
                if (o += 2, t.length - o < d) return null;
                i.instructions = a.readBytes(t, o, d), o += d;
                var u = i.endPts[i.noc - 1] + 1;
                i.flags = [];
                for (s = 0; s < u; s++) {
                    var h = t[o];
                    if (o++, i.flags.push(h), 0 != (8 & h)) {
                        var p = t[o];
                        o++;
                        for (var f = 0; f < p; f++) i.flags.push(h), s++
                    }
                }
                i.xs = [];
                for (s = 0; s < u; s++) {
                    var l = 0 != (2 & i.flags[s]), v = 0 != (16 & i.flags[s]);
                    l ? (i.xs.push(v ? t[o] : -t[o]), o++) : v ? i.xs.push(0) : (i.xs.push(a.readShort(t, o)), o += 2)
                }
                i.ys = [];
                for (s = 0; s < u; s++) {
                    l = 0 != (4 & i.flags[s]), v = 0 != (32 & i.flags[s]);
                    l ? (i.ys.push(v ? t[o] : -t[o]), o++) : v ? i.ys.push(0) : (i.ys.push(a.readShort(t, o)), o += 2)
                }
                var y = 0, c = 0;
                for (s = 0; s < u; s++) y += i.xs[s], c += i.ys[s], i.xs[s] = y, i.ys[s] = c
            } else {
                var S;
                i.parts = [];
                do {
                    S = a.readUshort(t, o), o += 2;
                    var T = { m: { a: 1, b: 0, c: 0, d: 1, tx: 0, ty: 0 }, p1: -1, p2: -1 };
                    if (i.parts.push(T), T.glyphIndex = a.readUshort(t, o), o += 2, 1 & S) {
                        var U = a.readShort(t, o);
                        o += 2;
                        var g = a.readShort(t, o);
                        o += 2
                    } else {
                        U = a.readInt8(t, o);
                        o++;
                        g = a.readInt8(t, o);
                        o++
                    }
                    2 & S ? (T.m.tx = U, T.m.ty = g) : (T.p1 = U, T.p2 = g), 8 & S ? (T.m.a = T.m.d = a.readF2dot14(t, o), o += 2) : 64 & S ? (T.m.a = a.readF2dot14(t, o), o += 2, T.m.d = a.readF2dot14(t, o), o += 2) : 128 & S && (T.m.a = a.readF2dot14(t, o), o += 2, T.m.b = a.readF2dot14(t, o), o += 2, T.m.c = a.readF2dot14(t, o), o += 2, T.m.d = a.readF2dot14(t, o), o += 2)
                } while (32 & S);
                if (256 & S) {
                    var m = a.readUshort(t, o);
                    o += 2, i.instr = [];
                    for (s = 0; s < m; s++) i.instr.push(t[o]), o++
                }
            }
            return i
        }
    }, Typr.T.head = {
        parseTab: function (r, e, a) {
            var t = Typr.B, n = {};
            t.readFixed(r, e);
            e += 4, n.fontRevision = t.readFixed(r, e), e += 4;
            t.readUint(r, e);
            e += 4;
            t.readUint(r, e);
            return e += 4, n.flags = t.readUshort(r, e), e += 2, n.unitsPerEm = t.readUshort(r, e), e += 2, n.created = t.readUint64(r, e), e += 8, n.modified = t.readUint64(r, e), e += 8, n.xMin = t.readShort(r, e), e += 2, n.yMin = t.readShort(r, e), e += 2, n.xMax = t.readShort(r, e), e += 2, n.yMax = t.readShort(r, e), e += 2, n.macStyle = t.readUshort(r, e), e += 2, n.lowestRecPPEM = t.readUshort(r, e), e += 2, n.fontDirectionHint = t.readShort(r, e), e += 2, n.indexToLocFormat = t.readShort(r, e), e += 2, n.glyphDataFormat = t.readShort(r, e), e += 2, n
        }
    }, Typr.T.hhea = {
        parseTab: function (r, e, a) {
            var t = Typr.B, n = {};
            t.readFixed(r, e);
            e += 4;
            for (var o = ["ascender", "descender", "lineGap", "advanceWidthMax", "minLeftSideBearing", "minRightSideBearing", "xMaxExtent", "caretSlopeRise", "caretSlopeRun", "caretOffset", "res0", "res1", "res2", "res3", "metricDataFormat", "numberOfHMetrics"], i = 0; i < o.length; i++) {
                var s = o[i],
                    d = "advanceWidthMax" == s || "numberOfHMetrics" == s ? t.readUshort : t.readShort;
                n[s] = d(r, e + 2 * i)
            }
            return n
        }
    }, Typr.T.hmtx = {
        parseTab: function (r, e, a, t) {
            for (var n = Typr.B, o = [], i = [], s = t.maxp.numGlyphs, d = t.hhea.numberOfHMetrics, u = 0, h = 0, p = 0; p < d;) u = n.readUshort(r, e + (p << 2)), h = n.readShort(r, e + (p << 2) + 2), o.push(u), i.push(h), p++;
            for (; p < s;) o.push(u), i.push(h), p++;
            return { aWidth: o, lsBearing: i }
        }
    }, Typr.T.kern = {
        parseTab: function (r, e, a, t) {
            var n = Typr.B, o = Typr.T.kern;
            if (1 == n.readUshort(r, e)) return o.parseV1(r, e, a, t);
            var i = n.readUshort(r, e + 2);
            e += 4;
            for (var s = { glyph1: [], rval: [] }, d = 0; d < i; d++) {
                e += 2;
                a = n.readUshort(r, e);
                e += 2;
                var u = n.readUshort(r, e);
                e += 2;
                var h = u >>> 8;
                0 == (h &= 15) && (e = o.readFormat0(r, e, s))
            }
            return s
        }, parseV1: function (r, e, a, t) {
            var n = Typr.B, o = Typr.T.kern, i = (n.readFixed(r, e), n.readUint(r, e + 4));
            e += 8;
            for (var s = { glyph1: [], rval: [] }, d = 0; d < i; d++) {
                n.readUint(r, e);
                e += 4;
                var u = n.readUshort(r, e);
                e += 2;
                n.readUshort(r, e);
                e += 2, 0 == (255 & u) && (e = o.readFormat0(r, e, s))
            }
            return s
        }, readFormat0: function (r, e, a) {
            var t = Typr.B, n = t.readUshort, o = -1, i = n(r, e);
            n(r, e + 2), n(r, e + 4), n(r, e + 6);
            e += 8;
            for (var s = 0; s < i; s++) {
                var d = n(r, e), u = n(r, e += 2);
                e += 2;
                var h = t.readShort(r, e);
                e += 2, d != o && (a.glyph1.push(d), a.rval.push({ glyph2: [], vals: [] }));
                var p = a.rval[a.rval.length - 1];
                p.glyph2.push(u), p.vals.push(h), o = d
            }
            return e
        }
    }, Typr.T.loca = {
        parseTab: function (r, e, a, t) {
            var n = Typr.B, o = [], i = t.head.indexToLocFormat, s = t.maxp.numGlyphs + 1;
            if (0 == i) for (var d = 0; d < s; d++) o.push(n.readUshort(r, e + (d << 1)) << 1);
            if (1 == i) for (d = 0; d < s; d++) o.push(n.readUint(r, e + (d << 2)));
            return o
        }
    }, Typr.T.maxp = {
        parseTab: function (r, e, a) {
            var t = Typr.B, n = t.readUshort, o = {};
            t.readUint(r, e);
            return e += 4, o.numGlyphs = n(r, e), e += 2, o
        }
    }, Typr.T.name = {
        parseTab: function (r, e, a) {
            var t = Typr.B, n = {};
            t.readUshort(r, e);
            e += 2;
            var o = t.readUshort(r, e);
            e += 2;
            t.readUshort(r, e);
            for (var i = ["copyright", "fontFamily", "fontSubfamily", "ID", "fullName", "version", "postScriptName", "trademark", "manufacturer", "designer", "description", "urlVendor", "urlDesigner", "licence", "licenceURL", "---", "typoFamilyName", "typoSubfamilyName", "compatibleFull", "sampleText", "postScriptCID", "wwsFamilyName", "wwsSubfamilyName", "lightPalette", "darkPalette"], s = e += 2, d = t.readUshort, u = 0; u < o; u++) {
                var h = d(r, e), p = d(r, e += 2), f = d(r, e += 2), l = d(r, e += 2), v = d(r, e += 2),
                    y = d(r, e += 2);
                e += 2;
                var c, S = s + 12 * o + y;
                0 == h || 3 == h && 0 == p ? c = t.readUnicode(r, S, v / 2) : 0 == p ? c = t.readASCII(r, S, v) : 1 == p || 3 == p || 4 == p || 10 == p ? c = t.readUnicode(r, S, v / 2) : 1 == h ? (c = t.readASCII(r, S, v), console.log("reading unknown MAC encoding " + p + " as ASCII")) : (console.log("unknown encoding " + p + ", platformID: " + h), c = t.readASCII(r, S, v));
                var T = "p" + h + "," + f.toString(16);
                null == n[T] && (n[T] = {}), n[T][i[l]] = c, n[T]._lang = f
            }
            var U, g = "postScriptName";
            for (var m in n) if (null != n[m][g] && 1033 == n[m]._lang) return n[m];
            for (var m in n) if (null != n[m][g] && 0 == n[m]._lang) return n[m];
            for (var m in n) if (null != n[m][g] && 3084 == n[m]._lang) return n[m];
            for (var m in n) if (null != n[m][g]) return n[m];
            for (var m in n) {
                U = n[m];
                break
            }
            return console.log("returning name table with languageID " + U._lang), null == U[g] && null != U.ID && (U[g] = U.ID), U
        }
    }, Typr.T.OS2 = {
        parseTab: function (r, e, a) {
            var t = Typr.B.readUshort(r, e);
            e += 2;
            var n = Typr.T.OS2, o = {};
            if (0 == t) n.version0(r, e, o); else if (1 == t) n.version1(r, e, o); else if (2 == t || 3 == t || 4 == t) n.version2(r, e, o); else {
                if (5 != t) throw "unknown OS/2 table version: " + t;
                n.version5(r, e, o)
            }
            return o
        }, version0: function (r, e, a) {
            var t = Typr.B;
            return a.xAvgCharWidth = t.readShort(r, e), e += 2, a.usWeightClass = t.readUshort(r, e), e += 2, a.usWidthClass = t.readUshort(r, e), e += 2, a.fsType = t.readUshort(r, e), e += 2, a.ySubscriptXSize = t.readShort(r, e), e += 2, a.ySubscriptYSize = t.readShort(r, e), e += 2, a.ySubscriptXOffset = t.readShort(r, e), e += 2, a.ySubscriptYOffset = t.readShort(r, e), e += 2, a.ySuperscriptXSize = t.readShort(r, e), e += 2, a.ySuperscriptYSize = t.readShort(r, e), e += 2, a.ySuperscriptXOffset = t.readShort(r, e), e += 2, a.ySuperscriptYOffset = t.readShort(r, e), e += 2, a.yStrikeoutSize = t.readShort(r, e), e += 2, a.yStrikeoutPosition = t.readShort(r, e), e += 2, a.sFamilyClass = t.readShort(r, e), e += 2, a.panose = t.readBytes(r, e, 10), e += 10, a.ulUnicodeRange1 = t.readUint(r, e), e += 4, a.ulUnicodeRange2 = t.readUint(r, e), e += 4, a.ulUnicodeRange3 = t.readUint(r, e), e += 4, a.ulUnicodeRange4 = t.readUint(r, e), e += 4, a.achVendID = t.readASCII(r, e, 4), e += 4, a.fsSelection = t.readUshort(r, e), e += 2, a.usFirstCharIndex = t.readUshort(r, e), e += 2, a.usLastCharIndex = t.readUshort(r, e), e += 2, a.sTypoAscender = t.readShort(r, e), e += 2, a.sTypoDescender = t.readShort(r, e), e += 2, a.sTypoLineGap = t.readShort(r, e), e += 2, a.usWinAscent = t.readUshort(r, e), e += 2, a.usWinDescent = t.readUshort(r, e), e += 2
        }, version1: function (r, e, a) {
            var t = Typr.B;
            return e = Typr.T.OS2.version0(r, e, a), a.ulCodePageRange1 = t.readUint(r, e), e += 4, a.ulCodePageRange2 = t.readUint(r, e), e += 4
        }, version2: function (r, e, a) {
            var t = Typr.B, n = t.readUshort;
            return e = Typr.T.OS2.version1(r, e, a), a.sxHeight = t.readShort(r, e), e += 2, a.sCapHeight = t.readShort(r, e), e += 2, a.usDefault = n(r, e), e += 2, a.usBreak = n(r, e), e += 2, a.usMaxContext = n(r, e), e += 2
        }, version5: function (r, e, a) {
            var t = Typr.B.readUshort;
            return e = Typr.T.OS2.version2(r, e, a), a.usLowerOpticalPointSize = t(r, e), e += 2, a.usUpperOpticalPointSize = t(r, e), e += 2
        }
    }, Typr.T.post = {
        parseTab: function (r, e, a) {
            var t = Typr.B, n = {};
            return n.version = t.readFixed(r, e), e += 4, n.italicAngle = t.readFixed(r, e), e += 4, n.underlinePosition = t.readShort(r, e), e += 2, n.underlineThickness = t.readShort(r, e), e += 2, n
        }
    }, Typr.T.SVG = {
        parseTab: function (r, e, a) {
            var t = Typr.B, n = { entries: [] }, o = e;
            t.readUshort(r, e);
            e += 2;
            var i = t.readUint(r, e);
            e += 4;
            t.readUint(r, e);
            e += 4, e = i + o;
            var s = t.readUshort(r, e);
            e += 2;
            for (var d = 0; d < s; d++) {
                var u = t.readUshort(r, e);
                e += 2;
                var h = t.readUshort(r, e);
                e += 2;
                var p = t.readUint(r, e);
                e += 4;
                var f = t.readUint(r, e);
                e += 4;
                for (var l = new Uint8Array(r.buffer, o + p + i, f), v = t.readUTF8(l, 0, l.length), y = u; y <= h; y++) n.entries[y] = v
            }
            return n
        }
    };
    Typr.U = {
        shape: function (t, e, r) {
            for (var s = function (t, e, r, s) {
                var n = e[r], a = e[r + 1], h = t.kern;
                if (h) {
                    var o = h.glyph1.indexOf(n);
                    if (-1 != o) {
                        var f = h.rval[o].glyph2.indexOf(a);
                        if (-1 != f) return [0, 0, h.rval[o].vals[f], 0]
                    }
                }
                return [0, 0, 0, 0]
            }, n = [], a = 0; a < e.length; a++) {
                var h = e.codePointAt(a);
                h > 65535 && a++, n.push(Typr.U.codeToGlyph(t, h))
            }
            var o = [];
            for (a = 0; a < n.length; a++) {
                var f = s(t, n, a), i = n[a], l = t.hmtx.aWidth[i] + f[2];
                o.push({ g: i, cl: a, dx: 0, dy: 0, ax: l, ay: 0 }), l
            }
            return o
        }, shapeToPath: function (t, e, r) {
            for (var s = { cmds: [], crds: [] }, n = 0, a = 0, h = 0; h < e.length; h++) {
                for (var o = e[h], f = Typr.U.glyphToPath(t, o.g), i = f.crds, l = 0; l < i.length; l += 2) s.crds.push(i[l] + n + o.dx), s.crds.push(i[l + 1] + a + o.dy);
                r && s.cmds.push(r);
                for (l = 0; l < f.cmds.length; l++) s.cmds.push(f.cmds[l]);
                var c = s.cmds.length;
                r && 0 != c && "X" != s.cmds[c - 1] && s.cmds.push("X"), n += o.ax, a += o.ay
            }
            return { cmds: s.cmds, crds: s.crds }
        }, codeToGlyph: function (t, e) {
            for (var r = t.cmap, s = -1, n = ["p3e10", "p0e4", "p3e1", "p1e0", "p0e3", "p0e1"], a = 0; a < n.length; a++) if (null != r.ids[n[a]]) {
                s = r.ids[n[a]];
                break
            }
            if (-1 == s) throw "no familiar platform and encoding!";
            var h = function (t, e, r) {
                for (var s = 0, n = Math.floor(t.length / e); s + 1 != n;) {
                    var a = s + (n - s >>> 1);
                    t[a * e] <= r ? s = a : n = a
                }
                return s * e
            }, o = r.tables[s], f = o.format, i = -1;
            if (0 == f) i = e >= o.map.length ? 0 : o.map[e]; else if (4 == f) {
                var l = -1, c = o.endCount;
                if (e > c[c.length - 1] ? l = -1 : c[l = h(c, 1, e)] < e && l++, -1 == l) i = 0; else if (e < o.startCount[l]) i = 0; else {
                    i = 65535 & (0 != o.idRangeOffset[l] ? o.glyphIdArray[e - o.startCount[l] + (o.idRangeOffset[l] >> 1) - (o.idRangeOffset.length - l)] : e + o.idDelta[l])
                }
            } else if (6 == f) {
                var u = e - o.firstCode, d = o.glyphIdArray;
                i = u < 0 || u >= d.length ? 0 : d[u]
            } else {
                if (12 != f) throw "unknown cmap table format " + o.format;
                var v = o.groups;
                e > v[v.length - 2] ? i = 0 : (v[a = h(v, 3, e)] <= e && e <= v[a + 1] && (i = v[a + 2] + (e - v[a])), -1 == i && (i = 0))
            }
            var p = t["SVG "], g = t.loca;
            return 0 == i || null != t["CFF "] || null != p && null != p.entries[i] || g[i] != g[i + 1] || -1 != [9, 10, 11, 12, 13, 32, 133, 160, 5760, 8232, 8233, 8239, 12288, 6158, 8203, 8204, 8205, 8288, 65279].indexOf(e) || 8192 <= e && e <= 8202 || (i = 0), i
        }, glyphToPath: function (t, e) {
            var r = { cmds: [], crds: [] }, s = t["SVG "], n = t["CFF "], a = Typr.U;
            if (s && s.entries[e]) {
                var h = s.entries[e];
                null != h && ("string" == typeof h && (h = a.SVG.toPath(h), s.entries[e] = h), r = h)
            } else if (n) {
                var o = n.Private, f = {
                    x: 0,
                    y: 0,
                    stack: [],
                    nStems: 0,
                    haveWidth: !1,
                    width: o ? o.defaultWidthX : 0,
                    open: !1
                };
                if (n.ROS) {
                    for (var i = 0; n.FDSelect[i + 2] <= e;) i += 2;
                    o = n.FDArray[n.FDSelect[i + 1]].Private
                }
                a._drawCFF(n.CharStrings[e], f, n, o, r)
            } else t.glyf && a._drawGlyf(e, t, r);
            return { cmds: r.cmds, crds: r.crds }
        }, _drawGlyf: function (t, e, r) {
            var s = e.glyf[t];
            null == s && (s = e.glyf[t] = Typr.T.glyf._parseGlyf(e, t)), null != s && (s.noc > -1 ? Typr.U._simpleGlyph(s, r) : Typr.U._compoGlyph(s, e, r))
        }, _simpleGlyph: function (t, e) {
            for (var r = Typr.U.P, s = 0; s < t.noc; s++) {
                for (var n = 0 == s ? 0 : t.endPts[s - 1] + 1, a = t.endPts[s], h = n; h <= a; h++) {
                    var o = h == n ? a : h - 1, f = h == a ? n : h + 1, i = 1 & t.flags[h],
                        l = 1 & t.flags[o], c = 1 & t.flags[f], u = t.xs[h], d = t.ys[h];
                    if (h == n) if (i) {
                        if (!l) {
                            r.MoveTo(e, u, d);
                            continue
                        }
                        r.MoveTo(e, t.xs[o], t.ys[o])
                    } else l ? r.MoveTo(e, t.xs[o], t.ys[o]) : r.MoveTo(e, Math.floor(.5 * (t.xs[o] + u)), Math.floor(.5 * (t.ys[o] + d)));
                    i ? l && r.LineTo(e, u, d) : c ? r.qCurveTo(e, u, d, t.xs[f], t.ys[f]) : r.qCurveTo(e, u, d, Math.floor(.5 * (u + t.xs[f])), Math.floor(.5 * (d + t.ys[f])))
                }
                r.ClosePath(e)
            }
        }, _compoGlyph: function (t, e, r) {
            for (var s = 0; s < t.parts.length; s++) {
                var n = { cmds: [], crds: [] }, a = t.parts[s];
                Typr.U._drawGlyf(a.glyphIndex, e, n);
                for (var h = a.m, o = 0; o < n.crds.length; o += 2) {
                    var f = n.crds[o], i = n.crds[o + 1];
                    r.crds.push(f * h.a + i * h.b + h.tx), r.crds.push(f * h.c + i * h.d + h.ty)
                }
                for (o = 0; o < n.cmds.length; o++) r.cmds.push(n.cmds[o])
            }
        }, pathToSVG: function (t, e) {
            var r = t.cmds, s = t.crds;
            null == e && (e = 5);
            for (var n = [], a = 0, h = { M: 2, L: 2, Q: 4, C: 6 }, o = 0; o < r.length; o++) {
                var f = r[o], i = a + (h[f] ? h[f] : 0);
                for (n.push(f); a < i;) {
                    var l = s[a++];
                    n.push(parseFloat(l.toFixed(e)) + (a == i ? "" : " "))
                }
            }
            return n.join("")
        }, SVGToPath: function (t) {
            var e = { cmds: [], crds: [] };
            return Typr.U.SVG.svgToPath(t, e), { cmds: e.cmds, crds: e.crds }
        }, pathToContext: function (t, e) {
            for (var r = 0, s = t.cmds, n = t.crds, a = 0; a < s.length; a++) {
                var h = s[a];
                "M" == h ? (e.moveTo(n[r], n[r + 1]), r += 2) : "L" == h ? (e.lineTo(n[r], n[r + 1]), r += 2) : "C" == h ? (e.bezierCurveTo(n[r], n[r + 1], n[r + 2], n[r + 3], n[r + 4], n[r + 5]), r += 6) : "Q" == h ? (e.quadraticCurveTo(n[r], n[r + 1], n[r + 2], n[r + 3]), r += 4) : "#" == h.charAt(0) ? (e.beginPath(), e.fillStyle = h) : "Z" == h ? e.closePath() : "X" == h && e.fill()
            }
        }, P: {
            MoveTo: function (t, e, r) {
                t.cmds.push("M"), t.crds.push(e, r)
            }, LineTo: function (t, e, r) {
                t.cmds.push("L"), t.crds.push(e, r)
            }, CurveTo: function (t, e, r, s, n, a, h) {
                t.cmds.push("C"), t.crds.push(e, r, s, n, a, h)
            }, qCurveTo: function (t, e, r, s, n) {
                t.cmds.push("Q"), t.crds.push(e, r, s, n)
            }, ClosePath: function (t) {
                t.cmds.push("Z")
            }
        }, _drawCFF: function (t, e, r, s, n) {
            for (var a = e.stack, h = e.nStems, o = e.haveWidth, f = e.width, i = e.open, l = 0, c = e.x, u = e.y, d = 0, v = 0, p = 0, g = 0, m = 0, y = 0, T = 0, C = 0, b = 0, _ = 0, M = Typr.T.CFF, x = Typr.U.P, P = s.nominalWidthX, w = {
                val: 0,
                size: 0
            }; l < t.length;) {
                M.getCharString(t, l, w);
                var S = w.val;
                if (l += w.size, "o1" == S || "o18" == S) a.length % 2 != 0 && !o && (f = a.shift() + P), h += a.length >> 1, a.length = 0, o = !0; else if ("o3" == S || "o23" == S) {
                    a.length % 2 != 0 && !o && (f = a.shift() + P), h += a.length >> 1, a.length = 0, o = !0
                } else if ("o4" == S) a.length > 1 && !o && (f = a.shift() + P, o = !0), i && x.ClosePath(n), u += a.pop(), x.MoveTo(n, c, u), i = !0; else if ("o5" == S) for (; a.length > 0;) c += a.shift(), u += a.shift(), x.LineTo(n, c, u); else if ("o6" == S || "o7" == S) for (var F = a.length, A = "o6" == S, U = 0; U < F; U++) {
                    var G = a.shift();
                    A ? c += G : u += G, A = !A, x.LineTo(n, c, u)
                } else if ("o8" == S || "o24" == S) {
                    F = a.length;
                    for (var L = 0; L + 6 <= F;) d = c + a.shift(), v = u + a.shift(), p = d + a.shift(), g = v + a.shift(), c = p + a.shift(), u = g + a.shift(), x.CurveTo(n, d, v, p, g, c, u), L += 6;
                    "o24" == S && (c += a.shift(), u += a.shift(), x.LineTo(n, c, u))
                } else {
                    if ("o11" == S) break;
                    if ("o1234" == S || "o1235" == S || "o1236" == S || "o1237" == S) "o1234" == S && (v = u, p = (d = c + a.shift()) + a.shift(), _ = g = v + a.shift(), y = g, C = u, c = (T = (m = (b = p + a.shift()) + a.shift()) + a.shift()) + a.shift(), x.CurveTo(n, d, v, p, g, b, _), x.CurveTo(n, m, y, T, C, c, u)), "o1235" == S && (d = c + a.shift(), v = u + a.shift(), p = d + a.shift(), g = v + a.shift(), b = p + a.shift(), _ = g + a.shift(), m = b + a.shift(), y = _ + a.shift(), T = m + a.shift(), C = y + a.shift(), c = T + a.shift(), u = C + a.shift(), a.shift(), x.CurveTo(n, d, v, p, g, b, _), x.CurveTo(n, m, y, T, C, c, u)), "o1236" == S && (d = c + a.shift(), v = u + a.shift(), p = d + a.shift(), _ = g = v + a.shift(), y = g, T = (m = (b = p + a.shift()) + a.shift()) + a.shift(), C = y + a.shift(), c = T + a.shift(), x.CurveTo(n, d, v, p, g, b, _), x.CurveTo(n, m, y, T, C, c, u)), "o1237" == S && (d = c + a.shift(), v = u + a.shift(), p = d + a.shift(), g = v + a.shift(), b = p + a.shift(), _ = g + a.shift(), m = b + a.shift(), y = _ + a.shift(), T = m + a.shift(), C = y + a.shift(), Math.abs(T - c) > Math.abs(C - u) ? c = T + a.shift() : u = C + a.shift(), x.CurveTo(n, d, v, p, g, b, _), x.CurveTo(n, m, y, T, C, c, u)); else if ("o14" == S) {
                        if (a.length > 0 && !o && (f = a.shift() + r.nominalWidthX, o = !0), 4 == a.length) {
                            var k = a.shift(), O = a.shift(), V = a.shift(), W = a.shift(),
                                B = M.glyphBySE(r, V), I = M.glyphBySE(r, W);
                            Typr.U._drawCFF(r.CharStrings[B], e, r, s, n), e.x = k, e.y = O, Typr.U._drawCFF(r.CharStrings[I], e, r, s, n)
                        }
                        i && (x.ClosePath(n), i = !1)
                    } else if ("o19" == S || "o20" == S) {
                        a.length % 2 != 0 && !o && (f = a.shift() + P), h += a.length >> 1, a.length = 0, o = !0, l += h + 7 >> 3
                    } else if ("o21" == S) a.length > 2 && !o && (f = a.shift() + P, o = !0), u += a.pop(), c += a.pop(), i && x.ClosePath(n), x.MoveTo(n, c, u), i = !0; else if ("o22" == S) a.length > 1 && !o && (f = a.shift() + P, o = !0), c += a.pop(), i && x.ClosePath(n), x.MoveTo(n, c, u), i = !0; else if ("o25" == S) {
                        for (; a.length > 6;) c += a.shift(), u += a.shift(), x.LineTo(n, c, u);
                        d = c + a.shift(), v = u + a.shift(), p = d + a.shift(), g = v + a.shift(), c = p + a.shift(), u = g + a.shift(), x.CurveTo(n, d, v, p, g, c, u)
                    } else if ("o26" == S) for (a.length % 2 && (c += a.shift()); a.length > 0;) d = c, v = u + a.shift(), c = p = d + a.shift(), u = (g = v + a.shift()) + a.shift(), x.CurveTo(n, d, v, p, g, c, u); else if ("o27" == S) for (a.length % 2 && (u += a.shift()); a.length > 0;) v = u, p = (d = c + a.shift()) + a.shift(), g = v + a.shift(), c = p + a.shift(), u = g, x.CurveTo(n, d, v, p, g, c, u); else if ("o10" == S || "o29" == S) {
                        var q = "o10" == S ? s : r;
                        if (0 == a.length) console.log("error: empty stack"); else {
                            var Q = a.pop(), X = q.Subrs[Q + q.Bias];
                            e.x = c, e.y = u, e.nStems = h, e.haveWidth = o, e.width = f, e.open = i, Typr.U._drawCFF(X, e, r, s, n), c = e.x, u = e.y, h = e.nStems, o = e.haveWidth, f = e.width, i = e.open
                        }
                    } else if ("o30" == S || "o31" == S) {
                        var D = a.length, E = (L = 0, "o31" == S);
                        for (L += D - (F = -3 & D); L < F;) E ? (v = u, p = (d = c + a.shift()) + a.shift(), u = (g = v + a.shift()) + a.shift(), F - L == 5 ? (c = p + a.shift(), L++) : c = p, E = !1) : (d = c, v = u + a.shift(), p = d + a.shift(), g = v + a.shift(), c = p + a.shift(), F - L == 5 ? (u = g + a.shift(), L++) : u = g, E = !0), x.CurveTo(n, d, v, p, g, c, u), L += 4
                    } else {
                        if ("o" == (S + "").charAt(0)) throw console.log("Unknown operation: " + S, t), S;
                        a.push(S)
                    }
                }
            }
            e.x = c, e.y = u, e.nStems = h, e.haveWidth = o, e.width = f, e.open = i
        }, SVG: function () {
            var t = {
                getScale: function (t) {
                    return Math.sqrt(Math.abs(t[0] * t[3] - t[1] * t[2]))
                }, translate: function (e, r, s) {
                    t.concat(e, [1, 0, 0, 1, r, s])
                }, rotate: function (e, r) {
                    t.concat(e, [Math.cos(r), -Math.sin(r), Math.sin(r), Math.cos(r), 0, 0])
                }, scale: function (e, r, s) {
                    t.concat(e, [r, 0, 0, s, 0, 0])
                }, concat: function (t, e) {
                    var r = t[0], s = t[1], n = t[2], a = t[3], h = t[4], o = t[5];
                    t[0] = r * e[0] + s * e[2], t[1] = r * e[1] + s * e[3], t[2] = n * e[0] + a * e[2], t[3] = n * e[1] + a * e[3], t[4] = h * e[0] + o * e[2] + e[4], t[5] = h * e[1] + o * e[3] + e[5]
                }, invert: function (t) {
                    var e = t[0], r = t[1], s = t[2], n = t[3], a = t[4], h = t[5], o = e * n - r * s;
                    t[0] = n / o, t[1] = -r / o, t[2] = -s / o, t[3] = e / o, t[4] = (s * h - n * a) / o, t[5] = (r * a - e * h) / o
                }, multPoint: function (t, e) {
                    var r = e[0], s = e[1];
                    return [r * t[0] + s * t[2] + t[4], r * t[1] + s * t[3] + t[5]]
                }, multArray: function (t, e) {
                    for (var r = 0; r < e.length; r += 2) {
                        var s = e[r], n = e[r + 1];
                        e[r] = s * t[0] + n * t[2] + t[4], e[r + 1] = s * t[1] + n * t[3] + t[5]
                    }
                }
            };

            function e(t, e, r) {
                for (var s = [], n = 0, a = 0, h = 0; ;) {
                    var o = t.indexOf(e, a), f = t.indexOf(r, a);
                    if (-1 == o && -1 == f) break;
                    -1 == f || -1 != o && o < f ? (0 == h && (s.push(t.slice(n, o).trim()), n = o + 1), h++, a = o + 1) : (-1 == o || -1 != f && f < o) && (0 == --h && (s.push(t.slice(n, f).trim()), n = f + 1), a = f + 1)
                }
                return s
            }

            function r(r) {
                for (var n = e(r, "(", ")"), a = [1, 0, 0, 1, 0, 0], h = 0; h < n.length; h += 2) {
                    var o = a;
                    a = s(n[h], n[h + 1]), t.concat(a, o)
                }
                return a
            }

            function s(e, r) {
                for (var s = [1, 0, 0, 1, 0, 0], n = !0, a = 0; a < r.length; a++) {
                    var h = r.charAt(a);
                    "," == h || " " == h ? n = !0 : "." == h ? (n || (r = r.slice(0, a) + "," + r.slice(a), a++), n = !1) : "-" == h && a > 0 && "e" != r[a - 1] && (r = r.slice(0, a) + " " + r.slice(a), a++, n = !0)
                }
                if (r = r.split(/\s*[\s,]\s*/).map(parseFloat), "translate" == e) 1 == r.length ? t.translate(s, r[0], 0) : t.translate(s, r[0], r[1]); else if ("scale" == e) 1 == r.length ? t.scale(s, r[0], r[0]) : t.scale(s, r[0], r[1]); else if ("rotate" == e) {
                    var o = 0, f = 0;
                    1 != r.length && (o = r[1], f = r[2]), t.translate(s, -o, -f), t.rotate(s, -Math.PI * r[0] / 180), t.translate(s, o, f)
                } else "matrix" == e ? s = r : console.log("unknown transform: ", e);
                return s
            }

            function n(e, s, a) {
                for (var o = 0; o < e.length; o++) {
                    var f = e[o], i = f.tagName, l = f.getAttribute("fill");
                    if (null == l && (l = a), "g" == i) {
                        var c = { crds: [], cmds: [] };
                        n(f.children, c, l);
                        var u = f.getAttribute("transform");
                        if (u) {
                            var d = r(u);
                            t.multArray(d, c.crds)
                        }
                        s.crds = s.crds.concat(c.crds), s.cmds = s.cmds.concat(c.cmds)
                    } else if ("path" == i || "circle" == i || "ellipse" == i) {
                        var v;
                        if (s.cmds.push(l || "#000000"), "path" == i && (v = f.getAttribute("d")), "circle" == i || "ellipse" == i) {
                            for (var p = [0, 0, 0, 0], g = ["cx", "cy", "rx", "ry", "r"], m = 0; m < 5; m++) {
                                var y = f.getAttribute(g[m]);
                                y && (y = parseFloat(y), m < 4 ? p[m] = y : p[2] = p[3] = y)
                            }
                            var T = p[0], C = p[1], b = p[2], _ = p[3];
                            v = ["M", T - b, C, "a", b, _, 0, 1, 0, 2 * b, 0, "a", b, _, 0, 1, 0, 2 * -b, 0].join(" ")
                        }
                        h(v, s), s.cmds.push("X")
                    } else "defs" == i || console.log(i, f)
                }
            }

            function a(t, e, r) {
                for (var s = e; s < t.length && "string" != typeof t[s];) s += r;
                return (s - e) / r
            }

            function h(t, e) {
                for (var r = function (t) {
                    for (var e = [], r = 0, s = !1, n = "", a = ""; r < t.length;) {
                        var h = t.charCodeAt(r), o = t.charAt(r);
                        r++;
                        var f = 48 <= h && h <= 57 || "." == o || "-" == o || "e" == o || "E" == o;
                        s ? "-" == o && "e" != a || "." == o && -1 != n.indexOf(".") ? (e.push(parseFloat(n)), n = o) : f ? n += o : (e.push(parseFloat(n)), "," != o && " " != o && e.push(o), s = !1) : f ? (n = o, s = !0) : "," != o && " " != o && e.push(o), a = o
                    }
                    return s && e.push(parseFloat(n)), e
                }(t), s = 0, n = 0, h = 0, o = 0, f = 0, i = e.crds.length, l = {
                    M: 2,
                    L: 2,
                    H: 1,
                    V: 1,
                    T: 2,
                    S: 4,
                    A: 7,
                    Q: 4,
                    C: 6
                }, c = e.cmds, u = e.crds; s < r.length;) {
                    var d = r[s];
                    s++;
                    var v = d.toUpperCase();
                    if ("Z" == v) c.push("Z"), n = o, h = f; else for (var p = a(r, s, l[v]), g = 0; g < p; g++) {
                        1 == g && "M" == v && (d = d == v ? "L" : "l", v = "L");
                        var m = 0, y = 0;
                        if (d != v && (m = n, y = h), "M" == v) n = m + r[s++], h = y + r[s++], c.push("M"), u.push(n, h), o = n, f = h; else if ("L" == v) n = m + r[s++], h = y + r[s++], c.push("L"), u.push(n, h); else if ("H" == v) n = m + r[s++], c.push("L"), u.push(n, h); else if ("V" == v) h = y + r[s++], c.push("L"), u.push(n, h); else if ("Q" == v) {
                            var T = m + r[s++], C = y + r[s++], b = m + r[s++], _ = y + r[s++];
                            c.push("Q"), u.push(T, C, b, _), n = b, h = _
                        } else if ("T" == v) {
                            T = n + n - u[P = Math.max(u.length - 2, i)], C = h + h - u[P + 1], b = m + r[s++], _ = y + r[s++];
                            c.push("Q"), u.push(T, C, b, _), n = b, h = _
                        } else if ("C" == v) {
                            T = m + r[s++], C = y + r[s++], b = m + r[s++], _ = y + r[s++];
                            var M = m + r[s++], x = y + r[s++];
                            c.push("C"), u.push(T, C, b, _, M, x), n = M, h = x
                        } else if ("S" == v) {
                            var P;
                            T = n + n - u[P = Math.max(u.length - ("C" == c[c.length - 1] ? 4 : 2), i)], C = h + h - u[P + 1], b = m + r[s++], _ = y + r[s++], M = m + r[s++], x = y + r[s++];
                            c.push("C"), u.push(T, C, b, _, M, x), n = M, h = x
                        } else if ("A" == v) {
                            T = n, C = h;
                            var w = r[s++], S = r[s++], F = r[s++] * (Math.PI / 180), A = r[s++],
                                U = r[s++];
                            b = m + r[s++], _ = y + r[s++];
                            if (b == n && _ == h && 0 == w && 0 == S) continue;
                            var G = (T - b) / 2, L = (C - _) / 2, k = Math.cos(F), O = Math.sin(F),
                                V = k * G + O * L, W = -O * G + k * L, B = w * w, I = S * S, q = V * V,
                                Q = W * W, X = (B * I - B * Q - I * q) / (B * Q + I * q),
                                D = (A != U ? 1 : -1) * Math.sqrt(Math.max(X, 0)), E = D * (w * W) / S,
                                H = S * V * -D / w, R = k * E - O * H + (T + b) / 2,
                                Z = O * E + k * H + (C + _) / 2, z = function (t, e, r, s) {
                                    var n = (t * r + e * s) / (Math.sqrt(t * t + e * e) * Math.sqrt(r * r + s * s));
                                    return (t * s - e * r >= 0 ? 1 : -1) * Math.acos(Math.max(-1, Math.min(1, n)))
                                }, N = (V - E) / w, j = (W - H) / S, J = z(1, 0, N, j),
                                K = z(N, j, (-V - E) / w, (-W - H) / S);
                            !function (t, e, r, s, n, a, h) {
                                var o = function (t, e) {
                                    var r = Math.sin(e), s = Math.cos(e), n = (e = t[0], t[1]), a = t[2],
                                        h = t[3];
                                    t[0] = e * s + n * r, t[1] = -e * r + n * s, t[2] = a * s + h * r, t[3] = -a * r + h * s
                                }, f = function (t, e) {
                                    for (var r = 0; r < e.length; r += 2) {
                                        var s = e[r], n = e[r + 1];
                                        e[r] = t[0] * s + t[2] * n + t[4], e[r + 1] = t[1] * s + t[3] * n + t[5]
                                    }
                                }, i = function (t, e) {
                                    for (var r = 0; r < e.length; r++) t.push(e[r])
                                };
                                if (h) for (; a > n;) a -= 2 * Math.PI; else for (; a < n;) a += 2 * Math.PI;
                                var l = (a - n) / 4, c = Math.cos(l / 2), u = -Math.sin(l / 2),
                                    d = (4 - c) / 3, v = 0 == u ? u : (1 - c) * (3 - c) / (3 * u),
                                    p = [d, v, d, -v, c, -u],
                                    g = { cmds: ["C", "C", "C", "C"], crds: p.slice(0) },
                                    m = [1, 0, 0, 1, 0, 0];
                                o(m, -l);
                                for (var y = 0; y < 3; y++) f(m, p), i(g.crds, p);
                                o(m, l / 2 - n), m[0] *= s, m[1] *= s, m[2] *= s, m[3] *= s, m[4] = e, m[5] = r, f(m, g.crds), f(t.ctm, g.crds), function (t, e) {
                                    i(t.cmds, e.cmds), i(t.crds, e.crds)
                                }(t.pth, g)
                            }({
                                pth: e,
                                ctm: [w * k, w * O, -S * O, S * k, R, Z]
                            }, 0, 0, 1, J, J + (K %= 2 * Math.PI), 0 == U), n = b, h = _
                        } else console.log("Unknown SVG command " + d)
                    }
                }
            }

            return {
                cssMap: function (t) {
                    for (var r = e(t, "{", "}"), s = {}, n = 0; n < r.length; n += 2) for (var a = r[n].split(","), h = 0; h < a.length; h++) {
                        var o = a[h].trim();
                        null == s[o] && (s[o] = ""), s[o] += r[n + 1]
                    }
                    return s
                }, readTrnf: r, svgToPath: h, toPath: function (t) {
                    var e = { cmds: [], crds: [] };
                    if (null == t) return e;
                    var r = (new DOMParser).parseFromString(t, "image/svg+xml").getElementsByTagName("svg")[0],
                        s = r.getAttribute("viewBox");
                    s = s ? s.trim().split(" ").map(parseFloat) : [0, 0, 1e3, 1e3], n(r.children, e);
                    for (var a = 0; a < e.crds.length; a += 2) {
                        var h = e.crds[a], o = e.crds[a + 1];
                        h -= s[0], o = -(o -= s[1]), e.crds[a] = h, e.crds[a + 1] = o
                    }
                    return e
                }
            }
        }(), initHB: function (t, e) {
            var r = function (t) {
                var e = 0;
                return 0 == (4294967168 & t) ? e = 1 : 0 == (4294965248 & t) ? e = 2 : 0 == (4294901760 & t) ? e = 3 : 0 == (4292870144 & t) && (e = 4), e
            }, s = new window.TextEncoder("utf8");
            fetch(t).then((function (t) {
                return t.arrayBuffer()
            })).then((function (t) {
                return WebAssembly.instantiate(t)
            })).then((function (t) {
                console.log("HB ready");
                var n = t.instance.exports, a = n.memory;
                a.grow(700);
                var h, o, f, i, l, c = new Uint8Array(a.buffer), u = new Uint32Array(a.buffer),
                    d = new Int32Array(a.buffer);
                Typr.U.shapeHB = function (t, e, a) {
                    var v = t._data, p = t.name.postScriptName;
                    h != p && (null != o && (n.hb_blob_destroy(o), n.free(f), n.hb_face_destroy(i), n.hb_font_destroy(l)), f = n.malloc(v.byteLength), c.set(v, f), o = n.hb_blob_create(f, v.byteLength, 2, 0, 0), i = n.hb_face_create(o, 0), l = n.hb_font_create(i), h = p);
                    var g = n.hb_buffer_create(), m = s.encode(e), y = m.length, T = n.malloc(y);
                    c.set(m, T), n.hb_buffer_add_utf8(g, T, y, 0, y), n.free(T), n.hb_buffer_set_direction(g, a ? 4 : 5), n.hb_buffer_guess_segment_properties(g), n.hb_shape(l, g, 0, 0);
                    var C = function (t) {
                        for (var e = n.hb_buffer_get_length(t), r = [], s = n.hb_buffer_get_glyph_infos(t, 0) >>> 2, a = n.hb_buffer_get_glyph_positions(t, 0) >>> 2, h = 0; h < e; ++h) {
                            var o = s + 5 * h, f = a + 5 * h;
                            r.push({
                                g: u[o + 0],
                                cl: u[o + 2],
                                ax: d[f + 0],
                                ay: d[f + 1],
                                dx: d[f + 2],
                                dy: d[f + 3]
                            })
                        }
                        return r
                    }(g);
                    n.hb_buffer_destroy(g);
                    var b = C.slice(0);
                    a || b.reverse();
                    for (var _ = 0, M = 0, x = 1; x < b.length; x++) {
                        for (var P = b[x], w = P.cl; ;) {
                            var S = e.codePointAt(_), F = r(S);
                            if (!(M + F <= w)) break;
                            M += F, _ += S <= 65535 ? 1 : 2
                        }
                        P.cl = _
                    }
                    return C
                }, e()
            }))
        }
    };
    var $tip = $('style:contains(font-cxsecret)');
    if (!$tip.length) return;
    var font = $tip.text().match(/base64,([\w\W]+?)'/)[1];
    font = Typr.parse(base64ToUint8Array(font))[0];
    var table = JSON.parse(GM_getResourceText('ttf'));
    var match = {};
    for (var i = 19968; i < 40870; i++) {
        $tip = Typr.U.codeToGlyph(font, i);
        if (!$tip) continue;
        $tip = Typr.U.glyphToPath(font, $tip);
        $tip = md5(JSON.stringify($tip)).slice(24);
        match[i] = table[$tip];
    }
    $('.font-cxsecret').html(function (index, html) {
        $.each(match, function (key, value) {
            key = String.fromCharCode(key);
            key = new RegExp(key, 'g');
            value = String.fromCharCode(value);
            html = html.replace(key, value);
        });
        return html;
    }).removeClass('font-cxsecret');
}

function base64ToUint8Array(base64) {
    var data = window.atob(base64);
    var buffer = new Uint8Array(data.length);
    for (var i = 0; i < data.length; ++i) {
        buffer[i] = data.charCodeAt(i);
    }
    return buffer;
}

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址