UNPKG

3.34 kBJavaScriptView Raw
1#!/usr/bin/env node
2/*
3 Terminal Kit
4
5 Copyright (c) 2009 - 2020 Cédric Ronvel
6
7 The MIT License (MIT)
8
9 Permission is hereby granted, free of charge, to any person obtaining a copy
10 of this software and associated documentation files (the "Software"), to deal
11 in the Software without restriction, including without limitation the rights
12 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13 copies of the Software, and to permit persons to whom the Software is
14 furnished to do so, subject to the following conditions:
15
16 The above copyright notice and this permission notice shall be included in all
17 copies or substantial portions of the Software.
18
19 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
25 SOFTWARE.
26*/
27
28"use strict" ;
29
30
31
32var tree = require( 'tree-kit' ) ;
33var termkit = require( '../lib/termkit.js' ) ;
34var term = termkit.terminal ;
35
36
37
38term.clear() ;
39
40var screen = termkit.ScreenBufferHD.create( { dst: term , width: 60 , height: 20 } ) ;
41
42var clear ;
43
44clear = { attr: { bgColor: {
45 r: 127 ,
46 g: 127 ,
47 b: 127
48} } } ;
49clear = { attr: { bgColor: {
50 r: 255 ,
51 g: 255 ,
52 b: 255
53} } } ;
54clear = { attr: { bgColor: {
55 r: 13 ,
56 g: 10 ,
57 b: 20
58} } } ;
59
60screen.fill( clear ) ;
61
62var blue = termkit.ScreenBufferHD.create( { dst: screen , width: 12 , height: 6 } ) ;
63
64blue.fill( { attr: { bgColor: {
65 r: 130 ,
66 g: 100 ,
67 b: 200 ,
68 a: 125
69} } } ) ;
70
71blue.x = 8 ;
72blue.y = 4 ;
73
74var red = termkit.ScreenBufferHD.create( { dst: screen , width: 12 , height: 6 } ) ;
75
76red.fill( { attr: { bgColor: {
77 r: 230 ,
78 g: 100 ,
79 b: 0 ,
80 a: 125
81} } } ) ;
82
83red.x = 11 ;
84red.y = 18 ;
85
86var green = termkit.ScreenBufferHD.create( { dst: screen , width: 12 , height: 6 } ) ;
87
88green.fill( { attr: { bgColor: {
89 r: 130 ,
90 g: 200 ,
91 b: 80 ,
92 a: 125
93} } } ) ;
94
95green.x = 26 ;
96green.y = 5 ;
97
98var blendingOpt = {
99 opacity: 0.9 ,
100 //fn: termkit.ScreenBufferHD.blendFn.multiply
101 //fn: termkit.ScreenBufferHD.blendFn.screen
102 //fn: termkit.ScreenBufferHD.blendFn.overlay
103 //fn: termkit.ScreenBufferHD.blendFn.hardLight
104 //fn: termkit.ScreenBufferHD.blendFn.softLight
105} ;
106
107var redBlending = tree.extend( { own: true } , {} , blendingOpt ) ;
108var greenBlending = tree.extend( { own: true } , {} , blendingOpt ) ;
109var blueBlending = tree.extend( { own: true } , {} , blendingOpt ) ;
110
111
112
113var moved = 0 ;
114
115function moveRedraw() {
116 green.x -- ;
117 red.y -= 0.5 ;
118 redBlending.opacity += ( moved % 11 - 5 ) / 40 ;
119 greenBlending.opacity += ( moved % 9 - 4 ) / 30 ;
120 blueBlending.opacity += ( moved % 7 - 3 ) / 20 ;
121
122 // Clear the screen
123 screen.fill( clear ) ;
124
125 blue.draw( { blending: blueBlending } ) ;
126 green.draw( { blending: greenBlending } ) ;
127 red.draw( { blending: redBlending } ) ;
128
129 screen.draw( { delta: true } ) ;
130
131 if ( ++ moved <= 35 ) {
132 setTimeout( moveRedraw , 80 ) ;
133 }
134 else {
135 term.hideCursor( false ) ;
136 term.fullscreen( false ) ;
137 term.styleReset() ;
138 }
139}
140
141term.hideCursor() ;
142term.fullscreen() ;
143
144moveRedraw() ;
145
146