mirror of
https://github.com/overte-org/overte.git
synced 2025-08-08 13:58:51 +02:00
Merge branch 'master' of https://github.com/worklist/hifi into metavoxels
This commit is contained in:
commit
adc8d8dbbc
10 changed files with 169 additions and 22 deletions
BIN
interface/resources/styles/Inconsolata.otf
Normal file
BIN
interface/resources/styles/Inconsolata.otf
Normal file
Binary file not shown.
7
interface/resources/styles/log_dialog.qss
Normal file
7
interface/resources/styles/log_dialog.qss
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
QPlainTextEdit {
|
||||||
|
font-family: Inconsolata, Lucida Console, Andale Mono, Monaco;
|
||||||
|
font-size: 16px;
|
||||||
|
padding-left: 28px;
|
||||||
|
color: #333333;
|
||||||
|
background-color: #FFFFFF;
|
||||||
|
}
|
|
@ -143,11 +143,17 @@ Application::Application(int& argc, char** argv, timeval &startup_time) :
|
||||||
_pasteMode(false)
|
_pasteMode(false)
|
||||||
{
|
{
|
||||||
_applicationStartupTime = startup_time;
|
_applicationStartupTime = startup_time;
|
||||||
|
|
||||||
|
switchToResourcesParentIfRequired();
|
||||||
|
QFontDatabase::addApplicationFont("resources/styles/Inconsolata.otf");
|
||||||
_window->setWindowTitle("Interface");
|
_window->setWindowTitle("Interface");
|
||||||
|
|
||||||
qDebug( "[VERSION] Build sequence: %i", BUILD_VERSION);
|
|
||||||
|
|
||||||
qInstallMessageHandler(messageHandler);
|
qInstallMessageHandler(messageHandler);
|
||||||
|
|
||||||
|
// call Menu getInstance static method to set up the menu
|
||||||
|
_window->setMenuBar(Menu::getInstance());
|
||||||
|
|
||||||
|
qDebug("[VERSION] Build sequence: %i", BUILD_VERSION);
|
||||||
|
|
||||||
unsigned int listenPort = 0; // bind to an ephemeral port by default
|
unsigned int listenPort = 0; // bind to an ephemeral port by default
|
||||||
const char** constArgv = const_cast<const char**>(argv);
|
const char** constArgv = const_cast<const char**>(argv);
|
||||||
|
@ -173,16 +179,9 @@ Application::Application(int& argc, char** argv, timeval &startup_time) :
|
||||||
|
|
||||||
// network receive thread and voxel parsing thread are both controlled by the --nonblocking command line
|
// network receive thread and voxel parsing thread are both controlled by the --nonblocking command line
|
||||||
_enableProcessVoxelsThread = _enableNetworkThread = !cmdOptionExists(argc, constArgv, "--nonblocking");
|
_enableProcessVoxelsThread = _enableNetworkThread = !cmdOptionExists(argc, constArgv, "--nonblocking");
|
||||||
|
|
||||||
// setup QSettings
|
|
||||||
#ifdef Q_OS_MAC
|
|
||||||
QString resourcesPath = QCoreApplication::applicationDirPath() + "/../Resources";
|
|
||||||
#else
|
|
||||||
QString resourcesPath = QCoreApplication::applicationDirPath() + "/resources";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// read the ApplicationInfo.ini file for Name/Version/Domain information
|
// read the ApplicationInfo.ini file for Name/Version/Domain information
|
||||||
QSettings applicationInfo(resourcesPath + "/info/ApplicationInfo.ini", QSettings::IniFormat);
|
QSettings applicationInfo("resources/info/ApplicationInfo.ini", QSettings::IniFormat);
|
||||||
|
|
||||||
// set the associated application properties
|
// set the associated application properties
|
||||||
applicationInfo.beginGroup("INFO");
|
applicationInfo.beginGroup("INFO");
|
||||||
|
@ -191,11 +190,8 @@ Application::Application(int& argc, char** argv, timeval &startup_time) :
|
||||||
setApplicationVersion(applicationInfo.value("version").toString());
|
setApplicationVersion(applicationInfo.value("version").toString());
|
||||||
setOrganizationName(applicationInfo.value("organizationName").toString());
|
setOrganizationName(applicationInfo.value("organizationName").toString());
|
||||||
setOrganizationDomain(applicationInfo.value("organizationDomain").toString());
|
setOrganizationDomain(applicationInfo.value("organizationDomain").toString());
|
||||||
|
|
||||||
_settings = new QSettings(this);
|
_settings = new QSettings(this);
|
||||||
|
|
||||||
// call Menu getInstance static method to set up the menu
|
|
||||||
_window->setMenuBar(Menu::getInstance());
|
|
||||||
|
|
||||||
// Check to see if the user passed in a command line option for loading a local
|
// Check to see if the user passed in a command line option for loading a local
|
||||||
// Voxel File.
|
// Voxel File.
|
||||||
|
@ -251,6 +247,9 @@ Application::Application(int& argc, char** argv, timeval &startup_time) :
|
||||||
}
|
}
|
||||||
|
|
||||||
Application::~Application() {
|
Application::~Application() {
|
||||||
|
|
||||||
|
qInstallMessageHandler(NULL);
|
||||||
|
|
||||||
// make sure we don't call the idle timer any more
|
// make sure we don't call the idle timer any more
|
||||||
delete idleTimer;
|
delete idleTimer;
|
||||||
|
|
||||||
|
@ -4479,3 +4478,12 @@ void Application::loadScript() {
|
||||||
// restore the main window's active state
|
// restore the main window's active state
|
||||||
_window->activateWindow();
|
_window->activateWindow();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Application::toggleLogDialog() {
|
||||||
|
if (! _logDialog) {
|
||||||
|
_logDialog = new LogDialog(_glWidget);
|
||||||
|
_logDialog->show();
|
||||||
|
} else {
|
||||||
|
_logDialog->close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
#include <QTouchEvent>
|
#include <QTouchEvent>
|
||||||
#include <QList>
|
#include <QList>
|
||||||
|
#include <QPointer>
|
||||||
|
|
||||||
#include <NetworkPacket.h>
|
#include <NetworkPacket.h>
|
||||||
#include <NodeList.h>
|
#include <NodeList.h>
|
||||||
|
@ -67,6 +68,7 @@
|
||||||
#include "ui/VoxelStatsDialog.h"
|
#include "ui/VoxelStatsDialog.h"
|
||||||
#include "ui/RearMirrorTools.h"
|
#include "ui/RearMirrorTools.h"
|
||||||
#include "ui/LodToolsDialog.h"
|
#include "ui/LodToolsDialog.h"
|
||||||
|
#include "ui/LogDialog.h"
|
||||||
#include "ParticleTreeRenderer.h"
|
#include "ParticleTreeRenderer.h"
|
||||||
#include "ParticleEditHandle.h"
|
#include "ParticleEditHandle.h"
|
||||||
|
|
||||||
|
@ -222,7 +224,7 @@ public slots:
|
||||||
void decreaseVoxelSize();
|
void decreaseVoxelSize();
|
||||||
void increaseVoxelSize();
|
void increaseVoxelSize();
|
||||||
void loadScript();
|
void loadScript();
|
||||||
|
void toggleLogDialog();
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
|
|
||||||
|
@ -503,6 +505,8 @@ private:
|
||||||
|
|
||||||
std::vector<VoxelFade> _voxelFades;
|
std::vector<VoxelFade> _voxelFades;
|
||||||
std::vector<Avatar*> _avatarFades;
|
std::vector<Avatar*> _avatarFades;
|
||||||
|
|
||||||
|
QPointer<LogDialog> _logDialog;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* defined(__interface__Application__) */
|
#endif /* defined(__interface__Application__) */
|
||||||
|
|
|
@ -91,6 +91,7 @@ void LogDisplay::setCharacterSize(unsigned width, unsigned height) {
|
||||||
void LogDisplay::addMessage(const char* ptr) {
|
void LogDisplay::addMessage(const char* ptr) {
|
||||||
|
|
||||||
pthread_mutex_lock(& _mutex);
|
pthread_mutex_lock(& _mutex);
|
||||||
|
emit logReceived(ptr);
|
||||||
|
|
||||||
// T-pipe, if requested
|
// T-pipe, if requested
|
||||||
if (_stream != 0l) {
|
if (_stream != 0l) {
|
||||||
|
@ -118,7 +119,7 @@ void LogDisplay::addMessage(const char* ptr) {
|
||||||
_writePos = _chars;
|
_writePos = _chars;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (++_writtenInLine >= _lineLength || c == '\0') {
|
if (c == '\0') {
|
||||||
|
|
||||||
// new line? store its start to the line buffer and mark next line as empty
|
// new line? store its start to the line buffer and mark next line as empty
|
||||||
++_lastLinePos;
|
++_lastLinePos;
|
||||||
|
@ -148,13 +149,24 @@ void LogDisplay::addMessage(const char* ptr) {
|
||||||
|
|
||||||
// remember start position in character buffer for next line and reset character count
|
// remember start position in character buffer for next line and reset character count
|
||||||
_writeLineStartPos = _writePos;
|
_writeLineStartPos = _writePos;
|
||||||
_writtenInLine = 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pthread_mutex_unlock(& _mutex);
|
pthread_mutex_unlock(& _mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QStringList LogDisplay::getLogData() {
|
||||||
|
// wait for adding new log data whilr iterating over _lines
|
||||||
|
pthread_mutex_lock(& _mutex);
|
||||||
|
QStringList list;
|
||||||
|
int i = 0;
|
||||||
|
while (_lines[i] != *_lastLinePos) {
|
||||||
|
list.append(_lines[i++]);
|
||||||
|
}
|
||||||
|
pthread_mutex_unlock(& _mutex);
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Rendering
|
// Rendering
|
||||||
//
|
//
|
||||||
|
|
|
@ -14,7 +14,8 @@
|
||||||
|
|
||||||
#include "ui/TextRenderer.h"
|
#include "ui/TextRenderer.h"
|
||||||
|
|
||||||
class LogDisplay {
|
class LogDisplay : public QObject {
|
||||||
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
|
|
||||||
static LogDisplay instance;
|
static LogDisplay instance;
|
||||||
|
@ -43,6 +44,11 @@ public:
|
||||||
static unsigned const LINE_BUFFER_SIZE = 256; // number of lines that are buffered
|
static unsigned const LINE_BUFFER_SIZE = 256; // number of lines that are buffered
|
||||||
static unsigned const MAX_MESSAGE_LENGTH = 512; // maximum number of characters for a message
|
static unsigned const MAX_MESSAGE_LENGTH = 512; // maximum number of characters for a message
|
||||||
|
|
||||||
|
QStringList getLogData();
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void logReceived(QString message);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// use static 'instance' to access the single instance
|
// use static 'instance' to access the single instance
|
||||||
LogDisplay();
|
LogDisplay();
|
||||||
|
|
|
@ -265,7 +265,7 @@ Menu::Menu() :
|
||||||
|
|
||||||
addDisabledActionAndSeparator(viewMenu, "Stats");
|
addDisabledActionAndSeparator(viewMenu, "Stats");
|
||||||
addCheckableActionToQMenuAndActionHash(viewMenu, MenuOption::Stats, Qt::Key_Slash);
|
addCheckableActionToQMenuAndActionHash(viewMenu, MenuOption::Stats, Qt::Key_Slash);
|
||||||
addCheckableActionToQMenuAndActionHash(viewMenu, MenuOption::Log, Qt::CTRL | Qt::Key_L);
|
addActionToQMenuAndActionHash(viewMenu, MenuOption::Log, Qt::CTRL | Qt::Key_L, appInstance, SLOT(toggleLogDialog()));
|
||||||
addCheckableActionToQMenuAndActionHash(viewMenu, MenuOption::Oscilloscope, 0, true);
|
addCheckableActionToQMenuAndActionHash(viewMenu, MenuOption::Oscilloscope, 0, true);
|
||||||
addCheckableActionToQMenuAndActionHash(viewMenu, MenuOption::Bandwidth, 0, true);
|
addCheckableActionToQMenuAndActionHash(viewMenu, MenuOption::Bandwidth, 0, true);
|
||||||
addActionToQMenuAndActionHash(viewMenu, MenuOption::BandwidthDetails, 0, this, SLOT(bandwidthDetails()));
|
addActionToQMenuAndActionHash(viewMenu, MenuOption::BandwidthDetails, 0, this, SLOT(bandwidthDetails()));
|
||||||
|
|
|
@ -146,7 +146,6 @@ private:
|
||||||
int _boundaryLevelAdjust;
|
int _boundaryLevelAdjust;
|
||||||
QAction* _useVoxelShader;
|
QAction* _useVoxelShader;
|
||||||
int _maxVoxelPacketsPerSecond;
|
int _maxVoxelPacketsPerSecond;
|
||||||
|
|
||||||
QMenu* _activeScriptsMenu;
|
QMenu* _activeScriptsMenu;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
75
interface/src/ui/LogDialog.cpp
Normal file
75
interface/src/ui/LogDialog.cpp
Normal file
|
@ -0,0 +1,75 @@
|
||||||
|
//
|
||||||
|
// LogDialog.cpp
|
||||||
|
// interface
|
||||||
|
//
|
||||||
|
// Created by Stojce Slavkovski on 12/12/13.
|
||||||
|
// Copyright (c) 2013 High Fidelity, Inc. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <QDesktopWidget>
|
||||||
|
#include <QTextBlock>
|
||||||
|
#include <QtGui>
|
||||||
|
|
||||||
|
#include "SharedUtil.h"
|
||||||
|
#include "ui/LogDialog.h"
|
||||||
|
#include "LogDisplay.h"
|
||||||
|
|
||||||
|
const int INITIAL_WIDTH = 720;
|
||||||
|
const float INITIAL_HEIGHT_RATIO = 0.6f;
|
||||||
|
|
||||||
|
int cursorMeta = qRegisterMetaType<QTextCursor>("QTextCursor");
|
||||||
|
int blockMeta = qRegisterMetaType<QTextBlock>("QTextBlock");
|
||||||
|
|
||||||
|
LogDialog::LogDialog(QWidget* parent) : QDialog(parent, Qt::Dialog) {
|
||||||
|
|
||||||
|
setWindowTitle("Log");
|
||||||
|
|
||||||
|
_logTextBox = new QPlainTextEdit(this);
|
||||||
|
_logTextBox->setReadOnly(true);
|
||||||
|
_logTextBox->show();
|
||||||
|
|
||||||
|
switchToResourcesParentIfRequired();
|
||||||
|
QFile styleSheet("resources/styles/log_dialog.qss");
|
||||||
|
|
||||||
|
if (styleSheet.open(QIODevice::ReadOnly)) {
|
||||||
|
setStyleSheet(styleSheet.readAll());
|
||||||
|
}
|
||||||
|
|
||||||
|
QDesktopWidget desktop;
|
||||||
|
QRect screen = desktop.screenGeometry();
|
||||||
|
resize(INITIAL_WIDTH, static_cast<int>(screen.height() * INITIAL_HEIGHT_RATIO));
|
||||||
|
move(screen.center() - rect().center());
|
||||||
|
|
||||||
|
setAttribute(Qt::WA_DeleteOnClose);
|
||||||
|
}
|
||||||
|
|
||||||
|
LogDialog::~LogDialog() {
|
||||||
|
deleteLater();
|
||||||
|
}
|
||||||
|
|
||||||
|
void LogDialog::showEvent(QShowEvent *e) {
|
||||||
|
_logTextBox->clear();
|
||||||
|
|
||||||
|
pthread_mutex_lock(& _mutex);
|
||||||
|
QStringList _logData = LogDisplay::instance.getLogData();
|
||||||
|
|
||||||
|
connect(&LogDisplay::instance, &LogDisplay::logReceived, this, &LogDialog::appendLogLine);
|
||||||
|
for(int i = 0; i < _logData.size(); ++i) {
|
||||||
|
appendLogLine(_logData[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
pthread_mutex_unlock(& _mutex);
|
||||||
|
}
|
||||||
|
|
||||||
|
void LogDialog::resizeEvent(QResizeEvent *e) {
|
||||||
|
_logTextBox->resize(width(), height());
|
||||||
|
}
|
||||||
|
|
||||||
|
void LogDialog::appendLogLine(QString logLine) {
|
||||||
|
if (isVisible()) {
|
||||||
|
pthread_mutex_lock(& _mutex);
|
||||||
|
_logTextBox->appendPlainText(logLine.simplified());
|
||||||
|
pthread_mutex_unlock(& _mutex);
|
||||||
|
_logTextBox->ensureCursorVisible();
|
||||||
|
}
|
||||||
|
}
|
36
interface/src/ui/LogDialog.h
Normal file
36
interface/src/ui/LogDialog.h
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
//
|
||||||
|
// LogDialog.h
|
||||||
|
// interface
|
||||||
|
//
|
||||||
|
// Created by Stojce Slavkovski on 12/12/13.
|
||||||
|
// Copyright (c) 2013 High Fidelity, Inc. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef __interface__LogDialog__
|
||||||
|
#define __interface__LogDialog__
|
||||||
|
|
||||||
|
#include <QDialog>
|
||||||
|
#include <QPlainTextEdit>
|
||||||
|
|
||||||
|
class LogDialog : public QDialog {
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
LogDialog(QWidget* parent);
|
||||||
|
~LogDialog();
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
void appendLogLine(QString logLine);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void resizeEvent(QResizeEvent* e);
|
||||||
|
void showEvent(QShowEvent* e);
|
||||||
|
|
||||||
|
private:
|
||||||
|
QPlainTextEdit* _logTextBox;
|
||||||
|
pthread_mutex_t _mutex;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue