mirror of
https://github.com/overte-org/overte.git
synced 2025-04-07 00:52:58 +02:00
Update grid rendering to fade from center location rather than distance from camera
This commit is contained in:
parent
a8de290482
commit
b6b2388d41
4 changed files with 39 additions and 5 deletions
|
@ -5,14 +5,23 @@
|
|||
// fragment shader
|
||||
//
|
||||
// Created by Andrzej Kapolka on 1/21/14.
|
||||
// Update by Ryan Huffman on 12/30/14.
|
||||
// Copyright 2013 High Fidelity, Inc.
|
||||
//
|
||||
// Distributed under the Apache License, Version 2.0.
|
||||
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||
//
|
||||
|
||||
varying vec2 modelCoords;
|
||||
|
||||
// Squared distance from center of 1x1 square to an edge along a single axis (0.5 * 0.5)
|
||||
const float SQUARED_DISTANCE_TO_EDGE = 0.25;
|
||||
|
||||
void main(void) {
|
||||
// use the standard exponential fog calculation
|
||||
const float FOG_DENSITY = 0.5;
|
||||
gl_FragColor = vec4(gl_Color.rgb, exp(-FOG_DENSITY / gl_FragCoord.w));
|
||||
// Squared distance from grid center - this assumes the grid lines are from
|
||||
// 0.0 ... 1.0 in model space.
|
||||
float sqDist = pow(modelCoords.x - 0.5, 2) + pow(modelCoords.y - 0.5, 2);
|
||||
float alpha = max(0, SQUARED_DISTANCE_TO_EDGE - sqDist) / SQUARED_DISTANCE_TO_EDGE;
|
||||
alpha *= gl_Color.a;
|
||||
gl_FragColor = vec4(gl_Color.rgb, alpha);
|
||||
}
|
||||
|
|
20
interface/resources/shaders/grid.vert
Normal file
20
interface/resources/shaders/grid.vert
Normal file
|
@ -0,0 +1,20 @@
|
|||
#version 120
|
||||
|
||||
//
|
||||
// grid.vert
|
||||
// vertex shader
|
||||
//
|
||||
// Created by Ryan Huffman on 12/30/14
|
||||
// Copyright 2014 High Fidelity, Inc.
|
||||
//
|
||||
// Distributed under the Apache License, Version 2.0.
|
||||
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||
//
|
||||
|
||||
varying vec2 modelCoords;
|
||||
|
||||
void main(void) {
|
||||
modelCoords = gl_Vertex.xy;
|
||||
gl_Position = gl_ModelViewProjectionMatrix * vec4(gl_Vertex.xy, 0, 1);
|
||||
gl_FrontColor = gl_Color;
|
||||
}
|
|
@ -148,6 +148,7 @@ MetavoxelEditor::MetavoxelEditor() :
|
|||
return;
|
||||
}
|
||||
|
||||
_gridProgram.addShaderFromSourceFile(QGLShader::Vertex, PathUtils::resourcesPath() + "shaders/grid.vert");
|
||||
_gridProgram.addShaderFromSourceFile(QGLShader::Fragment, PathUtils::resourcesPath() + "shaders/grid.frag");
|
||||
_gridProgram.link();
|
||||
}
|
||||
|
|
|
@ -37,6 +37,10 @@ void Grid3DOverlay::render(RenderArgs* args) {
|
|||
}
|
||||
|
||||
if (!_gridProgram.isLinked()) {
|
||||
if (!_gridProgram.addShaderFromSourceFile(QGLShader::Vertex, PathUtils::resourcesPath() + "shaders/grid.vert")) {
|
||||
qDebug() << "Failed to compile: " + _gridProgram.log();
|
||||
return;
|
||||
}
|
||||
if (!_gridProgram.addShaderFromSourceFile(QGLShader::Fragment, PathUtils::resourcesPath() + "shaders/grid.frag")) {
|
||||
qDebug() << "Failed to compile: " + _gridProgram.log();
|
||||
return;
|
||||
|
@ -70,8 +74,8 @@ void Grid3DOverlay::render(RenderArgs* args) {
|
|||
xColor color = getColor();
|
||||
glm::vec3 position = getPosition();
|
||||
|
||||
const int MINOR_GRID_DIVISIONS = 100;
|
||||
const int MAJOR_GRID_DIVISIONS = 50;
|
||||
const int MINOR_GRID_DIVISIONS = 200;
|
||||
const int MAJOR_GRID_DIVISIONS = 100;
|
||||
const float MAX_COLOR = 255.0f;
|
||||
|
||||
|
||||
|
|
Loading…
Reference in a new issue