333
schangxiang@126.com
2025-09-19 18966e02fb573c7e2bb0c6426ed792b38b910940
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
<!DOCTYPE html>
<html>
<head>
    <title>FIGlet Example</title>
</head>
<body>
    <div>
        <label for="font">Font:</label>
        <select id="font">
            <option value="3D Diagonal">3D Diagonal</option>
            <option value="Dancing Font">Dancing Font</option>
            <option value="Ghost">Ghost</option>
            <option value="Graffiti">Graffiti</option>
            <option value="Patorjk's Cheese">Patorjk's Cheese</option>
            <option value="Standard" selected>Standard</option>
        </select>
    </div>
 
    <div>
        <label for="hLayout">Horizontal Layout:</label>
        <select id="hLayout">
            <option value="default" selected>Default</option>
            <option value="full">Full</option>
            <option value="fitted">Fitted</option>
            <option value="controlled smushing">Controlled Smushing</option>
            <option value="universal smushing">Universal Smushing</option>
        </select>
    </div>
 
    <div>
        <label for="vLayout">Vertical Layout:</label>
        <select id="vLayout">
            <option value="default" selected>Default</option>
            <option value="full">Full</option>
            <option value="fitted">Fitted</option>
            <option value="controlled smushing">Controlled Smushing</option>
            <option value="universal smushing">Universal Smushing</option>
        </select>
    </div>
 
    <div>
        <label for="inputText">Input:</label>
    </div>
    <textarea id="inputText" style="height:100px;width:200px;">test
123</textarea>
    <p></p>
    <div>
        <label for="outputFigDisplay">Output</label>
    </div>
    <div id="outputFigDisplay"></div>
    
    <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/fetch/1.0.0/fetch.min.js"></script>
    <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
    <script type="text/javascript" src="../../lib/figlet.js"></script>
    
<script>
 
if (window.location.protocol === 'file:') {
    alert('fetch APi does not support file: protocol.');
}
    
figlet.defaults({
    fontPath: '../../fonts'
});
 
/*
    Generates the put
*/
var update = function() {
    var fontName = $('#font option:selected').val(),
        inputText = $('#inputText').val(),
        vLayout = $('#vLayout option:selected').val(),
        hLayout = $('#hLayout option:selected').val();
 
    /*
        How to use the text output.
 
        The below call could also have been: figlet.text(...
    */
    figlet(inputText, {
        font: fontName,
        horizontalLayout: hLayout,
        verticalLayout: vLayout
    }, function(err, text) {
        if (err) {
            console.log('something went wrong...');
            console.dir(err);
            return;
        }
        $('#outputFigDisplay').html("<pre>" + text + "</pre>");
    });
 
    /*
        How to read the metadata for a font
    */
    /*
    figlet.metadata(fontName, function(err, options, headerComment) {
        if (err) {
            console.log('something went wrong...');
            console.dir(err);
            return;
        }
        console.dir(options);
        console.log(headerComment);
    });
    */
};
 
/*
    GUI Controls
*/
 
$('#hLayout').change(update);
$('#vLayout').change(update);
$('#font').change(update);
$('#inputText').keyup(update);
 
update(); // init
 
</script>
    
</body>
</html>