Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Q
qgroundcontrol
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Valentin Platzgummer
qgroundcontrol
Commits
c170e356
Commit
c170e356
authored
Jul 30, 2012
by
Lorenz Meier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Some VT100 hacks, fixed MAVLink inclusion path
parent
4281a113
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
65 additions
and
18 deletions
+65
-18
style-mission.css
images/style-mission.css
+4
-2
qgroundcontrol.pro
qgroundcontrol.pro
+1
-1
QGCMAVLink.h
src/comm/QGCMAVLink.h
+5
-11
DebugConsole.cc
src/ui/DebugConsole.cc
+51
-4
DebugConsole.h
src/ui/DebugConsole.h
+4
-0
No files found.
images/style-mission.css
View file @
c170e356
...
...
@@ -34,13 +34,15 @@ border: 1px solid #777777;
}
QTextEdit
{
border
:
1px
solid
#777777
;
border
:
1px
solid
#777777
;
border-radius
:
2px
;
}
QPlainTextEdit
{
border
:
1px
solid
#777777
;
border
:
1px
solid
#777777
;
border-radius
:
2px
;
font-family
:
"Monospace"
;
font
:
large
;
}
QComboBox
{
...
...
qgroundcontrol.pro
View file @
c170e356
...
...
@@ -111,7 +111,7 @@ isEmpty(MAVLINK_CONF) {
INCLUDEPATH
+=
$$
MAVLINKPATH
/
common
}
else
{
INCLUDEPATH
+=
$$
MAVLINKPATH
/
$$
MAVLINK_CONF
DEFINES
+=
'MAVLINK_CONF="$${MAVLINK_CONF}.h"'
#
DEFINES
+=
'MAVLINK_CONF="$${MAVLINK_CONF}.h"'
DEFINES
+=
$$
sprintf
(
'QGC_USE_%1_MESSAGES'
,
$$
upper
(
$$
MAVLINK_CONF
))
}
...
...
src/comm/QGCMAVLink.h
View file @
c170e356
...
...
@@ -30,19 +30,13 @@ This file is part of the QGROUNDCONTROL project
#ifndef QGCMAVLINK_H
#define QGCMAVLINK_H
#include <
../../mavlink/include/mavlink/v1.0/mavlink_types
.h>
#include <
mavlink
.h>
#ifdef QGC_USE_PIXHAWK_MESSAGES
#include <../../mavlink/include/mavlink/v1.0/pixhawk/pixhawk.h> //please do not delete this.
#else
#include <../../mavlink/include/mavlink/v1.0/common/mavlink.h>
#endif
#ifdef MAVLINK_CONF
#define MY_MACRO(x) <x>
#include MY_MACRO(MAVLINK_CONF)
//#ifdef MAVLINK_CONF
//#define MY_MACRO(x) <x>
//#include MY_MACRO(MAVLINK_CONF)
//#include MAVLINK_CONF
#endif
//
#endif
#endif // QGCMAVLINK_H
...
...
src/ui/DebugConsole.cc
View file @
c170e356
...
...
@@ -74,12 +74,13 @@ DebugConsole::DebugConsole(QWidget *parent) :
m_ui
->
receiveText
->
setMaximumBlockCount
(
500
);
// Allow to wrap everywhere
m_ui
->
receiveText
->
setWordWrapMode
(
QTextOption
::
WrapAnywhere
);
// // Set monospace font
// m_ui->receiveText->setFontFamily("Monospace");
// Enable 10 Hz output
//connect(&lineBufferTimer, SIGNAL(timeout()), this, SLOT(showData()));
//lineBufferTimer.setInterval(100); // 100 Hz
//lineBufferTimer.start();
loadSettings
();
// Enable traffic measurements
...
...
@@ -392,20 +393,65 @@ void DebugConsole::receiveBytes(LinkInterface* link, QByteArray bytes)
// Convert to ASCII for readability
if
(
convertToAscii
)
{
if
((
byte
<=
32
)
||
(
byte
>
126
))
if
(
escReceived
)
{
if
(
escIndex
<
sizeof
(
escBytes
))
{
escBytes
[
escIndex
]
=
byte
;
//qDebug() << "GOT BYTE ESC:" << byte;
if
(
/*escIndex == 1 && */
escBytes
[
escIndex
]
==
0x48
)
{
// Handle sequence
// for this one, clear all text
m_ui
->
receiveText
->
clear
();
escReceived
=
false
;
}
else
if
(
/*escIndex == 1 && */
escBytes
[
escIndex
]
==
0x4b
)
{
// Handle sequence
// for this one, do nothing
escReceived
=
false
;
}
else
if
(
byte
==
0x5b
)
{
// Do nothing, this is still a valid escape sequence
}
else
{
escReceived
=
false
;
}
}
else
{
// Obviously something went wrong, reset
escReceived
=
false
;
escIndex
=
0
;
}
}
else
if
((
byte
<=
32
)
||
(
byte
>
126
))
{
switch
(
byte
)
{
case
(
unsigned
char
)
'\n'
:
// Accept line feed
if
(
lastByte
!=
'\r'
)
// Do not break line again for
CR+LF
if
(
lastByte
!=
'\r'
)
// Do not break line again for
LF+CR
str
.
append
(
byte
);
// only break line for single LF or CR bytes
break
;
case
(
unsigned
char
)
' '
:
// space of any type means don't add another on hex output
case
(
unsigned
char
)
'\t'
:
// Accept tab
case
(
unsigned
char
)
'\r'
:
// Catch and carriage return
str
.
append
(
byte
);
if
(
lastByte
!=
'\n'
)
// Do not break line again for CR+LF
str
.
append
(
byte
);
// only break line for single LF or CR bytes
lastSpace
=
1
;
break
;
/* VT100 emulation (partially */
case
0x1b
:
// ESC received
escReceived
=
true
;
escIndex
=
0
;
//qDebug() << "GOT ESC";
break
;
case
0x08
:
// BS (backspace) received
// Do nothing for now
break
;
default:
// Append replacement character (box) if char is not ASCII
// str.append(QChar(QChar::ReplacementCharacter));
QString
str2
;
...
...
@@ -414,6 +460,7 @@ void DebugConsole::receiveBytes(LinkInterface* link, QByteArray bytes)
else
str2
.
sprintf
(
" 0x%02x "
,
byte
);
str
.
append
(
str2
);
lastSpace
=
1
;
escReceived
=
false
;
break
;
}
}
...
...
src/ui/DebugConsole.h
View file @
c170e356
...
...
@@ -121,6 +121,10 @@ protected:
bool
autoHold
;
///< Auto-hold mode sets view into hold if the data rate is too high
int
bytesToIgnore
;
///< Number of bytes to ignore
char
lastByte
;
///< The last received byte
bool
escReceived
;
///< True if received ESC char in ASCII mode
int
escIndex
;
///< Index of bytes since ESC was received
char
escBytes
[
5
];
///< Escape-following bytes
bool
terminalReceived
;
///< Terminal sequence received
QList
<
QString
>
sentBytes
;
///< Transmitted bytes, per transmission
QByteArray
holdBuffer
;
///< Buffer where bytes are stored during hold-enable
QString
lineBuffer
;
///< Buffere where bytes are stored before writing them out
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment