1
0
mirror of https://github.com/Swordfish90/cool-retro-term.git synced 2024-10-06 19:10:51 +01:00
cool-retro-term/qml/cool-old-term/main.qml

218 lines
7.9 KiB
QML
Raw Normal View History

/****************************************************************************
* This file is part of Terminal.
*
* Copyright (C) 2013 Pier Luigi Fiorini <pierluigi.fiorini@gmail.com>
*
* Author(s):
* Pier Luigi Fiorini
*
* $BEGIN_LICENSE:GPL2+$
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* $END_LICENSE$
***************************************************************************/
import QtQuick 2.1
2013-11-25 15:46:10 +00:00
import QtQuick.Window 2.0
import QtQuick.Controls 1.0
import QtGraphicalEffects 1.0
ApplicationWindow{
id: mainwindow
2013-11-23 15:09:46 +00:00
width: 1024
height: 768
title: qsTr("Terminal")
2013-11-23 16:34:11 +00:00
2013-11-25 15:46:10 +00:00
menuBar: MenuBar {
Menu {
2013-11-25 18:05:31 +00:00
title: qsTr("File")
MenuItem { text: "Close"; onTriggered: mainwindow.close()}
2013-11-25 15:46:10 +00:00
}
2013-11-25 18:05:31 +00:00
Menu {
title: qsTr("Edit")
MenuItem {
text: qsTr("Settings")
onTriggered: {
var component = Qt.createComponent("SettingsWindow.qml");
component.createObject(mainwindow);
}
}
}
2013-11-25 15:46:10 +00:00
}
visible: true
2013-11-23 15:09:46 +00:00
ShaderSettings{
id: shadersettings
}
ShaderEffectSource{
id: theSource
sourceItem: terminal
//sourceRect: Qt.rect(-20, -20, terminal.width + 40, terminal.height + 40)
2013-11-23 15:09:46 +00:00
}
ShaderEffect {
id: shadercontainer
2013-11-25 15:46:10 +00:00
anchors.fill: terminal
blending: true
z: 2
property color font_color: shadersettings.font_color
property color background_color: shadersettings.background_color
2013-11-23 15:09:46 +00:00
property variant source: theSource
property size txt_Size: Qt.size(terminal.width, terminal.height)
property real time: 0
property real noise_strength: shadersettings.noise_strength
property real screen_distorsion: shadersettings.screen_distortion
property real glowing_line_strength: shadersettings.glowing_line_strength
2013-11-25 18:05:31 +00:00
property real brightness: 1.0
2013-11-26 18:10:15 +00:00
NumberAnimation on brightness{
to: 1.0
duration: 300
onStopped: {to = 1 - Math.random() * shadersettings.brightness_flickering; start();}
running: true
}
property real deltay: 1.0 / terminal.height
property real deltax: 1.0 / terminal.width
2013-11-23 15:09:46 +00:00
//property real faulty_screen_prob: shadersettings.faulty_screen_prob
NumberAnimation on time{
from: -1
to: 100
duration: 5000
2013-11-23 16:34:11 +00:00
2013-11-23 15:09:46 +00:00
loops: Animation.Infinite
}
fragmentShader: "
uniform sampler2D source;
uniform highp float qt_Opacity;
uniform highp float time;
uniform highp vec2 txt_Size;
varying highp vec2 qt_TexCoord0;
uniform highp vec4 font_color;
uniform highp vec4 background_color;
2013-11-25 18:05:31 +00:00
2013-11-23 15:09:46 +00:00
uniform highp float noise_strength;
uniform highp float screen_distorsion;
uniform highp float glowing_line_strength;
2013-11-26 18:10:15 +00:00
uniform highp float brightness;
2013-11-25 18:05:31 +00:00
uniform highp float deltax;
uniform highp float deltay;
2013-11-23 15:09:46 +00:00
float rand(vec2 co, float time){
return fract(sin(dot(co.xy ,vec2(0.37898 * time ,0.78233))) * 437.5875453);
2013-11-23 15:09:46 +00:00
}
float stepNoise(vec2 p){
vec2 newP = p * txt_Size*0.25;
return rand(floor(newP), time);
}
float getScanlineIntensity(vec2 pos){
2013-11-25 15:46:10 +00:00
return 0.5 + abs(sin(pos.y * txt_Size.y)) * 0.5;
2013-11-23 15:09:46 +00:00
}
vec2 distortCoordinates(vec2 coords){
vec2 cc = coords - vec2(0.5);
float dist = dot(cc, cc) * screen_distorsion;
return (coords + cc * (1.0 + dist) * dist);
}
float randomPass(vec2 coords){
return fract(smoothstep(-0.2, 0.0, coords.y - time * 0.03)) * glowing_line_strength;
}
vec4 blurredColor(sampler2D source, vec2 coords){
vec4 sum = vec4(0.0);
sum += texture2D(source, coords - vec2(-deltax, -deltay)) * 0.11;
sum += texture2D(source, coords - vec2(-deltax, 0.0)) * 0.11;
sum += texture2D(source, coords - vec2(-deltax, +deltay)) * 0.11;
sum += texture2D(source, coords - vec2(0.0, -deltay)) * 0.11;
sum += texture2D(source, coords - vec2(0.0, 0.0)) * 0.11;
sum += texture2D(source, coords - vec2(0.0, +deltay)) * 0.11;
sum += texture2D(source, coords - vec2(+deltax, -deltay)) * 0.11;
sum += texture2D(source, coords - vec2(+deltax, 0.0)) * 0.11;
sum += texture2D(source, coords - vec2(+deltax, +deltay)) * 0.11;
return sum;
}
2013-11-23 15:09:46 +00:00
void main() {
vec2 coords = distortCoordinates(qt_TexCoord0);
//Emulate faulty screen
//coords.x = coords.x + sin(coords.y * 5.0) * 0.05 * step(faulty_screen_prob, rand(txt_Size, floor(time)));
//vec4 color = texture2D(source, coords);
2013-11-26 18:10:15 +00:00
vec4 color = blurredColor(source, coords) * brightness;
float scanline_alpha = getScanlineIntensity(coords);
float inside = step(0.0, coords.x) * step(-1.0, -coords.x) * step(0.0, coords.y) * step(-1.0, -coords.y);
2013-11-23 15:09:46 +00:00
float noise = stepNoise(coords) * noise_strength;
float randomPass = randomPass(coords) * glowing_line_strength;
vec4 added_color = (noise + randomPass) * font_color;
vec4 finalColor = color + added_color;
finalColor = mix(finalColor, background_color, 1.0 - scanline_alpha);
gl_FragColor = vec4(finalColor.rgb * inside, inside);
2013-11-23 15:09:46 +00:00
}"
}
Rectangle{
z: 1
anchors.fill: parent
color: "black"
}
2013-11-25 15:46:10 +00:00
Image{
id: frame
2013-11-25 18:05:31 +00:00
source: "../images/frame.png"
2013-11-25 15:46:10 +00:00
anchors.centerIn: parent
width: parent.width * 1.05
height: parent.height * 1.05
z: 10
visible: true
opacity: shadersettings.ambient_light
}
TerminalScreen {
id: terminal
2013-11-25 15:46:10 +00:00
anchors.centerIn: parent
width: mainwindow.width * 0.95
height: mainwindow.height * 0.93
visible: false
//FIXME: Ugly forced clear terminal at the beginning
Component.onCompleted: terminal.screen.sendKey("l", 76, 67108864);
}
2013-11-25 15:46:10 +00:00
RadialGradient{
z: 4
anchors.fill: parent
cached: true
opacity: 0.25
gradient: Gradient{
GradientStop{position: 0.0; color: shadersettings.font_color}
GradientStop{position: 1.0; color: shadersettings.background_color}
}
}
}