Plebified settings

This commit is contained in:
Tamius Han 2019-06-02 02:44:02 +02:00
parent 66f9c1b9e3
commit 2e6d33bc79
4 changed files with 104 additions and 4 deletions

View File

@ -1,6 +1,6 @@
<template> <template>
<div class="button center-text flex" <div class="button center-text flex"
:class="{'selected': selected, 'w24': fixedWidth, 'flex-auto': !fixedWidth }" :class="{'setting-selected': selected, 'w24': fixedWidth, 'flex-auto': !fixedWidth }"
> >
{{label}} {{label}}
</div> </div>

View File

@ -112,7 +112,7 @@ var ExtensionConf = {
sampleWidth: 8, // we take a sample this wide for edge detection sampleWidth: 8, // we take a sample this wide for edge detection
detectionThreshold: 4, // sample needs to have this many non-black pixels to be a valid edge detectionThreshold: 4, // sample needs to have this many non-black pixels to be a valid edge
confirmationThreshold: 1, // confirmationThreshold: 1, //
singleSideConfirmationThreshold: 4, // we need this much edges (out of all samples, not just edges) in order singleSideConfirmationThreshold: 3, // we need this much edges (out of all samples, not just edges) in order
// to confirm an edge in case there's no edges on top or bottom (other // to confirm an edge in case there's no edges on top or bottom (other
// than logo, of course) // than logo, of course)
logoThreshold: 0.15, // if edge candidate sits with count greater than this*all_samples, it can't be logo logoThreshold: 0.15, // if edge candidate sits with count greater than this*all_samples, it can't be logo

View File

@ -1,5 +1,62 @@
<template> <template>
<div> <div>
<h2>Quick settings</h2>
<div class="flex label-secondary form-label">
How often should autodetection check for changes?
</div>
<div class="description">
Shorter intervals (left side of the slider) are more responsive to changes in aspect ratio detections,
but requires more system resources.
</div>
<div class="indent">
<div class="flex flex-row row-padding">
<div class="flex flex-input">
<input type="range"
:value="Math.log(settings.active.arDetect.timers.playing)"
@change="setArCheckFrequency($event.target.value)"
min="2.3"
max="9.3"
step="any"
/>
</div>
</div>
</div>
<div class="flex label-secondary form-label">
How sensitive should aspect ratio detection be?
</div>
<div class="description">
Sensitive preset will allow the extension to correct aspect ratio even when letterbox isn't clearly defined. This
can result in aspect ratio detection correcting aspect ratio when it shouldn't.
Accurate preset will take a more conservative approach to determining aspect ratio, correcting aspect ratio only when
it's absolutely sure that the aspect ratio needs changing. This option results in fewer incorrect aspect ratio corrections,
but can also result in extension not correcting aspect ratio when it should.
Strict preset is 'accurate' on stereoids.
</div>
<div class="flex flex-row row-padding">
<Button label="Sensitive"
:selected="sensitivity === 'sensitive'"
@click.native="setConfirmationThresholds('sensitive')"
/>
<Button label="Balanced"
:selected="sensitivity === 'balanced'"
@click.native="setConfirmationThresholds('balanced')"
/>
<Button label="Accurate"
:selected="getSensitivity() === 'accurate'"
@click.native="setConfirmationThresholds('accurate')"
/>
<Button label="Strict"
:selected="getSensitivity() === 'strict'"
@click.native="setConfirmationThresholds('strict')"
/>
<Button label="Custom (changed below)"
:selected="getSensitivity() === 'user-defined'"
/>
</div>
<h2>Autodetection settings in detail</h2>
<div> <div>
<input type="checkbox" <input type="checkbox"
v-model="showAdvancedOptions" v-model="showAdvancedOptions"
@ -482,15 +539,23 @@
</template> </template>
<script> <script>
import Button from '../common/components/Button.vue';
export default { export default {
components: {
Button,
},
props: ['settings'], props: ['settings'],
data() { data() {
return { return {
showAdvancedOptions: false, showAdvancedOptions: false,
fallbackModeAvailable: false, fallbackModeAvailable: false,
sensitivity: 'sensitive',
} }
}, },
created() { created() {
this.sensitivity = this.getSensitivity();
const canvas = document.createElement('canvas'); const canvas = document.createElement('canvas');
canvas.width = 10; canvas.width = 10;
canvas.height = 10; canvas.height = 10;
@ -504,7 +569,42 @@ export default {
} }
}, },
methods: { methods: {
setArCheckFrequency(event) {
this.settings.active.arDetect.timers.playing = Math.floor(Math.pow(Math.E, event));
},
getSensitivity() {
if (this.settings.active.arDetect.edgeDetection.singleSideConfirmationThreshold === 3 && this.settings.active.arDetect.edgeDetection.confirmationThreshold === 1) {
return 'sensitive';
}
if (this.settings.active.arDetect.edgeDetection.singleSideConfirmationThreshold === 5 && this.settings.active.arDetect.edgeDetection.confirmationThreshold === 2) {
return 'balanced';
}
if (this.settings.active.arDetect.edgeDetection.singleSideConfirmationThreshold === 7 && this.settings.active.arDetect.edgeDetection.confirmationThreshold === 3) {
return 'accurate';
}
if (this.settings.active.arDetect.edgeDetection.singleSideConfirmationThreshold === 16 && this.settings.active.arDetect.edgeDetection.confirmationThreshold === 8) {
return 'strict';
}
return 'user-defined';
},
setConfirmationThresholds(sens) {
console.log("setting conf treshold", sens)
if (sens === 'sensitive') {
this.settings.active.arDetect.edgeDetection.singleSideConfirmationThreshold = 3;
this.settings.active.arDetect.edgeDetection.confirmationThreshold = 1;
} else if (sens === 'balanced') {
this.settings.active.arDetect.edgeDetection.singleSideConfirmationThreshold = 5;
this.settings.active.arDetect.edgeDetection.confirmationThreshold = 2;
} else if (sens === 'accurate') {
this.settings.active.arDetect.edgeDetection.singleSideConfirmationThreshold = 7;
this.settings.active.arDetect.edgeDetection.confirmationThreshold = 3;
} else if (sens === 'strict') {
this.settings.active.arDetect.edgeDetection.singleSideConfirmationThreshold = 16;
this.settings.active.arDetect.edgeDetection.confirmationThreshold = 8;
}
this.sensitivity = this.getSensitivity();
}
} }
} }
</script> </script>

View File

@ -193,8 +193,8 @@ small {
.selected, .setting-selected { .selected, .setting-selected {
color: $selected-color; color: $selected-color !important;
background-color: $background-selected; background-color: $background-selected !important;
} }
.selected-tab { .selected-tab {