commit
4e3d6527dd
@ -329,7 +329,7 @@ class dsp(object):
|
|||||||
logger.debug("secondary command (fft) = %s", secondary_command_fft)
|
logger.debug("secondary command (fft) = %s", secondary_command_fft)
|
||||||
|
|
||||||
self.secondary_process_fft = subprocess.Popen(
|
self.secondary_process_fft = subprocess.Popen(
|
||||||
secondary_command_fft, stdout=subprocess.PIPE, shell=True, preexec_fn=os.setpgrp, env=my_env
|
secondary_command_fft, stdout=subprocess.PIPE, shell=True, start_new_session=True, env=my_env
|
||||||
)
|
)
|
||||||
self.output.send_output(
|
self.output.send_output(
|
||||||
"secondary_fft",
|
"secondary_fft",
|
||||||
@ -341,7 +341,7 @@ class dsp(object):
|
|||||||
# it would block if not read. by piping it to devnull, we avoid a potential pitfall here.
|
# it would block if not read. by piping it to devnull, we avoid a potential pitfall here.
|
||||||
secondary_output = subprocess.DEVNULL if self.isPacket() else subprocess.PIPE
|
secondary_output = subprocess.DEVNULL if self.isPacket() else subprocess.PIPE
|
||||||
self.secondary_process_demod = subprocess.Popen(
|
self.secondary_process_demod = subprocess.Popen(
|
||||||
secondary_command_demod, stdout=secondary_output, shell=True, preexec_fn=os.setpgrp, env=my_env
|
secondary_command_demod, stdout=secondary_output, shell=True, start_new_session=True, env=my_env
|
||||||
)
|
)
|
||||||
self.secondary_processes_running = True
|
self.secondary_processes_running = True
|
||||||
|
|
||||||
@ -669,7 +669,7 @@ class dsp(object):
|
|||||||
my_env["CSDR_PRINT_BUFSIZES"] = "1"
|
my_env["CSDR_PRINT_BUFSIZES"] = "1"
|
||||||
|
|
||||||
out = subprocess.PIPE if self.output.supports_type("audio") else subprocess.DEVNULL
|
out = subprocess.PIPE if self.output.supports_type("audio") else subprocess.DEVNULL
|
||||||
self.process = subprocess.Popen(command, stdout=out, shell=True, preexec_fn=os.setpgrp, env=my_env)
|
self.process = subprocess.Popen(command, stdout=out, shell=True, start_new_session=True, env=my_env)
|
||||||
|
|
||||||
def watch_thread():
|
def watch_thread():
|
||||||
rc = self.process.wait()
|
rc = self.process.wait()
|
||||||
|
@ -304,34 +304,9 @@ input[type=range]:focus::-ms-fill-upper
|
|||||||
color: #ff6262;
|
color: #ff6262;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*#webrx-freq-show
|
|
||||||
{
|
|
||||||
visibility: hidden;
|
|
||||||
position: absolute;
|
|
||||||
top: 0px;
|
|
||||||
left: 0px;
|
|
||||||
padding: 5px;
|
|
||||||
font-weight: bold;
|
|
||||||
border-radius: 10px;
|
|
||||||
-moz-border-radius: 10px;
|
|
||||||
background-color: #999999;
|
|
||||||
color: White;
|
|
||||||
z-index:9999; /*should be higher?
|
|
||||||
|
|
||||||
}*/
|
|
||||||
|
|
||||||
/* removed non-free fonts like that: */
|
|
||||||
/*@font-face {
|
|
||||||
font-family: 'unibody_8_pro_regregular';
|
|
||||||
src: url('../gfx/unibody8pro-regular-webfont.eot');
|
|
||||||
src: url('../gfx/unibody8pro-regular-webfont.ttf');
|
|
||||||
font-weight: normal;
|
|
||||||
font-style: normal;
|
|
||||||
}*/
|
|
||||||
|
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: 'expletus-sans-medium';
|
font-family: 'roboto-mono';
|
||||||
src: url('../gfx/font-expletus-sans/ExpletusSans-Medium.ttf');
|
src: url('../fonts/RobotoMono-Regular.ttf');
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
}
|
}
|
||||||
@ -341,7 +316,7 @@ input[type=range]:focus::-ms-fill-upper
|
|||||||
width: 100%;
|
width: 100%;
|
||||||
text-align: left;
|
text-align: left;
|
||||||
font-size: 16pt;
|
font-size: 16pt;
|
||||||
font-family: 'expletus-sans-medium';
|
font-family: 'roboto-mono';
|
||||||
padding: 0;
|
padding: 0;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
line-height:22px;
|
line-height:22px;
|
||||||
@ -354,7 +329,7 @@ input[type=range]:focus::-ms-fill-upper
|
|||||||
text-align: left;
|
text-align: left;
|
||||||
font-size: 10pt;
|
font-size: 10pt;
|
||||||
color: #AAA;
|
color: #AAA;
|
||||||
font-family: 'expletus-sans-medium';
|
font-family: 'roboto-mono';
|
||||||
margin-bottom: 5px;
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -646,7 +621,7 @@ img.openwebrx-mirror-img
|
|||||||
float: right;
|
float: right;
|
||||||
margin-right: 5px;
|
margin-right: 5px;
|
||||||
margin-top: 24px;
|
margin-top: 24px;
|
||||||
font-family: 'expletus-sans-medium';
|
font-family: 'roboto-mono';
|
||||||
}
|
}
|
||||||
|
|
||||||
.openwebrx-overlay {
|
.openwebrx-overlay {
|
||||||
|
BIN
htdocs/fonts/RobotoMono-Regular.ttf
Normal file
BIN
htdocs/fonts/RobotoMono-Regular.ttf
Normal file
Binary file not shown.
Binary file not shown.
@ -1,93 +0,0 @@
|
|||||||
Copyright (c) 2011, Jasper de Waard (jasper@designtown.nl),
|
|
||||||
with Reserved Font Name "Expletus Sans".
|
|
||||||
This Font Software is licensed under the SIL Open Font License, Version 1.1.
|
|
||||||
This license is copied below, and is also available with a FAQ at:
|
|
||||||
http://scripts.sil.org/OFL
|
|
||||||
|
|
||||||
|
|
||||||
-----------------------------------------------------------
|
|
||||||
SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
|
|
||||||
-----------------------------------------------------------
|
|
||||||
|
|
||||||
PREAMBLE
|
|
||||||
The goals of the Open Font License (OFL) are to stimulate worldwide
|
|
||||||
development of collaborative font projects, to support the font creation
|
|
||||||
efforts of academic and linguistic communities, and to provide a free and
|
|
||||||
open framework in which fonts may be shared and improved in partnership
|
|
||||||
with others.
|
|
||||||
|
|
||||||
The OFL allows the licensed fonts to be used, studied, modified and
|
|
||||||
redistributed freely as long as they are not sold by themselves. The
|
|
||||||
fonts, including any derivative works, can be bundled, embedded,
|
|
||||||
redistributed and/or sold with any software provided that any reserved
|
|
||||||
names are not used by derivative works. The fonts and derivatives,
|
|
||||||
however, cannot be released under any other type of license. The
|
|
||||||
requirement for fonts to remain under this license does not apply
|
|
||||||
to any document created using the fonts or their derivatives.
|
|
||||||
|
|
||||||
DEFINITIONS
|
|
||||||
"Font Software" refers to the set of files released by the Copyright
|
|
||||||
Holder(s) under this license and clearly marked as such. This may
|
|
||||||
include source files, build scripts and documentation.
|
|
||||||
|
|
||||||
"Reserved Font Name" refers to any names specified as such after the
|
|
||||||
copyright statement(s).
|
|
||||||
|
|
||||||
"Original Version" refers to the collection of Font Software components as
|
|
||||||
distributed by the Copyright Holder(s).
|
|
||||||
|
|
||||||
"Modified Version" refers to any derivative made by adding to, deleting,
|
|
||||||
or substituting -- in part or in whole -- any of the components of the
|
|
||||||
Original Version, by changing formats or by porting the Font Software to a
|
|
||||||
new environment.
|
|
||||||
|
|
||||||
"Author" refers to any designer, engineer, programmer, technical
|
|
||||||
writer or other person who contributed to the Font Software.
|
|
||||||
|
|
||||||
PERMISSION & CONDITIONS
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
a copy of the Font Software, to use, study, copy, merge, embed, modify,
|
|
||||||
redistribute, and sell modified and unmodified copies of the Font
|
|
||||||
Software, subject to the following conditions:
|
|
||||||
|
|
||||||
1) Neither the Font Software nor any of its individual components,
|
|
||||||
in Original or Modified Versions, may be sold by itself.
|
|
||||||
|
|
||||||
2) Original or Modified Versions of the Font Software may be bundled,
|
|
||||||
redistributed and/or sold with any software, provided that each copy
|
|
||||||
contains the above copyright notice and this license. These can be
|
|
||||||
included either as stand-alone text files, human-readable headers or
|
|
||||||
in the appropriate machine-readable metadata fields within text or
|
|
||||||
binary files as long as those fields can be easily viewed by the user.
|
|
||||||
|
|
||||||
3) No Modified Version of the Font Software may use the Reserved Font
|
|
||||||
Name(s) unless explicit written permission is granted by the corresponding
|
|
||||||
Copyright Holder. This restriction only applies to the primary font name as
|
|
||||||
presented to the users.
|
|
||||||
|
|
||||||
4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
|
|
||||||
Software shall not be used to promote, endorse or advertise any
|
|
||||||
Modified Version, except to acknowledge the contribution(s) of the
|
|
||||||
Copyright Holder(s) and the Author(s) or with their explicit written
|
|
||||||
permission.
|
|
||||||
|
|
||||||
5) The Font Software, modified or unmodified, in part or in whole,
|
|
||||||
must be distributed entirely under this license, and must not be
|
|
||||||
distributed under any other license. The requirement for fonts to
|
|
||||||
remain under this license does not apply to any document created
|
|
||||||
using the Font Software.
|
|
||||||
|
|
||||||
TERMINATION
|
|
||||||
This license becomes null and void if any of the above conditions are
|
|
||||||
not met.
|
|
||||||
|
|
||||||
DISCLAIMER
|
|
||||||
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
|
|
||||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
|
|
||||||
OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
|
|
||||||
COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
|
||||||
INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
|
|
||||||
DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
||||||
FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
|
|
||||||
OTHER DEALINGS IN THE FONT SOFTWARE.
|
|
@ -31,6 +31,7 @@
|
|||||||
<script src="static/lib/AudioEngine.js"></script>
|
<script src="static/lib/AudioEngine.js"></script>
|
||||||
<script src="static/lib/ProgressBar.js"></script>
|
<script src="static/lib/ProgressBar.js"></script>
|
||||||
<script src="static/lib/Measurement.js"></script>
|
<script src="static/lib/Measurement.js"></script>
|
||||||
|
<script src="static/lib/FrequencyDisplay.js"></script>
|
||||||
<link rel="stylesheet" type="text/css" href="static/lib/nanoscroller.css" />
|
<link rel="stylesheet" type="text/css" href="static/lib/nanoscroller.css" />
|
||||||
<link rel="stylesheet" type="text/css" href="static/css/openwebrx.css" />
|
<link rel="stylesheet" type="text/css" href="static/css/openwebrx.css" />
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
|
@ -9,7 +9,7 @@ function BookmarkBar() {
|
|||||||
me.$container.find('.bookmark').removeClass('selected');
|
me.$container.find('.bookmark').removeClass('selected');
|
||||||
var b = $bookmark.data();
|
var b = $bookmark.data();
|
||||||
if (!b || !b.frequency || (!b.modulation && !b.digital_modulation)) return;
|
if (!b || !b.frequency || (!b.modulation && !b.digital_modulation)) return;
|
||||||
demodulator_set_offset_frequency(0, b.frequency - center_freq);
|
demodulators[0].set_offset_frequency(b.frequency - center_freq);
|
||||||
if (b.modulation) {
|
if (b.modulation) {
|
||||||
demodulator_analog_replace(b.modulation);
|
demodulator_analog_replace(b.modulation);
|
||||||
} else if (b.digital_modulation) {
|
} else if (b.digital_modulation) {
|
||||||
|
61
htdocs/lib/FrequencyDisplay.js
Normal file
61
htdocs/lib/FrequencyDisplay.js
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
function FrequencyDisplay(element) {
|
||||||
|
this.element = $(element);
|
||||||
|
this.digits = [];
|
||||||
|
this.digitContainer = $('<span>');
|
||||||
|
this.element.html([this.digitContainer, $('<span> MHz</span>')]);
|
||||||
|
this.decimalSeparator = (0.1).toLocaleString().substring(1, 2);
|
||||||
|
this.setFrequency(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
FrequencyDisplay.prototype.setFrequency = function(freq) {
|
||||||
|
this.frequency = freq;
|
||||||
|
var formatted = (freq / 1e6).toLocaleString(undefined, {maximumFractionDigits: 4, minimumFractionDigits: 4});
|
||||||
|
var children = this.digitContainer.children();
|
||||||
|
for (var i = 0; i < formatted.length; i++) {
|
||||||
|
if (!this.digits[i]) {
|
||||||
|
this.digits[i] = $('<span>');
|
||||||
|
var before = children[i];
|
||||||
|
if (before) {
|
||||||
|
$(before).after(this.digits[i]);
|
||||||
|
} else {
|
||||||
|
this.digitContainer.append(this.digits[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.digits[i][(isNaN(formatted[i]) ? 'remove' : 'add') + 'Class']('digit');
|
||||||
|
this.digits[i].html(formatted[i]);
|
||||||
|
}
|
||||||
|
while (this.digits.length > formatted.length) {
|
||||||
|
this.digits.pop().remove();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function TuneableFrequencyDisplay(element) {
|
||||||
|
FrequencyDisplay.call(this, element);
|
||||||
|
this.setupEvents();
|
||||||
|
}
|
||||||
|
|
||||||
|
TuneableFrequencyDisplay.prototype = new FrequencyDisplay();
|
||||||
|
|
||||||
|
TuneableFrequencyDisplay.prototype.setupEvents = function() {
|
||||||
|
var me = this;
|
||||||
|
this.element.on('wheel', function(e){
|
||||||
|
e.preventDefault();
|
||||||
|
e.stopPropagation();
|
||||||
|
|
||||||
|
var index = me.digitContainer.find('.digit').index(e.target);
|
||||||
|
if (index < 0) return;
|
||||||
|
|
||||||
|
var delta = 10 ** (Math.floor(Math.log10(me.frequency)) - index);
|
||||||
|
if (e.originalEvent.deltaY > 0) delta *= -1;
|
||||||
|
var newFrequency = me.frequency + delta;
|
||||||
|
|
||||||
|
me.listeners.forEach(function(l) {
|
||||||
|
l(newFrequency);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
this.listeners = [];
|
||||||
|
};
|
||||||
|
|
||||||
|
TuneableFrequencyDisplay.prototype.onFrequencyChange = function(listener){
|
||||||
|
this.listeners.push(listener);
|
||||||
|
};
|
@ -334,7 +334,6 @@ function demod_envelope_where_clicked(x, drag_ranges, key_modifiers) { // Check
|
|||||||
//******* class Demodulator *******
|
//******* class Demodulator *******
|
||||||
// this can be used as a base class for ANY demodulator
|
// this can be used as a base class for ANY demodulator
|
||||||
Demodulator = function (offset_frequency) {
|
Demodulator = function (offset_frequency) {
|
||||||
//console.log("this too");
|
|
||||||
this.offset_frequency = offset_frequency;
|
this.offset_frequency = offset_frequency;
|
||||||
this.envelope = {};
|
this.envelope = {};
|
||||||
this.color = demodulators_get_next_color();
|
this.color = demodulators_get_next_color();
|
||||||
@ -357,11 +356,7 @@ Demodulator.draggable_ranges = {
|
|||||||
|
|
||||||
demodulator_response_time = 50;
|
demodulator_response_time = 50;
|
||||||
|
|
||||||
//in ms; if we don't limit the number of SETs sent to the server, audio will underrun (possibly output buffer is cleared on SETs in GNU Radio
|
|
||||||
|
|
||||||
function Demodulator_default_analog(offset_frequency, subtype) {
|
function Demodulator_default_analog(offset_frequency, subtype) {
|
||||||
//console.log("hopefully this happens");
|
|
||||||
//http://stackoverflow.com/questions/4152931/javascript-inheritance-call-super-constructor-or-use-prototype-chain
|
|
||||||
Demodulator.call(this, offset_frequency);
|
Demodulator.call(this, offset_frequency);
|
||||||
this.subtype = subtype;
|
this.subtype = subtype;
|
||||||
this.filter = {
|
this.filter = {
|
||||||
@ -512,7 +507,7 @@ function Demodulator_default_analog(offset_frequency, subtype) {
|
|||||||
mkenvelopes(this.visible_range);
|
mkenvelopes(this.visible_range);
|
||||||
this.parent.set();
|
this.parent.set();
|
||||||
//will have to change this when changing to multi-demodulator mode:
|
//will have to change this when changing to multi-demodulator mode:
|
||||||
e("webrx-actual-freq").innerHTML = format_frequency("{x} MHz", center_freq + this.parent.offset_frequency, 1e6, 4);
|
tunedFrequencyDisplay.setFrequency(center_freq + this.parent.offset_frequency);
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -565,12 +560,12 @@ function demodulator_analog_replace(subtype, for_digital) { //this function shou
|
|||||||
update_digitalvoice_panels("openwebrx-panel-metadata-" + subtype);
|
update_digitalvoice_panels("openwebrx-panel-metadata-" + subtype);
|
||||||
}
|
}
|
||||||
|
|
||||||
function demodulator_set_offset_frequency(which, to_what) {
|
Demodulator.prototype.set_offset_frequency = function(to_what) {
|
||||||
if (to_what > bandwidth / 2 || to_what < -bandwidth / 2) return;
|
if (to_what > bandwidth / 2 || to_what < -bandwidth / 2) return;
|
||||||
demodulators[0].offset_frequency = Math.round(to_what);
|
this.offset_frequency = Math.round(to_what);
|
||||||
demodulators[0].set();
|
this.set();
|
||||||
mkenvelopes(get_visible_freq_range());
|
mkenvelopes(get_visible_freq_range());
|
||||||
$("#webrx-actual-freq").html(format_frequency("{x} MHz", center_freq + to_what, 1e6, 4));
|
tunedFrequencyDisplay.setFrequency(center_freq + to_what);
|
||||||
}
|
}
|
||||||
|
|
||||||
function waterfallWidth() {
|
function waterfallWidth() {
|
||||||
@ -584,9 +579,11 @@ function waterfallWidth() {
|
|||||||
|
|
||||||
var scale_ctx;
|
var scale_ctx;
|
||||||
var scale_canvas;
|
var scale_canvas;
|
||||||
|
var tunedFrequencyDisplay;
|
||||||
|
var mouseFrequencyDisplay;
|
||||||
|
|
||||||
function scale_setup() {
|
function scale_setup() {
|
||||||
e("webrx-actual-freq").innerHTML = format_frequency("{x} MHz", canvas_get_frequency(window.innerWidth / 2), 1e6, 4);
|
tunedFrequencyDisplay.setFrequency(canvas_get_frequency(window.innerWidth / 2));
|
||||||
scale_canvas = e("openwebrx-scale-canvas");
|
scale_canvas = e("openwebrx-scale-canvas");
|
||||||
scale_ctx = scale_canvas.getContext("2d");
|
scale_ctx = scale_canvas.getContext("2d");
|
||||||
scale_canvas.addEventListener("mousedown", scale_canvas_mousedown, false);
|
scale_canvas.addEventListener("mousedown", scale_canvas_mousedown, false);
|
||||||
@ -633,14 +630,14 @@ function scale_canvas_mousemove(evt) {
|
|||||||
else if (scale_canvas_drag_params.drag) {
|
else if (scale_canvas_drag_params.drag) {
|
||||||
//call the drag_move for all demodulators (and they will decide if they're dragged)
|
//call the drag_move for all demodulators (and they will decide if they're dragged)
|
||||||
for (i = 0; i < demodulators.length; i++) event_handled |= demodulators[i].envelope.drag_move(evt.pageX);
|
for (i = 0; i < demodulators.length; i++) event_handled |= demodulators[i].envelope.drag_move(evt.pageX);
|
||||||
if (!event_handled) demodulator_set_offset_frequency(0, scale_offset_freq_from_px(evt.pageX));
|
if (!event_handled) demodulators[0].set_offset_frequency(scale_offset_freq_from_px(evt.pageX));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function frequency_container_mousemove(evt) {
|
function frequency_container_mousemove(evt) {
|
||||||
var frequency = center_freq + scale_offset_freq_from_px(evt.pageX);
|
var frequency = center_freq + scale_offset_freq_from_px(evt.pageX);
|
||||||
e("webrx-mouse-freq").innerHTML = format_frequency("{x} MHz", frequency, 1e6, 4);
|
mouseFrequencyDisplay.setFrequency(frequency);
|
||||||
}
|
}
|
||||||
|
|
||||||
function scale_canvas_end_drag(x) {
|
function scale_canvas_end_drag(x) {
|
||||||
@ -649,7 +646,7 @@ function scale_canvas_end_drag(x) {
|
|||||||
scale_canvas_drag_params.mouse_down = false;
|
scale_canvas_drag_params.mouse_down = false;
|
||||||
var event_handled = false;
|
var event_handled = false;
|
||||||
for (var i = 0; i < demodulators.length; i++) event_handled |= demodulators[i].envelope.drag_end();
|
for (var i = 0; i < demodulators.length; i++) event_handled |= demodulators[i].envelope.drag_end();
|
||||||
if (!event_handled) demodulator_set_offset_frequency(0, scale_offset_freq_from_px(x));
|
if (!event_handled) demodulators[0].set_offset_frequency(scale_offset_freq_from_px(x));
|
||||||
}
|
}
|
||||||
|
|
||||||
function scale_canvas_mouseup(evt) {
|
function scale_canvas_mouseup(evt) {
|
||||||
@ -916,8 +913,9 @@ function canvas_mousemove(evt) {
|
|||||||
mkscale();
|
mkscale();
|
||||||
bookmarks.position();
|
bookmarks.position();
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
mouseFrequencyDisplay.setFrequency(canvas_get_frequency(relativeX));
|
||||||
}
|
}
|
||||||
else e("webrx-mouse-freq").innerHTML = format_frequency("{x} MHz", canvas_get_frequency(relativeX), 1e6, 4);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function canvas_container_mouseleave() {
|
function canvas_container_mouseleave() {
|
||||||
@ -929,7 +927,7 @@ function canvas_mouseup(evt) {
|
|||||||
var relativeX = get_relative_x(evt);
|
var relativeX = get_relative_x(evt);
|
||||||
|
|
||||||
if (!canvas_drag) {
|
if (!canvas_drag) {
|
||||||
demodulator_set_offset_frequency(0, canvas_get_freq_offset(relativeX));
|
demodulators[0].set_offset_frequency(canvas_get_freq_offset(relativeX));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
canvas_end_drag();
|
canvas_end_drag();
|
||||||
@ -1534,7 +1532,7 @@ function initialize_demodulator() {
|
|||||||
demodulator_analog_replace(starting_mod);
|
demodulator_analog_replace(starting_mod);
|
||||||
if (starting_offset_frequency) {
|
if (starting_offset_frequency) {
|
||||||
demodulators[0].offset_frequency = starting_offset_frequency;
|
demodulators[0].offset_frequency = starting_offset_frequency;
|
||||||
e("webrx-actual-freq").innerHTML = format_frequency("{x} MHz", center_freq + starting_offset_frequency, 1e6, 4);
|
tunedFrequencyDisplay.setFrequency(center_freq + starting_offset_frequency);
|
||||||
demodulators[0].set();
|
demodulators[0].set();
|
||||||
mkscale();
|
mkscale();
|
||||||
}
|
}
|
||||||
@ -1787,6 +1785,11 @@ function openwebrx_init() {
|
|||||||
secondary_demod_init();
|
secondary_demod_init();
|
||||||
digimodes_init();
|
digimodes_init();
|
||||||
initPanels();
|
initPanels();
|
||||||
|
tunedFrequencyDisplay = new TuneableFrequencyDisplay($('#webrx-actual-freq'));
|
||||||
|
tunedFrequencyDisplay.onFrequencyChange(function(f) {
|
||||||
|
demodulators[0].set_offset_frequency(f - center_freq);
|
||||||
|
});
|
||||||
|
mouseFrequencyDisplay = new FrequencyDisplay($('#webrx-mouse-freq'));
|
||||||
window.addEventListener("resize", openwebrx_resize);
|
window.addEventListener("resize", openwebrx_resize);
|
||||||
check_top_bar_congestion();
|
check_top_bar_congestion();
|
||||||
init_header();
|
init_header();
|
||||||
|
@ -145,13 +145,13 @@ class SdrSource(ABC):
|
|||||||
if len(cmd) > 1:
|
if len(cmd) > 1:
|
||||||
# multiple commands with pipes
|
# multiple commands with pipes
|
||||||
cmd = "|".join(cmd)
|
cmd = "|".join(cmd)
|
||||||
self.process = subprocess.Popen(cmd, shell=True, preexec_fn=os.setpgrp)
|
self.process = subprocess.Popen(cmd, shell=True, start_new_session=True)
|
||||||
else:
|
else:
|
||||||
# single command
|
# single command
|
||||||
cmd = cmd[0]
|
cmd = cmd[0]
|
||||||
# preexec_fn can go as soon as there's no piped commands left
|
# start_new_session can go as soon as there's no piped commands left
|
||||||
# the os.killpg call must be replaced with something more reasonable at the same time
|
# the os.killpg call must be replaced with something more reasonable at the same time
|
||||||
self.process = subprocess.Popen(shlex.split(cmd), preexec_fn=os.setpgrp)
|
self.process = subprocess.Popen(shlex.split(cmd), start_new_session=True)
|
||||||
logger.info("Started sdr source: " + cmd)
|
logger.info("Started sdr source: " + cmd)
|
||||||
|
|
||||||
available = False
|
available = False
|
||||||
|
Loading…
Reference in New Issue
Block a user