Compare commits
19 Commits
0.4.0
...
86886fb5d9
Author | SHA1 | Date | |
---|---|---|---|
86886fb5d9
|
|||
f262d5f931
|
|||
12dc5c8ef9
|
|||
9aaee4c183
|
|||
2017617614
|
|||
21d4afcedb
|
|||
8347e9fbb2
|
|||
8d17a52f00
|
|||
4668da3223
|
|||
a3b30c4543
|
|||
3f358c8b7d
|
|||
7b7c15ad27
|
|||
a95692196e
|
|||
68d9c4bb66
|
|||
1ece1e443d
|
|||
1eb7ea4a93
|
|||
e766c6d465
|
|||
1f9f646f51
|
|||
d88586739a
|
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
fyne-cross/*
|
||||||
|
ffmpeg/*
|
13
README.md
13
README.md
@@ -25,9 +25,9 @@
|
|||||||
* fyne-cross linux --icon icon.png --app-id "." -name "gui-for-ffmpeg"
|
* fyne-cross linux --icon icon.png --app-id "." -name "gui-for-ffmpeg"
|
||||||
7. Создаться папка **fyne-cross/bin** и там будет созданна папка с тем названием под которую Вы компилировали приложения (linux-amd64 или windows-amd64).
|
7. Создаться папка **fyne-cross/bin** и там будет созданна папка с тем названием под которую Вы компилировали приложения (linux-amd64 или windows-amd64).
|
||||||
8. В папку **fyne-cross/bin/linux-amd64** или **fyne-cross/bin/windows-amd64** копируете:
|
8. В папку **fyne-cross/bin/linux-amd64** или **fyne-cross/bin/windows-amd64** копируете:
|
||||||
* src/icon.png
|
* icon.png
|
||||||
* src/data
|
* data
|
||||||
* src/languages
|
* languages
|
||||||
* LICENSE
|
* LICENSE
|
||||||
* LICENSE-3RD-PARTY.txt
|
* LICENSE-3RD-PARTY.txt
|
||||||
<p><strong>Структура должна получиться такая:</strong></p>
|
<p><strong>Структура должна получиться такая:</strong></p>
|
||||||
@@ -35,8 +35,11 @@
|
|||||||
|
|
||||||
## Работа с переводами:
|
## Работа с переводами:
|
||||||
1. go install -v github.com/nicksnyder/go-i18n/v2/goi18n@latest
|
1. go install -v github.com/nicksnyder/go-i18n/v2/goi18n@latest
|
||||||
2. goi18n merge -sourceLanguage ru -outdir languages languages/active.\*.toml languages/translate.\*.toml
|
3. Создаём файл languages/translate.\*.toml
|
||||||
3. В файлах **languages/translate.\*.toml** переводим текст на нужный язык
|
|
||||||
4. goi18n merge -sourceLanguage ru -outdir languages languages/active.\*.toml languages/translate.\*.toml
|
4. goi18n merge -sourceLanguage ru -outdir languages languages/active.\*.toml languages/translate.\*.toml
|
||||||
|
5. В файлах **languages/translate.\*.toml** переводим текст на нужный язык
|
||||||
|
6. goi18n merge -sourceLanguage ru -outdir languages languages/active.\*.toml languages/translate.\*.toml
|
||||||
|
|
||||||
|
___где * подставляем нужный язык___
|
||||||
|
|
||||||
Более подробно можно почитать тут: https://github.com/nicksnyder/go-i18n
|
Более подробно можно почитать тут: https://github.com/nicksnyder/go-i18n
|
@@ -1,21 +1,18 @@
|
|||||||
package convertor
|
package convertor
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
|
||||||
"fyne.io/fyne/v2"
|
|
||||||
"fyne.io/fyne/v2/canvas"
|
"fyne.io/fyne/v2/canvas"
|
||||||
"fyne.io/fyne/v2/container"
|
"fyne.io/fyne/v2/container"
|
||||||
"fyne.io/fyne/v2/storage"
|
|
||||||
"fyne.io/fyne/v2/widget"
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
"github.com/nicksnyder/go-i18n/v2/i18n"
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
"image/color"
|
"image/color"
|
||||||
"path/filepath"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type ViewContract interface {
|
type ViewContract interface {
|
||||||
Main(
|
Main(
|
||||||
runConvert func(setting HandleConvertSetting),
|
formConversion view.ConversionContract,
|
||||||
)
|
)
|
||||||
SelectFFPath(
|
SelectFFPath(
|
||||||
ffmpegPath string,
|
ffmpegPath string,
|
||||||
@@ -30,183 +27,18 @@ type View struct {
|
|||||||
app kernel.AppContract
|
app kernel.AppContract
|
||||||
}
|
}
|
||||||
|
|
||||||
type HandleConvertSetting struct {
|
|
||||||
VideoFileInput kernel.File
|
|
||||||
DirectoryForSave string
|
|
||||||
OverwriteOutputFiles bool
|
|
||||||
}
|
|
||||||
|
|
||||||
type enableFormConversionStruct struct {
|
|
||||||
fileVideoForConversion *widget.Button
|
|
||||||
buttonForSelectedDir *widget.Button
|
|
||||||
form *widget.Form
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewView(app kernel.AppContract) *View {
|
func NewView(app kernel.AppContract) *View {
|
||||||
return &View{
|
return &View{
|
||||||
app: app,
|
app: app,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v View) Main(
|
func (v View) Main(formConversion view.ConversionContract) {
|
||||||
runConvert func(setting HandleConvertSetting),
|
|
||||||
) {
|
|
||||||
form := &widget.Form{}
|
|
||||||
|
|
||||||
conversionMessage := canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
|
||||||
conversionMessage.TextSize = 16
|
|
||||||
conversionMessage.TextStyle = fyne.TextStyle{Bold: true}
|
|
||||||
|
|
||||||
fileVideoForConversion, fileVideoForConversionMessage, fileInput := v.getButtonFileVideoForConversion(form, conversionMessage)
|
|
||||||
buttonForSelectedDir, buttonForSelectedDirMessage, pathToSaveDirectory := v.getButtonForSelectingDirectoryForSaving()
|
|
||||||
|
|
||||||
isOverwriteOutputFiles := false
|
|
||||||
checkboxOverwriteOutputFilesTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "checkboxOverwriteOutputFilesTitle",
|
|
||||||
})
|
|
||||||
checkboxOverwriteOutputFiles := widget.NewCheck(checkboxOverwriteOutputFilesTitle, func(b bool) {
|
|
||||||
isOverwriteOutputFiles = b
|
|
||||||
})
|
|
||||||
|
|
||||||
form.Items = []*widget.FormItem{
|
|
||||||
{
|
|
||||||
Text: v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "fileVideoForConversionTitle"}),
|
|
||||||
Widget: fileVideoForConversion,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Widget: container.NewHScroll(fileVideoForConversionMessage),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Text: v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "buttonForSelectedDirTitle"}),
|
|
||||||
Widget: buttonForSelectedDir,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Widget: container.NewHScroll(buttonForSelectedDirMessage),
|
|
||||||
},
|
|
||||||
{
|
|
||||||
Widget: checkboxOverwriteOutputFiles,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
form.SubmitText = v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "converterVideoFilesSubmitTitle",
|
|
||||||
})
|
|
||||||
|
|
||||||
enableFormConversionStruct := enableFormConversionStruct{
|
|
||||||
fileVideoForConversion: fileVideoForConversion,
|
|
||||||
buttonForSelectedDir: buttonForSelectedDir,
|
|
||||||
form: form,
|
|
||||||
}
|
|
||||||
|
|
||||||
form.OnSubmit = func() {
|
|
||||||
if len(*pathToSaveDirectory) == 0 {
|
|
||||||
showConversionMessage(conversionMessage, errors.New(v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "errorSelectedFolderSave",
|
|
||||||
})))
|
|
||||||
enableFormConversion(enableFormConversionStruct)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
conversionMessage.Text = ""
|
|
||||||
|
|
||||||
fileVideoForConversion.Disable()
|
|
||||||
buttonForSelectedDir.Disable()
|
|
||||||
form.Disable()
|
|
||||||
|
|
||||||
setting := HandleConvertSetting{
|
|
||||||
VideoFileInput: *fileInput,
|
|
||||||
DirectoryForSave: *pathToSaveDirectory,
|
|
||||||
OverwriteOutputFiles: isOverwriteOutputFiles,
|
|
||||||
}
|
|
||||||
runConvert(setting)
|
|
||||||
enableFormConversion(enableFormConversionStruct)
|
|
||||||
|
|
||||||
fileVideoForConversionMessage.Text = ""
|
|
||||||
form.Disable()
|
|
||||||
}
|
|
||||||
|
|
||||||
converterVideoFilesTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
converterVideoFilesTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
MessageID: "converterVideoFilesTitle",
|
MessageID: "converterVideoFilesTitle",
|
||||||
})
|
})
|
||||||
v.app.GetWindow().SetContent(widget.NewCard(converterVideoFilesTitle, "", container.NewVBox(form, conversionMessage)))
|
v.app.GetWindow().SetContent(widget.NewCard(converterVideoFilesTitle, "", container.NewVScroll(formConversion.GetContent())))
|
||||||
form.Disable()
|
formConversion.AfterViewContent()
|
||||||
}
|
|
||||||
|
|
||||||
func (v View) getButtonFileVideoForConversion(form *widget.Form, conversionMessage *canvas.Text) (*widget.Button, *canvas.Text, *kernel.File) {
|
|
||||||
fileInput := &kernel.File{}
|
|
||||||
|
|
||||||
fileVideoForConversionMessage := canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
|
||||||
fileVideoForConversionMessage.TextSize = 16
|
|
||||||
fileVideoForConversionMessage.TextStyle = fyne.TextStyle{Bold: true}
|
|
||||||
|
|
||||||
buttonTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "choose",
|
|
||||||
})
|
|
||||||
|
|
||||||
var locationURI fyne.ListableURI
|
|
||||||
|
|
||||||
button := widget.NewButton(buttonTitle, func() {
|
|
||||||
v.app.GetWindow().NewFileOpen(func(r fyne.URIReadCloser, err error) {
|
|
||||||
if err != nil {
|
|
||||||
fileVideoForConversionMessage.Text = err.Error()
|
|
||||||
setStringErrorStyle(fileVideoForConversionMessage)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if r == nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
fileInput.Path = r.URI().Path()
|
|
||||||
fileInput.Name = r.URI().Name()
|
|
||||||
fileInput.Ext = r.URI().Extension()
|
|
||||||
|
|
||||||
fileVideoForConversionMessage.Text = r.URI().Path()
|
|
||||||
setStringSuccessStyle(fileVideoForConversionMessage)
|
|
||||||
|
|
||||||
form.Enable()
|
|
||||||
conversionMessage.Text = ""
|
|
||||||
|
|
||||||
listableURI := storage.NewFileURI(filepath.Dir(r.URI().Path()))
|
|
||||||
locationURI, err = storage.ListerForURI(listableURI)
|
|
||||||
}, locationURI)
|
|
||||||
})
|
|
||||||
|
|
||||||
return button, fileVideoForConversionMessage, fileInput
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v View) getButtonForSelectingDirectoryForSaving() (button *widget.Button, buttonMessage *canvas.Text, dirPath *string) {
|
|
||||||
buttonMessage = canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
|
||||||
buttonMessage.TextSize = 16
|
|
||||||
buttonMessage.TextStyle = fyne.TextStyle{Bold: true}
|
|
||||||
|
|
||||||
path := ""
|
|
||||||
dirPath = &path
|
|
||||||
|
|
||||||
buttonTitle := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
|
||||||
MessageID: "choose",
|
|
||||||
})
|
|
||||||
|
|
||||||
var locationURI fyne.ListableURI
|
|
||||||
|
|
||||||
button = widget.NewButton(buttonTitle, func() {
|
|
||||||
v.app.GetWindow().NewFolderOpen(func(r fyne.ListableURI, err error) {
|
|
||||||
if err != nil {
|
|
||||||
buttonMessage.Text = err.Error()
|
|
||||||
setStringErrorStyle(buttonMessage)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if r == nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
path = r.Path()
|
|
||||||
|
|
||||||
buttonMessage.Text = r.Path()
|
|
||||||
setStringSuccessStyle(buttonMessage)
|
|
||||||
locationURI, _ = storage.ListerForURI(r)
|
|
||||||
|
|
||||||
}, locationURI)
|
|
||||||
})
|
|
||||||
|
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func setStringErrorStyle(text *canvas.Text) {
|
func setStringErrorStyle(text *canvas.Text) {
|
||||||
@@ -218,14 +50,3 @@ func setStringSuccessStyle(text *canvas.Text) {
|
|||||||
text.Color = color.RGBA{R: 49, G: 127, B: 114, A: 255}
|
text.Color = color.RGBA{R: 49, G: 127, B: 114, A: 255}
|
||||||
text.Refresh()
|
text.Refresh()
|
||||||
}
|
}
|
||||||
|
|
||||||
func showConversionMessage(conversionMessage *canvas.Text, err error) {
|
|
||||||
conversionMessage.Text = err.Error()
|
|
||||||
setStringErrorStyle(conversionMessage)
|
|
||||||
}
|
|
||||||
|
|
||||||
func enableFormConversion(enableFormConversionStruct enableFormConversionStruct) {
|
|
||||||
enableFormConversionStruct.fileVideoForConversion.Enable()
|
|
||||||
enableFormConversionStruct.buttonForSelectedDir.Enable()
|
|
||||||
enableFormConversionStruct.form.Enable()
|
|
||||||
}
|
|
||||||
|
444
convertor/view/conversion.go
Normal file
444
convertor/view/conversion.go
Normal file
@@ -0,0 +1,444 @@
|
|||||||
|
package view
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"fyne.io/fyne/v2"
|
||||||
|
"fyne.io/fyne/v2/canvas"
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/storage"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view/form_items"
|
||||||
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel/encoder"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
"image/color"
|
||||||
|
"path/filepath"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ConversionContract interface {
|
||||||
|
GetContent() fyne.CanvasObject
|
||||||
|
AfterViewContent()
|
||||||
|
}
|
||||||
|
|
||||||
|
type Conversion struct {
|
||||||
|
app kernel.AppContract
|
||||||
|
form *form
|
||||||
|
conversionMessage *canvas.Text
|
||||||
|
fileForConversion *fileForConversion
|
||||||
|
directoryForSaving *directoryForSaving
|
||||||
|
overwriteOutputFiles *overwriteOutputFiles
|
||||||
|
selectEncoder *selectEncoder
|
||||||
|
runConvert func(setting HandleConvertSetting)
|
||||||
|
}
|
||||||
|
|
||||||
|
type HandleConvertSetting struct {
|
||||||
|
FileInput kernel.File
|
||||||
|
DirectoryForSave string
|
||||||
|
OverwriteOutputFiles bool
|
||||||
|
Format string
|
||||||
|
Encoder encoder2.EncoderContract
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewConversion(app kernel.AppContract, formats encoder.ConvertorFormatsContract, runConvert func(setting HandleConvertSetting)) *Conversion {
|
||||||
|
conversionMessage := canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
||||||
|
conversionMessage.TextSize = 16
|
||||||
|
conversionMessage.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
fileForConversion := newFileForConversion(app)
|
||||||
|
directoryForSaving := newDirectoryForSaving(app)
|
||||||
|
overwriteOutputFiles := newOverwriteOutputFiles(app)
|
||||||
|
selectEncoder := newSelectEncoder(app, formats)
|
||||||
|
|
||||||
|
items := []*widget.FormItem{
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "fileForConversionTitle"}),
|
||||||
|
Widget: fileForConversion.button,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Widget: container.NewHScroll(fileForConversion.message),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "buttonForSelectedDirTitle"}),
|
||||||
|
Widget: directoryForSaving.button,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Widget: container.NewHScroll(directoryForSaving.message),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Widget: overwriteOutputFiles.checkbox,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Widget: selectEncoder.SelectFileType,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "selectFormat"}),
|
||||||
|
Widget: selectEncoder.SelectFormat,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "selectEncoder"}),
|
||||||
|
Widget: selectEncoder.SelectEncoder,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
form := newForm(app, items)
|
||||||
|
|
||||||
|
return &Conversion{
|
||||||
|
app: app,
|
||||||
|
form: form,
|
||||||
|
conversionMessage: conversionMessage,
|
||||||
|
fileForConversion: fileForConversion,
|
||||||
|
directoryForSaving: directoryForSaving,
|
||||||
|
overwriteOutputFiles: overwriteOutputFiles,
|
||||||
|
selectEncoder: selectEncoder,
|
||||||
|
runConvert: runConvert,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) GetContent() fyne.CanvasObject {
|
||||||
|
c.form.form.OnSubmit = c.submit
|
||||||
|
c.fileForConversion.AddChangeCallback(c.selectFileForConversion)
|
||||||
|
c.selectEncoder.AddChangeCallback(c.changeEncoder)
|
||||||
|
if c.selectEncoder.Encoder != nil {
|
||||||
|
c.selectEncoder.SelectEncoder.SetSelectedIndex(c.selectEncoder.SelectEncoder.SelectedIndex())
|
||||||
|
}
|
||||||
|
|
||||||
|
return container.NewVBox(
|
||||||
|
c.form.form,
|
||||||
|
c.conversionMessage,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) changeEncoder(encoder encoder2.EncoderContract) {
|
||||||
|
items := []*widget.FormItem{}
|
||||||
|
|
||||||
|
if form_items.Views[encoder.GetName()] != nil {
|
||||||
|
items = form_items.Views[encoder.GetName()](encoder, c.app)
|
||||||
|
}
|
||||||
|
|
||||||
|
c.form.ChangeItems(items)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) AfterViewContent() {
|
||||||
|
c.form.form.Disable()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) selectFileForConversion(err error) {
|
||||||
|
c.conversionMessage.Text = ""
|
||||||
|
if err != nil {
|
||||||
|
c.form.form.Disable()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
c.form.form.Enable()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) submit() {
|
||||||
|
if len(c.directoryForSaving.path) == 0 {
|
||||||
|
showConversionMessage(c.conversionMessage, errors.New(c.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "errorSelectedFolderSave",
|
||||||
|
})))
|
||||||
|
c.enableFormConversion()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(c.selectEncoder.SelectFormat.Selected) == 0 {
|
||||||
|
showConversionMessage(c.conversionMessage, errors.New(c.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "errorSelectedFormat",
|
||||||
|
})))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if c.selectEncoder.Encoder == nil {
|
||||||
|
showConversionMessage(c.conversionMessage, errors.New(c.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "errorSelectedEncoder",
|
||||||
|
})))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
c.conversionMessage.Text = ""
|
||||||
|
|
||||||
|
c.fileForConversion.button.Disable()
|
||||||
|
c.directoryForSaving.button.Disable()
|
||||||
|
c.form.form.Disable()
|
||||||
|
|
||||||
|
setting := HandleConvertSetting{
|
||||||
|
FileInput: *c.fileForConversion.file,
|
||||||
|
DirectoryForSave: c.directoryForSaving.path,
|
||||||
|
OverwriteOutputFiles: c.overwriteOutputFiles.IsChecked(),
|
||||||
|
Format: c.selectEncoder.SelectFormat.Selected,
|
||||||
|
Encoder: c.selectEncoder.Encoder,
|
||||||
|
}
|
||||||
|
c.runConvert(setting)
|
||||||
|
c.enableFormConversion()
|
||||||
|
|
||||||
|
c.fileForConversion.message.Text = ""
|
||||||
|
c.form.form.Disable()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c Conversion) enableFormConversion() {
|
||||||
|
c.fileForConversion.button.Enable()
|
||||||
|
c.directoryForSaving.button.Enable()
|
||||||
|
c.form.form.Enable()
|
||||||
|
}
|
||||||
|
|
||||||
|
type fileForConversion struct {
|
||||||
|
button *widget.Button
|
||||||
|
message *canvas.Text
|
||||||
|
file *kernel.File
|
||||||
|
|
||||||
|
changeCallbacks map[int]func(err error)
|
||||||
|
}
|
||||||
|
|
||||||
|
func newFileForConversion(app kernel.AppContract) *fileForConversion {
|
||||||
|
fileForConversion := &fileForConversion{
|
||||||
|
file: &kernel.File{},
|
||||||
|
changeCallbacks: map[int]func(err error){},
|
||||||
|
}
|
||||||
|
|
||||||
|
buttonTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "choose",
|
||||||
|
})
|
||||||
|
|
||||||
|
fileForConversion.message = canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
||||||
|
fileForConversion.message.TextSize = 16
|
||||||
|
fileForConversion.message.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
var locationURI fyne.ListableURI
|
||||||
|
|
||||||
|
fileForConversion.button = widget.NewButton(buttonTitle, func() {
|
||||||
|
app.GetWindow().NewFileOpen(func(r fyne.URIReadCloser, err error) {
|
||||||
|
if err != nil {
|
||||||
|
fileForConversion.message.Text = err.Error()
|
||||||
|
setStringErrorStyle(fileForConversion.message)
|
||||||
|
fileForConversion.eventSelectFile(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if r == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
fileForConversion.file.Path = r.URI().Path()
|
||||||
|
fileForConversion.file.Name = r.URI().Name()
|
||||||
|
fileForConversion.file.Ext = r.URI().Extension()
|
||||||
|
|
||||||
|
fileForConversion.message.Text = r.URI().Path()
|
||||||
|
setStringSuccessStyle(fileForConversion.message)
|
||||||
|
|
||||||
|
fileForConversion.eventSelectFile(nil)
|
||||||
|
|
||||||
|
listableURI := storage.NewFileURI(filepath.Dir(r.URI().Path()))
|
||||||
|
locationURI, err = storage.ListerForURI(listableURI)
|
||||||
|
}, locationURI)
|
||||||
|
})
|
||||||
|
|
||||||
|
return fileForConversion
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c fileForConversion) AddChangeCallback(callback func(err error)) {
|
||||||
|
c.changeCallbacks[len(c.changeCallbacks)] = callback
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c fileForConversion) eventSelectFile(err error) {
|
||||||
|
for _, changeCallback := range c.changeCallbacks {
|
||||||
|
changeCallback(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type directoryForSaving struct {
|
||||||
|
button *widget.Button
|
||||||
|
message *canvas.Text
|
||||||
|
path string
|
||||||
|
}
|
||||||
|
|
||||||
|
func newDirectoryForSaving(app kernel.AppContract) *directoryForSaving {
|
||||||
|
directoryForSaving := &directoryForSaving{
|
||||||
|
path: "",
|
||||||
|
}
|
||||||
|
|
||||||
|
directoryForSaving.message = canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
||||||
|
directoryForSaving.message.TextSize = 16
|
||||||
|
directoryForSaving.message.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
buttonTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "choose",
|
||||||
|
})
|
||||||
|
|
||||||
|
var locationURI fyne.ListableURI
|
||||||
|
|
||||||
|
directoryForSaving.button = widget.NewButton(buttonTitle, func() {
|
||||||
|
app.GetWindow().NewFolderOpen(func(r fyne.ListableURI, err error) {
|
||||||
|
if err != nil {
|
||||||
|
directoryForSaving.message.Text = err.Error()
|
||||||
|
setStringErrorStyle(directoryForSaving.message)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if r == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
directoryForSaving.path = r.Path()
|
||||||
|
|
||||||
|
directoryForSaving.message.Text = r.Path()
|
||||||
|
setStringSuccessStyle(directoryForSaving.message)
|
||||||
|
locationURI, _ = storage.ListerForURI(r)
|
||||||
|
|
||||||
|
}, locationURI)
|
||||||
|
})
|
||||||
|
|
||||||
|
return directoryForSaving
|
||||||
|
}
|
||||||
|
|
||||||
|
type overwriteOutputFiles struct {
|
||||||
|
checkbox *widget.Check
|
||||||
|
isChecked bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func newOverwriteOutputFiles(app kernel.AppContract) *overwriteOutputFiles {
|
||||||
|
overwriteOutputFiles := &overwriteOutputFiles{
|
||||||
|
isChecked: false,
|
||||||
|
}
|
||||||
|
checkboxOverwriteOutputFilesTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "checkboxOverwriteOutputFilesTitle",
|
||||||
|
})
|
||||||
|
overwriteOutputFiles.checkbox = widget.NewCheck(checkboxOverwriteOutputFilesTitle, func(b bool) {
|
||||||
|
overwriteOutputFiles.isChecked = b
|
||||||
|
})
|
||||||
|
|
||||||
|
return overwriteOutputFiles
|
||||||
|
}
|
||||||
|
|
||||||
|
func (receiver overwriteOutputFiles) IsChecked() bool {
|
||||||
|
return receiver.isChecked
|
||||||
|
}
|
||||||
|
|
||||||
|
type selectEncoder struct {
|
||||||
|
SelectFileType *widget.RadioGroup
|
||||||
|
SelectFormat *widget.Select
|
||||||
|
SelectEncoder *widget.Select
|
||||||
|
Encoder encoder2.EncoderContract
|
||||||
|
|
||||||
|
changeCallbacks map[int]func(encoder encoder2.EncoderContract)
|
||||||
|
}
|
||||||
|
|
||||||
|
func newSelectEncoder(app kernel.AppContract, formats encoder.ConvertorFormatsContract) *selectEncoder {
|
||||||
|
selectEncoder := &selectEncoder{
|
||||||
|
changeCallbacks: map[int]func(encoder encoder2.EncoderContract){},
|
||||||
|
}
|
||||||
|
|
||||||
|
encoders := map[int]encoder2.EncoderDataContract{}
|
||||||
|
selectEncoder.SelectEncoder = widget.NewSelect([]string{}, func(s string) {
|
||||||
|
if encoders[selectEncoder.SelectEncoder.SelectedIndex()] == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
selectEncoderData := encoders[selectEncoder.SelectEncoder.SelectedIndex()]
|
||||||
|
selectEncoder.ChangeEncoder(selectEncoderData.NewEncoder())
|
||||||
|
})
|
||||||
|
|
||||||
|
formatSelected := ""
|
||||||
|
selectEncoder.SelectFormat = widget.NewSelect([]string{}, func(s string) {
|
||||||
|
if formatSelected == s {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
formatSelected = s
|
||||||
|
format, err := formats.GetFormat(s)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
encoderOptions := []string{}
|
||||||
|
encoders = map[int]encoder2.EncoderDataContract{}
|
||||||
|
for _, e := range format.GetEncoders() {
|
||||||
|
encoders[len(encoders)] = e
|
||||||
|
encoderOptions = append(encoderOptions, app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoder_" + e.GetTitle()}))
|
||||||
|
}
|
||||||
|
selectEncoder.SelectEncoder.SetOptions(encoderOptions)
|
||||||
|
selectEncoder.SelectEncoder.SetSelectedIndex(0)
|
||||||
|
})
|
||||||
|
|
||||||
|
fileTypeOptions := []string{}
|
||||||
|
for _, fileType := range encoder2.GetListFileType() {
|
||||||
|
fileTypeOptions = append(fileTypeOptions, fileType.Name())
|
||||||
|
}
|
||||||
|
|
||||||
|
encoderGroupVideo := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoderGroupVideo"})
|
||||||
|
encoderGroupAudio := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoderGroupAudio"})
|
||||||
|
encoderGroupImage := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "encoderGroupImage"})
|
||||||
|
encoderGroup := map[string]string{
|
||||||
|
encoderGroupVideo: "video",
|
||||||
|
encoderGroupAudio: "audio",
|
||||||
|
encoderGroupImage: "image",
|
||||||
|
}
|
||||||
|
selectEncoder.SelectFileType = widget.NewRadioGroup([]string{encoderGroupVideo, encoderGroupAudio, encoderGroupImage}, func(s string) {
|
||||||
|
groupCode := encoderGroup[s]
|
||||||
|
|
||||||
|
formatOptions := []string{}
|
||||||
|
for _, f := range formats.GetFormats() {
|
||||||
|
if groupCode != f.GetFileType().Name() {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
formatOptions = append(formatOptions, f.GetTitle())
|
||||||
|
}
|
||||||
|
selectEncoder.SelectFormat.SetOptions(formatOptions)
|
||||||
|
if groupCode == encoder2.FileType(encoder2.Video).Name() {
|
||||||
|
selectEncoder.SelectFormat.SetSelected("mp4")
|
||||||
|
} else {
|
||||||
|
selectEncoder.SelectFormat.SetSelectedIndex(0)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
selectEncoder.SelectFileType.Horizontal = true
|
||||||
|
selectEncoder.SelectFileType.Required = true
|
||||||
|
selectEncoder.SelectFileType.SetSelected(encoderGroupVideo)
|
||||||
|
|
||||||
|
return selectEncoder
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *selectEncoder) ChangeEncoder(encoder encoder2.EncoderContract) {
|
||||||
|
e.Encoder = encoder
|
||||||
|
e.eventSelectEncoder(e.Encoder)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *selectEncoder) AddChangeCallback(callback func(encoder encoder2.EncoderContract)) {
|
||||||
|
e.changeCallbacks[len(e.changeCallbacks)] = callback
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *selectEncoder) eventSelectEncoder(encoder encoder2.EncoderContract) {
|
||||||
|
for _, changeCallback := range e.changeCallbacks {
|
||||||
|
changeCallback(encoder)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func setStringErrorStyle(text *canvas.Text) {
|
||||||
|
text.Color = color.RGBA{R: 255, G: 0, B: 0, A: 255}
|
||||||
|
text.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
func setStringSuccessStyle(text *canvas.Text) {
|
||||||
|
text.Color = color.RGBA{R: 49, G: 127, B: 114, A: 255}
|
||||||
|
text.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
func showConversionMessage(conversionMessage *canvas.Text, err error) {
|
||||||
|
conversionMessage.Text = err.Error()
|
||||||
|
setStringErrorStyle(conversionMessage)
|
||||||
|
}
|
||||||
|
|
||||||
|
type form struct {
|
||||||
|
form *widget.Form
|
||||||
|
items []*widget.FormItem
|
||||||
|
}
|
||||||
|
|
||||||
|
func newForm(app kernel.AppContract, items []*widget.FormItem) *form {
|
||||||
|
f := widget.NewForm()
|
||||||
|
f.SubmitText = app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "converterVideoFilesSubmitTitle",
|
||||||
|
})
|
||||||
|
f.Items = items
|
||||||
|
|
||||||
|
return &form{
|
||||||
|
form: f,
|
||||||
|
items: items,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f form) ChangeItems(items []*widget.FormItem) {
|
||||||
|
f.form.Items = f.items
|
||||||
|
f.form.Refresh()
|
||||||
|
f.form.Items = append(f.form.Items, items...)
|
||||||
|
f.form.Refresh()
|
||||||
|
}
|
16
convertor/view/form_items/form.go
Normal file
16
convertor/view/form_items/form.go
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
package form_items
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view/form_items/h264_nvenc"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view/form_items/libx264"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view/form_items/libx265"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
)
|
||||||
|
|
||||||
|
var Views = map[string]func(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem{
|
||||||
|
"libx264": libx264.View,
|
||||||
|
"h264_nvenc": h264_nvenc.View,
|
||||||
|
"libx265": libx265.View,
|
||||||
|
}
|
65
convertor/view/form_items/h264_nvenc/view.go
Normal file
65
convertor/view/form_items/h264_nvenc/view.go
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
package h264_nvenc
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/h264_nvenc"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
)
|
||||||
|
|
||||||
|
func View(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
items := []*widget.FormItem{}
|
||||||
|
|
||||||
|
items = append(items, presetParameter(encoder, app)...)
|
||||||
|
|
||||||
|
return items
|
||||||
|
}
|
||||||
|
|
||||||
|
func presetParameter(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
parameter, err := encoder.GetParameter("preset")
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
presets := map[string]string{}
|
||||||
|
presetsForSelect := []string{}
|
||||||
|
presetDefault := ""
|
||||||
|
|
||||||
|
for _, name := range h264_nvenc.Presets {
|
||||||
|
title := name
|
||||||
|
presetsForSelect = append(presetsForSelect, name)
|
||||||
|
presets[title] = name
|
||||||
|
if name == parameter.Get() {
|
||||||
|
presetDefault = title
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
elementSelect := widget.NewSelect(presetsForSelect, func(s string) {
|
||||||
|
if presets[s] == "" {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.Set(presets[s])
|
||||||
|
})
|
||||||
|
elementSelect.SetSelected(presetDefault)
|
||||||
|
elementSelect.Hide()
|
||||||
|
|
||||||
|
checkboxTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "parameterCheckbox"})
|
||||||
|
elementCheckbox := widget.NewCheck(checkboxTitle, func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
parameter.SetEnable()
|
||||||
|
elementSelect.Show()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.SetDisable()
|
||||||
|
elementSelect.Hide()
|
||||||
|
})
|
||||||
|
|
||||||
|
return []*widget.FormItem{
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "formPreset"}),
|
||||||
|
Widget: container.NewVBox(elementCheckbox, elementSelect),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
65
convertor/view/form_items/libx264/view.go
Normal file
65
convertor/view/form_items/libx264/view.go
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
package libx264
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libx264"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
)
|
||||||
|
|
||||||
|
func View(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
items := []*widget.FormItem{}
|
||||||
|
|
||||||
|
items = append(items, presetParameter(encoder, app)...)
|
||||||
|
|
||||||
|
return items
|
||||||
|
}
|
||||||
|
|
||||||
|
func presetParameter(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
parameter, err := encoder.GetParameter("preset")
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
presets := map[string]string{}
|
||||||
|
presetsForSelect := []string{}
|
||||||
|
presetDefault := ""
|
||||||
|
|
||||||
|
for _, name := range libx264.Presets {
|
||||||
|
title := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "preset_" + name})
|
||||||
|
presetsForSelect = append(presetsForSelect, title)
|
||||||
|
presets[title] = name
|
||||||
|
if name == parameter.Get() {
|
||||||
|
presetDefault = title
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
elementSelect := widget.NewSelect(presetsForSelect, func(s string) {
|
||||||
|
if presets[s] == "" {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.Set(presets[s])
|
||||||
|
})
|
||||||
|
elementSelect.SetSelected(presetDefault)
|
||||||
|
elementSelect.Hide()
|
||||||
|
|
||||||
|
checkboxTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "parameterCheckbox"})
|
||||||
|
elementCheckbox := widget.NewCheck(checkboxTitle, func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
parameter.SetEnable()
|
||||||
|
elementSelect.Show()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.SetDisable()
|
||||||
|
elementSelect.Hide()
|
||||||
|
})
|
||||||
|
|
||||||
|
return []*widget.FormItem{
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "formPreset"}),
|
||||||
|
Widget: container.NewVBox(elementCheckbox, elementSelect),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
65
convertor/view/form_items/libx265/view.go
Normal file
65
convertor/view/form_items/libx265/view.go
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
package libx265
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libx265"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
)
|
||||||
|
|
||||||
|
func View(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
items := []*widget.FormItem{}
|
||||||
|
|
||||||
|
items = append(items, presetParameter(encoder, app)...)
|
||||||
|
|
||||||
|
return items
|
||||||
|
}
|
||||||
|
|
||||||
|
func presetParameter(encoder encoder.EncoderContract, app kernel.AppContract) []*widget.FormItem {
|
||||||
|
parameter, err := encoder.GetParameter("preset")
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
presets := map[string]string{}
|
||||||
|
presetsForSelect := []string{}
|
||||||
|
presetDefault := ""
|
||||||
|
|
||||||
|
for _, name := range libx265.Presets {
|
||||||
|
title := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "preset_" + name})
|
||||||
|
presetsForSelect = append(presetsForSelect, title)
|
||||||
|
presets[title] = name
|
||||||
|
if name == parameter.Get() {
|
||||||
|
presetDefault = title
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
elementSelect := widget.NewSelect(presetsForSelect, func(s string) {
|
||||||
|
if presets[s] == "" {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.Set(presets[s])
|
||||||
|
})
|
||||||
|
elementSelect.SetSelected(presetDefault)
|
||||||
|
elementSelect.Hide()
|
||||||
|
|
||||||
|
checkboxTitle := app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "parameterCheckbox"})
|
||||||
|
elementCheckbox := widget.NewCheck(checkboxTitle, func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
parameter.SetEnable()
|
||||||
|
elementSelect.Show()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
parameter.SetDisable()
|
||||||
|
elementSelect.Hide()
|
||||||
|
})
|
||||||
|
|
||||||
|
return []*widget.FormItem{
|
||||||
|
{
|
||||||
|
Text: app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{MessageID: "formPreset"}),
|
||||||
|
Widget: container.NewVBox(elementCheckbox, elementSelect),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
@@ -1,5 +1,5 @@
|
|||||||
//go:build !windows
|
//go:build !windows && !linux
|
||||||
// +build !windows
|
// +build !windows,!linux
|
||||||
|
|
||||||
package convertor
|
package convertor
|
||||||
|
|
||||||
|
63
convertor/view_setting_button_download_ffmpeg_linux.go
Normal file
63
convertor/view_setting_button_download_ffmpeg_linux.go
Normal file
@@ -0,0 +1,63 @@
|
|||||||
|
//go:build linux
|
||||||
|
// +build linux
|
||||||
|
|
||||||
|
package convertor
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fyne.io/fyne/v2"
|
||||||
|
"fyne.io/fyne/v2/canvas"
|
||||||
|
"fyne.io/fyne/v2/container"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
"golang.org/x/image/colornames"
|
||||||
|
"image/color"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (v View) blockDownloadFFmpeg(
|
||||||
|
donwloadFFmpeg func(progressBar *widget.ProgressBar, progressMessage *canvas.Text) error,
|
||||||
|
) *fyne.Container {
|
||||||
|
|
||||||
|
errorDownloadFFmpegMessage := canvas.NewText("", color.RGBA{R: 255, G: 0, B: 0, A: 255})
|
||||||
|
errorDownloadFFmpegMessage.TextSize = 16
|
||||||
|
errorDownloadFFmpegMessage.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
progressDownloadFFmpegMessage := canvas.NewText("", color.RGBA{R: 49, G: 127, B: 114, A: 255})
|
||||||
|
progressDownloadFFmpegMessage.TextSize = 16
|
||||||
|
progressDownloadFFmpegMessage.TextStyle = fyne.TextStyle{Bold: true}
|
||||||
|
|
||||||
|
progressBar := widget.NewProgressBar()
|
||||||
|
|
||||||
|
var buttonDownloadFFmpeg *widget.Button
|
||||||
|
|
||||||
|
buttonDownloadFFmpeg = widget.NewButton(v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "download",
|
||||||
|
}), func() {
|
||||||
|
buttonDownloadFFmpeg.Disable()
|
||||||
|
|
||||||
|
err := donwloadFFmpeg(progressBar, progressDownloadFFmpegMessage)
|
||||||
|
if err != nil {
|
||||||
|
errorDownloadFFmpegMessage.Text = err.Error()
|
||||||
|
}
|
||||||
|
|
||||||
|
buttonDownloadFFmpeg.Enable()
|
||||||
|
})
|
||||||
|
|
||||||
|
downloadFFmpegFromSiteMessage := v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "downloadFFmpegFromSite",
|
||||||
|
})
|
||||||
|
|
||||||
|
return container.NewVBox(
|
||||||
|
canvas.NewLine(colornames.Darkgreen),
|
||||||
|
widget.NewCard(v.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "buttonDownloadFFmpeg",
|
||||||
|
}), "", container.NewVBox(
|
||||||
|
widget.NewRichTextFromMarkdown(
|
||||||
|
downloadFFmpegFromSiteMessage+" [https://github.com/BtbN/FFmpeg-Builds/releases](https://github.com/BtbN/FFmpeg-Builds/releases)",
|
||||||
|
),
|
||||||
|
buttonDownloadFFmpeg,
|
||||||
|
errorDownloadFFmpegMessage,
|
||||||
|
progressDownloadFFmpegMessage,
|
||||||
|
progressBar,
|
||||||
|
)),
|
||||||
|
)
|
||||||
|
}
|
7
db/db.go
Normal file
7
db/db.go
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
package db
|
||||||
|
|
||||||
|
import "errors"
|
||||||
|
|
||||||
|
var (
|
||||||
|
ErrRecordNotFound = errors.New("record not found")
|
||||||
|
)
|
19
encoder/apng/encoder.go
Normal file
19
encoder/apng/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package apng
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "apng"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("apng", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "apng"
|
||||||
|
formats := []string{"apng"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/bmp/encoder.go
Normal file
19
encoder/bmp/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package bmp
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "bmp"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("bmp", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "bmp"
|
||||||
|
formats := []string{"bmp"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
169
encoder/encoder.go
Normal file
169
encoder/encoder.go
Normal file
@@ -0,0 +1,169 @@
|
|||||||
|
package encoder
|
||||||
|
|
||||||
|
import "errors"
|
||||||
|
|
||||||
|
type EncoderContract interface {
|
||||||
|
GetName() string
|
||||||
|
GetParams() []string
|
||||||
|
GetParameter(name string) (ParameterContract, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
type ParameterContract interface {
|
||||||
|
GetName() string
|
||||||
|
Set(string) error
|
||||||
|
Get() string
|
||||||
|
IsEnabled() bool
|
||||||
|
SetEnable()
|
||||||
|
SetDisable()
|
||||||
|
}
|
||||||
|
|
||||||
|
type EncoderDataContract interface {
|
||||||
|
GetTitle() string
|
||||||
|
GetFormats() []string
|
||||||
|
GetFileType() FileTypeContract
|
||||||
|
NewEncoder() EncoderContract
|
||||||
|
}
|
||||||
|
|
||||||
|
type Data struct {
|
||||||
|
title string
|
||||||
|
formats []string
|
||||||
|
fileType FileTypeContract
|
||||||
|
encoder func() EncoderContract
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData(title string, formats []string, fileType FileTypeContract, encoder func() EncoderContract) *Data {
|
||||||
|
return &Data{
|
||||||
|
title: title,
|
||||||
|
formats: formats,
|
||||||
|
fileType: fileType,
|
||||||
|
encoder: encoder,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (data Data) GetTitle() string {
|
||||||
|
return data.title
|
||||||
|
}
|
||||||
|
|
||||||
|
func (data Data) GetFormats() []string {
|
||||||
|
return data.formats
|
||||||
|
}
|
||||||
|
|
||||||
|
func (data Data) NewEncoder() EncoderContract {
|
||||||
|
return data.encoder()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (data Data) GetFileType() FileTypeContract {
|
||||||
|
return data.fileType
|
||||||
|
}
|
||||||
|
|
||||||
|
type FileTypeContract interface {
|
||||||
|
Name() string
|
||||||
|
Ordinal() int
|
||||||
|
}
|
||||||
|
|
||||||
|
const (
|
||||||
|
Video = iota
|
||||||
|
Audio
|
||||||
|
Image
|
||||||
|
)
|
||||||
|
|
||||||
|
type FileType uint
|
||||||
|
|
||||||
|
var fileTypeStrings = []string{
|
||||||
|
"video",
|
||||||
|
"audio",
|
||||||
|
"image",
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fileType FileType) Name() string {
|
||||||
|
return fileTypeStrings[fileType]
|
||||||
|
}
|
||||||
|
|
||||||
|
func (fileType FileType) Ordinal() int {
|
||||||
|
return int(fileType)
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetListFileType() []FileTypeContract {
|
||||||
|
return []FileTypeContract{
|
||||||
|
FileType(Video),
|
||||||
|
FileType(Audio),
|
||||||
|
FileType(Image),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type Encoder struct {
|
||||||
|
name string
|
||||||
|
parameters map[string]ParameterContract
|
||||||
|
getParams func(parameters map[string]ParameterContract) []string
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewEncoder(name string, parameters map[string]ParameterContract, getParams func(parameters map[string]ParameterContract) []string) *Encoder {
|
||||||
|
return &Encoder{
|
||||||
|
name: name,
|
||||||
|
parameters: parameters,
|
||||||
|
getParams: getParams,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *Encoder) GetName() string {
|
||||||
|
return e.name
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *Encoder) GetParams() []string {
|
||||||
|
return e.getParams(e.parameters)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *Encoder) GetParameter(name string) (ParameterContract, error) {
|
||||||
|
if e.parameters[name] == nil {
|
||||||
|
return nil, errors.New("parameter not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
return e.parameters[name], nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type Parameter struct {
|
||||||
|
name string
|
||||||
|
isEnabled bool
|
||||||
|
parameter string
|
||||||
|
setParameter func(string) (string, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewParameter(name string, isEnabled bool, defaultParameter string, setParameter func(string) (string, error)) *Parameter {
|
||||||
|
return &Parameter{
|
||||||
|
name: name,
|
||||||
|
isEnabled: isEnabled,
|
||||||
|
parameter: defaultParameter,
|
||||||
|
setParameter: setParameter,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) GetName() string {
|
||||||
|
return p.name
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) Set(s string) (err error) {
|
||||||
|
if p.setParameter != nil {
|
||||||
|
s, err = p.setParameter(s)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
p.parameter = s
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) Get() string {
|
||||||
|
return p.parameter
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) IsEnabled() bool {
|
||||||
|
return p.isEnabled
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) SetEnable() {
|
||||||
|
p.isEnabled = true
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *Parameter) SetDisable() {
|
||||||
|
p.isEnabled = false
|
||||||
|
}
|
19
encoder/flv/encoder.go
Normal file
19
encoder/flv/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package flv
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "flv"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("flv", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "flv"
|
||||||
|
formats := []string{"flv"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/gif/encoder.go
Normal file
19
encoder/gif/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package gif
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "gif"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("gif", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "gif"
|
||||||
|
formats := []string{"gif"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
58
encoder/h264_nvenc/encoder.go
Normal file
58
encoder/h264_nvenc/encoder.go
Normal file
@@ -0,0 +1,58 @@
|
|||||||
|
package h264_nvenc
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
)
|
||||||
|
|
||||||
|
var Presets = []string{
|
||||||
|
"default",
|
||||||
|
"slow",
|
||||||
|
"medium",
|
||||||
|
"fast",
|
||||||
|
"hp",
|
||||||
|
"hq",
|
||||||
|
"bd",
|
||||||
|
"ll",
|
||||||
|
"llhq",
|
||||||
|
"llhp",
|
||||||
|
"lossless",
|
||||||
|
"losslesshp",
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{
|
||||||
|
"preset": newParameterPreset(),
|
||||||
|
}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
params := []string{"-c:v", "h264_nvenc"}
|
||||||
|
|
||||||
|
if parameters["preset"] != nil && parameters["preset"].IsEnabled() {
|
||||||
|
params = append(params, "-preset", parameters["preset"].Get())
|
||||||
|
}
|
||||||
|
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("h264_nvenc", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "h264_nvenc"
|
||||||
|
formats := []string{"mp4"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
||||||
|
|
||||||
|
func newParameterPreset() encoder2.ParameterContract {
|
||||||
|
setParameter := func(s string) (string, error) {
|
||||||
|
for _, value := range Presets {
|
||||||
|
if value == s {
|
||||||
|
return value, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return "", errors.New("preset not found")
|
||||||
|
}
|
||||||
|
return encoder2.NewParameter("preset", false, "default", setParameter)
|
||||||
|
}
|
19
encoder/libmp3lame/encoder.go
Normal file
19
encoder/libmp3lame/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package libmp3lame
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:a", "libmp3lame"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libmp3lame", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libmp3lame"
|
||||||
|
formats := []string{"mp3"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Audio)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/libshine/encoder.go
Normal file
19
encoder/libshine/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package libshine
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:a", "libshine"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libshine", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libshine"
|
||||||
|
formats := []string{"mp3"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Audio)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/libtwolame/encoder.go
Normal file
19
encoder/libtwolame/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package libtwolame
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:a", "libtwolame"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libtwolame", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libtwolame"
|
||||||
|
formats := []string{"mp2"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Audio)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/libvpx/encoder.go
Normal file
19
encoder/libvpx/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package libvpx
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "libvpx"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libvpx", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libvpx"
|
||||||
|
formats := []string{"webm", "mkv"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/libvpx_vp9/encoder.go
Normal file
19
encoder/libvpx_vp9/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package libvpx_vp9
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "libvpx-vp9"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libvpx_vp9", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libvpx-vp9"
|
||||||
|
formats := []string{"webm", "mkv"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/libwebp/encoder.go
Normal file
19
encoder/libwebp/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package libwebp
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "libwebp"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libwebp", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libwebp"
|
||||||
|
formats := []string{"webp"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/libwebp_anim/encoder.go
Normal file
19
encoder/libwebp_anim/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package libwebp_anim
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "libwebp_anim"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libwebp_anim", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libwebp_anim"
|
||||||
|
formats := []string{"webp"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
56
encoder/libx264/encoder.go
Normal file
56
encoder/libx264/encoder.go
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
package libx264
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
)
|
||||||
|
|
||||||
|
var Presets = []string{
|
||||||
|
"ultrafast",
|
||||||
|
"superfast",
|
||||||
|
"veryfast",
|
||||||
|
"faster",
|
||||||
|
"fast",
|
||||||
|
"medium",
|
||||||
|
"slow",
|
||||||
|
"slower",
|
||||||
|
"veryslow",
|
||||||
|
"placebo",
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{
|
||||||
|
"preset": newParameterPreset(),
|
||||||
|
}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
params := []string{"-c:v", "libx264"}
|
||||||
|
|
||||||
|
if parameters["preset"] != nil && parameters["preset"].IsEnabled() {
|
||||||
|
params = append(params, "-preset", parameters["preset"].Get())
|
||||||
|
}
|
||||||
|
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libx264", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libx264"
|
||||||
|
formats := []string{"mp4"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
||||||
|
|
||||||
|
func newParameterPreset() encoder2.ParameterContract {
|
||||||
|
setParameter := func(s string) (string, error) {
|
||||||
|
for _, value := range Presets {
|
||||||
|
if value == s {
|
||||||
|
return value, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return "", errors.New("preset not found")
|
||||||
|
}
|
||||||
|
return encoder2.NewParameter("preset", false, "medium", setParameter)
|
||||||
|
}
|
56
encoder/libx265/encoder.go
Normal file
56
encoder/libx265/encoder.go
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
package libx265
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
)
|
||||||
|
|
||||||
|
var Presets = []string{
|
||||||
|
"ultrafast",
|
||||||
|
"superfast",
|
||||||
|
"veryfast",
|
||||||
|
"faster",
|
||||||
|
"fast",
|
||||||
|
"medium",
|
||||||
|
"slow",
|
||||||
|
"slower",
|
||||||
|
"veryslow",
|
||||||
|
"placebo",
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{
|
||||||
|
"preset": newParameterPreset(),
|
||||||
|
}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
params := []string{"-c:v", "libx265"}
|
||||||
|
|
||||||
|
if parameters["preset"] != nil && parameters["preset"].IsEnabled() {
|
||||||
|
params = append(params, "-preset", parameters["preset"].Get())
|
||||||
|
}
|
||||||
|
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libx265", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libx265"
|
||||||
|
formats := []string{"mp4"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
||||||
|
|
||||||
|
func newParameterPreset() encoder2.ParameterContract {
|
||||||
|
setParameter := func(s string) (string, error) {
|
||||||
|
for _, value := range Presets {
|
||||||
|
if value == s {
|
||||||
|
return value, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return "", errors.New("preset not found")
|
||||||
|
}
|
||||||
|
return encoder2.NewParameter("preset", false, "medium", setParameter)
|
||||||
|
}
|
19
encoder/libxvid/encoder.go
Normal file
19
encoder/libxvid/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package libxvid
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "libxvid"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("libxvid", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "libxvid"
|
||||||
|
formats := []string{"avi"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/mjpeg/encoder.go
Normal file
19
encoder/mjpeg/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package mjpeg
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "mjpeg"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mjpeg", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "mjpeg"
|
||||||
|
formats := []string{"jpg"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/mp2/encoder.go
Normal file
19
encoder/mp2/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package mp2
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:a", "mp2"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mp2", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "mp2"
|
||||||
|
formats := []string{"mp2"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Audio)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/mp2fixed/encoder.go
Normal file
19
encoder/mp2fixed/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package mp2fixed
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:a", "mp2fixed"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mp2fixed", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "mp2fixed"
|
||||||
|
formats := []string{"mp2"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Audio)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/mpeg1video/encoder.go
Normal file
19
encoder/mpeg1video/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package mpeg1video
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "mpeg1video"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mpeg1video", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "mpeg1video"
|
||||||
|
formats := []string{"mpg", "mpeg"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/mpeg2video/encoder.go
Normal file
19
encoder/mpeg2video/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package mpeg2video
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "mpeg2video"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mpeg2video", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "mpeg2video"
|
||||||
|
formats := []string{"mpg", "mpeg"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/mpeg4/encoder.go
Normal file
19
encoder/mpeg4/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package mpeg4
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "mpeg4"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("mpeg4", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "mpeg4"
|
||||||
|
formats := []string{"avi"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/msmpeg4/encoder.go
Normal file
19
encoder/msmpeg4/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package msmpeg4
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "msmpeg4"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("msmpeg4", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "msmpeg4"
|
||||||
|
formats := []string{"avi"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/msmpeg4v2/encoder.go
Normal file
19
encoder/msmpeg4v2/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package msmpeg4v2
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "msmpeg4v2"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("msmpeg4v2", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "msmpeg4v2"
|
||||||
|
formats := []string{"avi"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/msvideo1/encoder.go
Normal file
19
encoder/msvideo1/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package msvideo1
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "msvideo1"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("msvideo1", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "msvideo1"
|
||||||
|
formats := []string{"avi"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/png/encoder.go
Normal file
19
encoder/png/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package png
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "png"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("png", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "png"
|
||||||
|
formats := []string{"png"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/qtrle/encoder.go
Normal file
19
encoder/qtrle/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package qtrle
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "qtrle"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("qtrle", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "qtrle"
|
||||||
|
formats := []string{"mov"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/sgi/encoder.go
Normal file
19
encoder/sgi/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package sgi
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "sgi"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("sgi", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "sgi"
|
||||||
|
formats := []string{"sgi"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/tiff/encoder.go
Normal file
19
encoder/tiff/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package tiff
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "tiff"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("tiff", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "tiff"
|
||||||
|
formats := []string{"tiff"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/wmav1/encoder.go
Normal file
19
encoder/wmav1/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package wmav1
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:a", "wmav1"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("wmav1", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "wmav1"
|
||||||
|
formats := []string{"wma"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Audio)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/wmav2/encoder.go
Normal file
19
encoder/wmav2/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package wmav2
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:a", "wmav2"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("wmav2", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "wmav2"
|
||||||
|
formats := []string{"wma"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Audio)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/wmv1/encoder.go
Normal file
19
encoder/wmv1/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package wmv1
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "wmv1"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("wmv1", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "wmv1"
|
||||||
|
formats := []string{"wmv"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/wmv2/encoder.go
Normal file
19
encoder/wmv2/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package wmv2
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "wmv2"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("wmv2", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "wmv2"
|
||||||
|
formats := []string{"wmv"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Video)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
19
encoder/xbm/encoder.go
Normal file
19
encoder/xbm/encoder.go
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
package xbm
|
||||||
|
|
||||||
|
import encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
|
||||||
|
func NewEncoder() encoder2.EncoderContract {
|
||||||
|
parameters := map[string]encoder2.ParameterContract{}
|
||||||
|
getParams := func(parameters map[string]encoder2.ParameterContract) []string {
|
||||||
|
return []string{"-c:v", "xbm"}
|
||||||
|
}
|
||||||
|
|
||||||
|
return encoder2.NewEncoder("xbm", parameters, getParams)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewData() encoder2.EncoderDataContract {
|
||||||
|
title := "xbm"
|
||||||
|
formats := []string{"xbm"}
|
||||||
|
fileType := encoder2.FileType(encoder2.Image)
|
||||||
|
return encoder2.NewData(title, formats, fileType, NewEncoder)
|
||||||
|
}
|
16
go.mod
16
go.mod
@@ -1,15 +1,18 @@
|
|||||||
module git.kor-elf.net/kor-elf/gui-for-ffmpeg
|
module git.kor-elf.net/kor-elf/gui-for-ffmpeg
|
||||||
|
|
||||||
go 1.21
|
go 1.23
|
||||||
|
|
||||||
|
toolchain go1.23.9
|
||||||
|
|
||||||
require (
|
require (
|
||||||
fyne.io/fyne/v2 v2.4.3
|
fyne.io/fyne/v2 v2.4.3
|
||||||
github.com/BurntSushi/toml v1.3.2
|
github.com/BurntSushi/toml v1.3.2
|
||||||
github.com/mattn/go-sqlite3 v1.14.21
|
github.com/mattn/go-sqlite3 v1.14.21
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.4.0
|
github.com/nicksnyder/go-i18n/v2 v2.4.0
|
||||||
|
github.com/ulikunitz/xz v0.5.12
|
||||||
|
go.etcd.io/bbolt v1.4.0
|
||||||
|
golang.org/x/image v0.11.0
|
||||||
golang.org/x/text v0.14.0
|
golang.org/x/text v0.14.0
|
||||||
gorm.io/driver/sqlite v1.5.4
|
|
||||||
gorm.io/gorm v1.25.6
|
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
@@ -26,19 +29,16 @@ require (
|
|||||||
github.com/go-text/typesetting v0.0.0-20230616162802-9c17dd34aa4a // indirect
|
github.com/go-text/typesetting v0.0.0-20230616162802-9c17dd34aa4a // indirect
|
||||||
github.com/godbus/dbus/v5 v5.1.0 // indirect
|
github.com/godbus/dbus/v5 v5.1.0 // indirect
|
||||||
github.com/gopherjs/gopherjs v1.17.2 // indirect
|
github.com/gopherjs/gopherjs v1.17.2 // indirect
|
||||||
github.com/jinzhu/inflection v1.0.0 // indirect
|
|
||||||
github.com/jinzhu/now v1.1.5 // indirect
|
|
||||||
github.com/jsummers/gobmp v0.0.0-20151104160322-e2ba15ffa76e // indirect
|
github.com/jsummers/gobmp v0.0.0-20151104160322-e2ba15ffa76e // indirect
|
||||||
github.com/pmezard/go-difflib v1.0.0 // indirect
|
github.com/pmezard/go-difflib v1.0.0 // indirect
|
||||||
github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c // indirect
|
github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c // indirect
|
||||||
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef // indirect
|
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef // indirect
|
||||||
github.com/stretchr/testify v1.8.4 // indirect
|
github.com/stretchr/testify v1.10.0 // indirect
|
||||||
github.com/tevino/abool v1.2.0 // indirect
|
github.com/tevino/abool v1.2.0 // indirect
|
||||||
github.com/yuin/goldmark v1.5.5 // indirect
|
github.com/yuin/goldmark v1.5.5 // indirect
|
||||||
golang.org/x/image v0.11.0 // indirect
|
|
||||||
golang.org/x/mobile v0.0.0-20230531173138-3c911d8e3eda // indirect
|
golang.org/x/mobile v0.0.0-20230531173138-3c911d8e3eda // indirect
|
||||||
golang.org/x/net v0.20.0 // indirect
|
golang.org/x/net v0.20.0 // indirect
|
||||||
golang.org/x/sys v0.16.0 // indirect
|
golang.org/x/sys v0.29.0 // indirect
|
||||||
gopkg.in/yaml.v3 v3.0.1 // indirect
|
gopkg.in/yaml.v3 v3.0.1 // indirect
|
||||||
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2 // indirect
|
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2 // indirect
|
||||||
)
|
)
|
||||||
|
45
go.sum
45
go.sum
@@ -73,8 +73,8 @@ github.com/envoyproxy/go-control-plane v0.9.9-0.20201210154907-fd9021fe5dad/go.m
|
|||||||
github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk=
|
github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk=
|
||||||
github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
|
github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
|
||||||
github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4=
|
github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4=
|
||||||
github.com/fredbi/uri v1.0.0 h1:s4QwUAZ8fz+mbTsukND+4V5f+mJ/wjaTokwstGUAemg=
|
github.com/felixge/fgprof v0.9.3 h1:VvyZxILNuCiUCSXtPtYmmtGvb65nqXh2QFWc0Wpf2/g=
|
||||||
github.com/fredbi/uri v1.0.0/go.mod h1:1xC40RnIOGCaQzswaOvrzvG/3M3F0hyDVb3aO/1iGy0=
|
github.com/felixge/fgprof v0.9.3/go.mod h1:RdbpDgzqYVh/T9fPELJyV7EYJuHB55UTEULNun8eiPw=
|
||||||
github.com/fredbi/uri v1.1.0 h1:OqLpTXtyRg9ABReqvDGdJPqZUxs8cyBDOMXBbskCaB8=
|
github.com/fredbi/uri v1.1.0 h1:OqLpTXtyRg9ABReqvDGdJPqZUxs8cyBDOMXBbskCaB8=
|
||||||
github.com/fredbi/uri v1.1.0/go.mod h1:aYTUoAXBOq7BLfVJ8GnKmfcuURosB1xyHDIfWeC/iW4=
|
github.com/fredbi/uri v1.1.0/go.mod h1:aYTUoAXBOq7BLfVJ8GnKmfcuURosB1xyHDIfWeC/iW4=
|
||||||
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
|
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
|
||||||
@@ -87,7 +87,6 @@ github.com/fyne-io/glfw-js v0.0.0-20220120001248-ee7290d23504/go.mod h1:gLRWYfYn
|
|||||||
github.com/fyne-io/image v0.0.0-20220602074514-4956b0afb3d2 h1:hnLq+55b7Zh7/2IRzWCpiTcAvjv/P8ERF+N7+xXbZhk=
|
github.com/fyne-io/image v0.0.0-20220602074514-4956b0afb3d2 h1:hnLq+55b7Zh7/2IRzWCpiTcAvjv/P8ERF+N7+xXbZhk=
|
||||||
github.com/fyne-io/image v0.0.0-20220602074514-4956b0afb3d2/go.mod h1:eO7W361vmlPOrykIg+Rsh1SZ3tQBaOsfzZhsIOb/Lm0=
|
github.com/fyne-io/image v0.0.0-20220602074514-4956b0afb3d2/go.mod h1:eO7W361vmlPOrykIg+Rsh1SZ3tQBaOsfzZhsIOb/Lm0=
|
||||||
github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
|
github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
|
||||||
github.com/go-gl/gl v0.0.0-20211210172815-726fda9656d6 h1:zDw5v7qm4yH7N8C8uWd+8Ii9rROdgWxQuGoJ9WDXxfk=
|
|
||||||
github.com/go-gl/gl v0.0.0-20211210172815-726fda9656d6/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
|
github.com/go-gl/gl v0.0.0-20211210172815-726fda9656d6/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
|
||||||
github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71 h1:5BVwOaUSBTlVZowGO6VZGw2H/zl9nrd3eCZfYV+NfQA=
|
github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71 h1:5BVwOaUSBTlVZowGO6VZGw2H/zl9nrd3eCZfYV+NfQA=
|
||||||
github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
|
github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw=
|
||||||
@@ -95,8 +94,6 @@ github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9
|
|||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20211213063430-748e38ca8aec/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20211213063430-748e38ca8aec/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20221017161538-93cebf72946b h1:GgabKamyOYguHqHjSkDACcgoPIz3w0Dis/zJ1wyHHHU=
|
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20221017161538-93cebf72946b/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240118000515-a250818d05e3 h1:nanQfMsOs3gnuKRm0E5jXWomedE/9YIFXdmHJNZYeqc=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240118000515-a250818d05e3 h1:nanQfMsOs3gnuKRm0E5jXWomedE/9YIFXdmHJNZYeqc=
|
||||||
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240118000515-a250818d05e3/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240118000515-a250818d05e3/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
|
||||||
github.com/go-text/render v0.0.0-20230619120952-35bccb6164b8 h1:VkKnvzbvHqgEfm351rfr8Uclu5fnwq8HP2ximUzJsBM=
|
github.com/go-text/render v0.0.0-20230619120952-35bccb6164b8 h1:VkKnvzbvHqgEfm351rfr8Uclu5fnwq8HP2ximUzJsBM=
|
||||||
@@ -167,6 +164,8 @@ github.com/google/pprof v0.0.0-20201023163331-3e6fc7fc9c4c/go.mod h1:kpwsk12EmLe
|
|||||||
github.com/google/pprof v0.0.0-20201203190320-1bf35d6f28c2/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
github.com/google/pprof v0.0.0-20201203190320-1bf35d6f28c2/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
||||||
github.com/google/pprof v0.0.0-20210122040257-d980be63207e/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
github.com/google/pprof v0.0.0-20210122040257-d980be63207e/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
||||||
github.com/google/pprof v0.0.0-20210226084205-cbba55b83ad5/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
github.com/google/pprof v0.0.0-20210226084205-cbba55b83ad5/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
|
||||||
|
github.com/google/pprof v0.0.0-20211214055906-6f57359322fd h1:1FjCyPC+syAzJ5/2S8fqdZK1R22vvA0J7JZKcuOIQ7Y=
|
||||||
|
github.com/google/pprof v0.0.0-20211214055906-6f57359322fd/go.mod h1:KgnwoLYCZ8IQu3XUZ8Nc/bM9CCZFOyjUNOSygVozoDg=
|
||||||
github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI=
|
github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI=
|
||||||
github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
||||||
github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg=
|
github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg=
|
||||||
@@ -201,10 +200,6 @@ github.com/hashicorp/serf v0.8.2/go.mod h1:6hOLApaqBFA1NXqRQAsxw9QxuDEvNxSQRwA/J
|
|||||||
github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
||||||
github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
||||||
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
||||||
github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E=
|
|
||||||
github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc=
|
|
||||||
github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ=
|
|
||||||
github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8=
|
|
||||||
github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
|
github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
|
||||||
github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU=
|
github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU=
|
||||||
github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk=
|
github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk=
|
||||||
@@ -222,8 +217,6 @@ github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
|
|||||||
github.com/magiconair/properties v1.8.5/go.mod h1:y3VJvCyxH9uVvJTWEGAELF3aiYNyPKd5NZ3oSwXrF60=
|
github.com/magiconair/properties v1.8.5/go.mod h1:y3VJvCyxH9uVvJTWEGAELF3aiYNyPKd5NZ3oSwXrF60=
|
||||||
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
|
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
|
||||||
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
|
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
|
||||||
github.com/mattn/go-sqlite3 v1.14.19 h1:fhGleo2h1p8tVChob4I9HpmVFIAkKGpiukdrgQbWfGI=
|
|
||||||
github.com/mattn/go-sqlite3 v1.14.19/go.mod h1:2eHXhiwb8IkHr+BDWZGa96P6+rkvnG63S2DGjv9HUNg=
|
|
||||||
github.com/mattn/go-sqlite3 v1.14.21 h1:IXocQLOykluc3xPE0Lvy8FtggMz1G+U3mEjg+0zGizc=
|
github.com/mattn/go-sqlite3 v1.14.21 h1:IXocQLOykluc3xPE0Lvy8FtggMz1G+U3mEjg+0zGizc=
|
||||||
github.com/mattn/go-sqlite3 v1.14.21/go.mod h1:Uh1q+B4BYcTPb+yiD3kU8Ct7aC0hY9fxUwlHK0RXw+Y=
|
github.com/mattn/go-sqlite3 v1.14.21/go.mod h1:Uh1q+B4BYcTPb+yiD3kU8Ct7aC0hY9fxUwlHK0RXw+Y=
|
||||||
github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg=
|
github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg=
|
||||||
@@ -240,13 +233,13 @@ github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lN
|
|||||||
github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
|
github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
|
||||||
github.com/neelance/astrewrite v0.0.0-20160511093645-99348263ae86/go.mod h1:kHJEU3ofeGjhHklVoIGuVj85JJwZ6kWPaJwCIxgnFmo=
|
github.com/neelance/astrewrite v0.0.0-20160511093645-99348263ae86/go.mod h1:kHJEU3ofeGjhHklVoIGuVj85JJwZ6kWPaJwCIxgnFmo=
|
||||||
github.com/neelance/sourcemap v0.0.0-20200213170602-2833bce08e4c/go.mod h1:Qr6/a/Q4r9LP1IltGz7tA7iOK1WonHEYhu1HRBA7ZiM=
|
github.com/neelance/sourcemap v0.0.0-20200213170602-2833bce08e4c/go.mod h1:Qr6/a/Q4r9LP1IltGz7tA7iOK1WonHEYhu1HRBA7ZiM=
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.3.0 h1:2NPsCsNFCVd7i+Su0xYsBrIhS3bE2XMv5gNTft2O+PQ=
|
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.3.0/go.mod h1:nxYSZE9M0bf3Y70gPQjN9ha7XNHX7gMc814+6wVyEI4=
|
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.4.0 h1:3IcvPOAvnCKwNm0TB0dLDTuawWEj+ax/RERNC+diLMM=
|
github.com/nicksnyder/go-i18n/v2 v2.4.0 h1:3IcvPOAvnCKwNm0TB0dLDTuawWEj+ax/RERNC+diLMM=
|
||||||
github.com/nicksnyder/go-i18n/v2 v2.4.0/go.mod h1:nxYSZE9M0bf3Y70gPQjN9ha7XNHX7gMc814+6wVyEI4=
|
github.com/nicksnyder/go-i18n/v2 v2.4.0/go.mod h1:nxYSZE9M0bf3Y70gPQjN9ha7XNHX7gMc814+6wVyEI4=
|
||||||
github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
|
github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
|
||||||
github.com/pelletier/go-toml v1.9.3/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c=
|
github.com/pelletier/go-toml v1.9.3/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c=
|
||||||
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
|
github.com/pkg/profile v1.7.0 h1:hnbDkaNWPCLMO9wGLdBFTIZvzDrDfBM2072E1S9gJkA=
|
||||||
|
github.com/pkg/profile v1.7.0/go.mod h1:8Uer0jas47ZQMJ7VD+OHknK4YDY07LPUC6dEvqDjvNo=
|
||||||
github.com/pkg/sftp v1.10.1/go.mod h1:lYOWFsE0bwd1+KfKJaKeuokY15vzFx25BLbzYYoAxZI=
|
github.com/pkg/sftp v1.10.1/go.mod h1:lYOWFsE0bwd1+KfKJaKeuokY15vzFx25BLbzYYoAxZI=
|
||||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
@@ -274,7 +267,6 @@ github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c/go.mod h1:cNQ3dwVJtS
|
|||||||
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef h1:Ch6Q+AZUxDBCVqdkI8FSpFyZDtCVBc2VmejdNrm5rRQ=
|
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef h1:Ch6Q+AZUxDBCVqdkI8FSpFyZDtCVBc2VmejdNrm5rRQ=
|
||||||
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef/go.mod h1:nXTWP6+gD5+LUJ8krVhhoeHjvHTutPxMYl5SvkcnJNE=
|
github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef/go.mod h1:nXTWP6+gD5+LUJ8krVhhoeHjvHTutPxMYl5SvkcnJNE=
|
||||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||||
github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
|
|
||||||
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
||||||
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
||||||
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
||||||
@@ -282,12 +274,13 @@ github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5
|
|||||||
github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
|
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
||||||
github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk=
|
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
||||||
github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo=
|
|
||||||
github.com/subosito/gotenv v1.2.0/go.mod h1:N0PQaV/YGNqwC0u51sEeR/aUtSLEXKX9iv69rRypqCw=
|
github.com/subosito/gotenv v1.2.0/go.mod h1:N0PQaV/YGNqwC0u51sEeR/aUtSLEXKX9iv69rRypqCw=
|
||||||
github.com/tevino/abool v1.2.0 h1:heAkClL8H6w+mK5md9dzsuohKeXHUpY7Vw0ZCKW+huA=
|
github.com/tevino/abool v1.2.0 h1:heAkClL8H6w+mK5md9dzsuohKeXHUpY7Vw0ZCKW+huA=
|
||||||
github.com/tevino/abool v1.2.0/go.mod h1:qc66Pna1RiIsPa7O4Egxxs9OqkuxDX55zznh9K07Tzg=
|
github.com/tevino/abool v1.2.0/go.mod h1:qc66Pna1RiIsPa7O4Egxxs9OqkuxDX55zznh9K07Tzg=
|
||||||
|
github.com/ulikunitz/xz v0.5.12 h1:37Nm15o69RwBkXM0J6A5OlE67RZTfzUxTj8fB3dfcsc=
|
||||||
|
github.com/ulikunitz/xz v0.5.12/go.mod h1:nbz6k7qbPmH4IRqmfOplQw/tblSgqTqBwxkY0oWt/14=
|
||||||
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
|
||||||
@@ -297,6 +290,8 @@ github.com/yuin/goldmark v1.4.0/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1
|
|||||||
github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
|
github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
|
||||||
github.com/yuin/goldmark v1.5.5 h1:IJznPe8wOzfIKETmMkd06F8nXkmlhaHqFRM9l1hAGsU=
|
github.com/yuin/goldmark v1.5.5 h1:IJznPe8wOzfIKETmMkd06F8nXkmlhaHqFRM9l1hAGsU=
|
||||||
github.com/yuin/goldmark v1.5.5/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
|
github.com/yuin/goldmark v1.5.5/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
|
||||||
|
go.etcd.io/bbolt v1.4.0 h1:TU77id3TnN/zKr7CO/uk+fBCwF2jGcMuw2B/FMAzYIk=
|
||||||
|
go.etcd.io/bbolt v1.4.0/go.mod h1:AsD+OCi/qPN1giOX1aiLAha3o1U8rAz65bvN4j0sRuk=
|
||||||
go.etcd.io/etcd/api/v3 v3.5.0/go.mod h1:cbVKeC6lCfl7j/8jBhAK6aIYO9XOjdptoxU/nLQcPvs=
|
go.etcd.io/etcd/api/v3 v3.5.0/go.mod h1:cbVKeC6lCfl7j/8jBhAK6aIYO9XOjdptoxU/nLQcPvs=
|
||||||
go.etcd.io/etcd/client/pkg/v3 v3.5.0/go.mod h1:IJHfcCEKxYu1Os13ZdwCwIUTUVGYTSAM3YSwc9/Ac1g=
|
go.etcd.io/etcd/client/pkg/v3 v3.5.0/go.mod h1:IJHfcCEKxYu1Os13ZdwCwIUTUVGYTSAM3YSwc9/Ac1g=
|
||||||
go.etcd.io/etcd/client/v2 v2.305.0/go.mod h1:h9puh54ZTgAKtEbut2oe9P4L/oqKCVB6xsXlzd7alYQ=
|
go.etcd.io/etcd/client/v2 v2.305.0/go.mod h1:h9puh54ZTgAKtEbut2oe9P4L/oqKCVB6xsXlzd7alYQ=
|
||||||
@@ -401,8 +396,6 @@ golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96b
|
|||||||
golang.org/x/net v0.0.0-20210805182204-aaa1db679c0d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
|
golang.org/x/net v0.0.0-20210805182204-aaa1db679c0d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
|
||||||
golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c=
|
golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c=
|
||||||
golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
|
golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
|
||||||
golang.org/x/net v0.17.0 h1:pVaXccu2ozPjCXewfr1S7xza/zcXTity9cCdXQYSjIM=
|
|
||||||
golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE=
|
|
||||||
golang.org/x/net v0.20.0 h1:aCL9BSgETF1k+blQaYUBx9hJ9LOGP3gAVemcZlf1Kpo=
|
golang.org/x/net v0.20.0 h1:aCL9BSgETF1k+blQaYUBx9hJ9LOGP3gAVemcZlf1Kpo=
|
||||||
golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY=
|
golang.org/x/net v0.20.0/go.mod h1:z8BVo6PvndSri0LbOE3hAn0apkU+1YvI6E70E9jsnvY=
|
||||||
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
|
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
|
||||||
@@ -430,6 +423,8 @@ golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJ
|
|||||||
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.10.0 h1:3NQrjDixjgGwUOCaF8w2+VYHv0Ve/vGYSbdkTa98gmQ=
|
||||||
|
golang.org/x/sync v0.10.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
|
||||||
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
golang.org/x/sys v0.0.0-20181026203630-95b1ffbd15a5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20181026203630-95b1ffbd15a5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
@@ -479,10 +474,8 @@ golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBc
|
|||||||
golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.13.0 h1:Af8nKPmuFypiUBjVoU9V20FiaFXOcuZI21p0ycVYYGE=
|
golang.org/x/sys v0.29.0 h1:TPYlXGxvx1MGTn2GiZDhnjPA9wZzZeGKHHmKhHYvgaU=
|
||||||
golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.29.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
||||||
golang.org/x/sys v0.16.0 h1:xWw16ngr6ZMtmxDyKyIgsE93KNKz5HKmMa3b8ALHidU=
|
|
||||||
golang.org/x/sys v0.16.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
|
||||||
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
|
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
|
||||||
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
|
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
|
||||||
golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
|
golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
|
||||||
@@ -677,12 +670,6 @@ gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C
|
|||||||
gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
||||||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gorm.io/driver/sqlite v1.5.4 h1:IqXwXi8M/ZlPzH/947tn5uik3aYQslP9BVveoax0nV0=
|
|
||||||
gorm.io/driver/sqlite v1.5.4/go.mod h1:qxAuCol+2r6PannQDpOP1FP6ag3mKi4esLnB/jHed+4=
|
|
||||||
gorm.io/gorm v1.25.5 h1:zR9lOiiYf09VNh5Q1gphfyia1JpiClIWG9hQaxB/mls=
|
|
||||||
gorm.io/gorm v1.25.5/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8=
|
|
||||||
gorm.io/gorm v1.25.6 h1:V92+vVda1wEISSOMtodHVRcUIOPYa2tgQtyF+DfFx+A=
|
|
||||||
gorm.io/gorm v1.25.6/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8=
|
|
||||||
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2 h1:oomkgU6VaQDsV6qZby2uz1Lap0eXmku8+2em3A/l700=
|
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2 h1:oomkgU6VaQDsV6qZby2uz1Lap0eXmku8+2em3A/l700=
|
||||||
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2/go.mod h1:sUMDUKNB2ZcVjt92UnLy3cdGs+wDAcrPdV3JP6sVgA4=
|
honnef.co/go/js/dom v0.0.0-20210725211120-f030747120f2/go.mod h1:sUMDUKNB2ZcVjt92UnLy3cdGs+wDAcrPdV3JP6sVgA4=
|
||||||
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
|
||||||
|
@@ -3,6 +3,8 @@ package handler
|
|||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor/view"
|
||||||
|
error2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/error"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/helper"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/helper"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
"github.com/nicksnyder/go-i18n/v2/i18n"
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
@@ -18,24 +20,33 @@ type ConvertorHandlerContract interface {
|
|||||||
type ConvertorHandler struct {
|
type ConvertorHandler struct {
|
||||||
app kernel.AppContract
|
app kernel.AppContract
|
||||||
convertorView convertor.ViewContract
|
convertorView convertor.ViewContract
|
||||||
|
errorView error2.ViewContract
|
||||||
convertorRepository convertor.RepositoryContract
|
convertorRepository convertor.RepositoryContract
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewConvertorHandler(
|
func NewConvertorHandler(
|
||||||
app kernel.AppContract,
|
app kernel.AppContract,
|
||||||
convertorView convertor.ViewContract,
|
convertorView convertor.ViewContract,
|
||||||
|
errorView error2.ViewContract,
|
||||||
convertorRepository convertor.RepositoryContract,
|
convertorRepository convertor.RepositoryContract,
|
||||||
) *ConvertorHandler {
|
) *ConvertorHandler {
|
||||||
return &ConvertorHandler{
|
return &ConvertorHandler{
|
||||||
app: app,
|
app: app,
|
||||||
convertorView: convertorView,
|
convertorView: convertorView,
|
||||||
|
errorView: errorView,
|
||||||
convertorRepository: convertorRepository,
|
convertorRepository: convertorRepository,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h ConvertorHandler) MainConvertor() {
|
func (h ConvertorHandler) MainConvertor() {
|
||||||
if h.checkingFFPathUtilities() == true {
|
if h.checkingFFPathUtilities() == true {
|
||||||
h.convertorView.Main(h.runConvert)
|
formats, err := h.app.GetConvertorService().GetSupportFormats()
|
||||||
|
if err != nil {
|
||||||
|
h.errorView.PanicError(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
conversion := view.NewConversion(h.app, formats, h.runConvert)
|
||||||
|
h.convertorView.Main(conversion)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
h.convertorView.SelectFFPath("", "", h.saveSettingFFPath, nil, h.downloadFFmpeg)
|
h.convertorView.SelectFFPath("", "", h.saveSettingFFPath, nil, h.downloadFFmpeg)
|
||||||
@@ -55,15 +66,16 @@ func (h ConvertorHandler) GetFfprobeVersion() (string, error) {
|
|||||||
return h.app.GetConvertorService().GetFFprobeVersion()
|
return h.app.GetConvertorService().GetFFprobeVersion()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h ConvertorHandler) runConvert(setting convertor.HandleConvertSetting) {
|
func (h ConvertorHandler) runConvert(setting view.HandleConvertSetting) {
|
||||||
h.app.GetQueue().Add(&kernel.ConvertSetting{
|
h.app.GetQueue().Add(&kernel.ConvertSetting{
|
||||||
VideoFileInput: setting.VideoFileInput,
|
VideoFileInput: setting.FileInput,
|
||||||
VideoFileOut: kernel.File{
|
VideoFileOut: kernel.File{
|
||||||
Path: setting.DirectoryForSave + helper.PathSeparator() + setting.VideoFileInput.Name + ".mp4",
|
Path: setting.DirectoryForSave + helper.PathSeparator() + setting.FileInput.Name + "." + setting.Format,
|
||||||
Name: setting.VideoFileInput.Name,
|
Name: setting.FileInput.Name,
|
||||||
Ext: ".mp4",
|
Ext: "." + setting.Format,
|
||||||
},
|
},
|
||||||
OverwriteOutputFiles: setting.OverwriteOutputFiles,
|
OverwriteOutputFiles: setting.OverwriteOutputFiles,
|
||||||
|
Encoder: setting.Encoder,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
//go:build !windows
|
//go:build !windows && !linux
|
||||||
// +build !windows
|
// +build !windows,!linux
|
||||||
|
|
||||||
package handler
|
package handler
|
||||||
|
|
||||||
|
208
handler/convertor_linux.go
Normal file
208
handler/convertor_linux.go
Normal file
@@ -0,0 +1,208 @@
|
|||||||
|
//go:build linux
|
||||||
|
// +build linux
|
||||||
|
|
||||||
|
package handler
|
||||||
|
|
||||||
|
import (
|
||||||
|
"archive/tar"
|
||||||
|
"errors"
|
||||||
|
"fyne.io/fyne/v2/canvas"
|
||||||
|
"fyne.io/fyne/v2/widget"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
|
"github.com/nicksnyder/go-i18n/v2/i18n"
|
||||||
|
"github.com/ulikunitz/xz"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
)
|
||||||
|
|
||||||
|
func getPathsToFF() []kernel.FFPathUtilities {
|
||||||
|
return []kernel.FFPathUtilities{{"ffmpeg/bin/ffmpeg", "ffmpeg/bin/ffprobe"}, {"ffmpeg", "ffprobe"}}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h ConvertorHandler) downloadFFmpeg(progressBar *widget.ProgressBar, progressMessage *canvas.Text) (err error) {
|
||||||
|
isDirectoryFFmpeg := isDirectory("ffmpeg")
|
||||||
|
if isDirectoryFFmpeg == false {
|
||||||
|
err = os.Mkdir("ffmpeg", 0777)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
progressMessage.Text = h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "downloadRun",
|
||||||
|
})
|
||||||
|
progressMessage.Refresh()
|
||||||
|
err = downloadFile("ffmpeg/ffmpeg.tar.xz", "https://github.com/BtbN/FFmpeg-Builds/releases/download/latest/ffmpeg-master-latest-linux64-gpl.tar.xz", progressBar)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
progressMessage.Text = h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "unzipRun",
|
||||||
|
})
|
||||||
|
progressMessage.Refresh()
|
||||||
|
err = unTarXz("ffmpeg/ffmpeg.tar.xz", "ffmpeg", progressBar)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
_ = os.Remove("ffmpeg/ffmpeg.tar.xz")
|
||||||
|
|
||||||
|
progressMessage.Text = h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
|
MessageID: "testFF",
|
||||||
|
})
|
||||||
|
progressMessage.Refresh()
|
||||||
|
|
||||||
|
err = h.saveSettingFFPath("ffmpeg/ffmpeg-master-latest-linux64-gpl/bin/ffmpeg", "ffmpeg/ffmpeg-master-latest-linux64-gpl/bin/ffprobe")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func downloadFile(filepath string, url string, progressBar *widget.ProgressBar) (err error) {
|
||||||
|
progressBar.Value = 0
|
||||||
|
progressBar.Max = 100
|
||||||
|
|
||||||
|
req, err := http.NewRequest("GET", url, nil)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
resp, err := http.DefaultClient.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
|
||||||
|
f, err := os.OpenFile(filepath, os.O_CREATE|os.O_WRONLY, 0644)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
|
||||||
|
buf := make([]byte, 32*1024)
|
||||||
|
var downloaded int64
|
||||||
|
for {
|
||||||
|
n, err := resp.Body.Read(buf)
|
||||||
|
if err != nil {
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if n > 0 {
|
||||||
|
f.Write(buf[:n])
|
||||||
|
downloaded += int64(n)
|
||||||
|
progressBar.Value = float64(downloaded) / float64(resp.ContentLength) * 100
|
||||||
|
progressBar.Refresh()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func unTarXz(fileTar string, directory string, progressBar *widget.ProgressBar) error {
|
||||||
|
progressBar.Value = 0
|
||||||
|
progressBar.Max = 100
|
||||||
|
|
||||||
|
f, err := os.Open(fileTar)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer f.Close()
|
||||||
|
|
||||||
|
xzReader, err := xz.NewReader(f)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
tarReader := tar.NewReader(xzReader)
|
||||||
|
|
||||||
|
totalFiles := 0
|
||||||
|
for {
|
||||||
|
_, err := tarReader.Next()
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
totalFiles++
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rewind back to the beginning of the file to re-process
|
||||||
|
_, err = f.Seek(0, 0)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
xzReader, err = xz.NewReader(f)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
tarReader = tar.NewReader(xzReader)
|
||||||
|
|
||||||
|
// We count the number of files already unpacked
|
||||||
|
unpackedFiles := 0
|
||||||
|
|
||||||
|
for {
|
||||||
|
header, err := tarReader.Next()
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
targetPath := filepath.Join(directory, header.Name)
|
||||||
|
switch header.Typeflag {
|
||||||
|
case tar.TypeDir:
|
||||||
|
err := os.MkdirAll(targetPath, 0755)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
case tar.TypeReg:
|
||||||
|
outFile, err := os.Create(targetPath)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer outFile.Close()
|
||||||
|
|
||||||
|
_, err = io.Copy(outFile, tarReader)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
return errors.New("unsupported file type")
|
||||||
|
}
|
||||||
|
|
||||||
|
unpackedFiles++
|
||||||
|
progressBar.Value = float64(unpackedFiles) / float64(totalFiles) * 100
|
||||||
|
progressBar.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
ffmpegPath := filepath.Join(directory, "ffmpeg-master-latest-linux64-gpl", "bin", "ffmpeg")
|
||||||
|
err = os.Chmod(ffmpegPath, 0755)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
ffprobePath := filepath.Join(directory, "ffmpeg-master-latest-linux64-gpl", "bin", "ffprobe")
|
||||||
|
err = os.Chmod(ffprobePath, 0755)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func isDirectory(path string) bool {
|
||||||
|
fileInfo, err := os.Stat(path)
|
||||||
|
if err != nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
return fileInfo.IsDir()
|
||||||
|
}
|
@@ -42,7 +42,7 @@ func (h ConvertorHandler) downloadFFmpeg(progressBar *widget.ProgressBar, progre
|
|||||||
MessageID: "unzipRun",
|
MessageID: "unzipRun",
|
||||||
})
|
})
|
||||||
progressMessage.Refresh()
|
progressMessage.Refresh()
|
||||||
err = unZip("ffmpeg/ffmpeg.zip", "ffmpeg")
|
err = unZip("ffmpeg/ffmpeg.zip", "ffmpeg", progressBar)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -100,13 +100,23 @@ func downloadFile(filepath string, url string, progressBar *widget.ProgressBar)
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func unZip(fileZip string, directory string) error {
|
func unZip(fileZip string, directory string, progressBar *widget.ProgressBar) error {
|
||||||
|
progressBar.Value = 0
|
||||||
|
progressBar.Max = 100
|
||||||
|
|
||||||
archive, err := zip.OpenReader(fileZip)
|
archive, err := zip.OpenReader(fileZip)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
defer archive.Close()
|
defer archive.Close()
|
||||||
|
|
||||||
|
totalBytes := int64(0)
|
||||||
|
for _, f := range archive.File {
|
||||||
|
totalBytes += int64(f.UncompressedSize64)
|
||||||
|
}
|
||||||
|
|
||||||
|
unpackedBytes := int64(0)
|
||||||
|
|
||||||
for _, f := range archive.File {
|
for _, f := range archive.File {
|
||||||
filePath := filepath.Join(directory, f.Name)
|
filePath := filepath.Join(directory, f.Name)
|
||||||
|
|
||||||
@@ -132,10 +142,15 @@ func unZip(fileZip string, directory string) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if _, err := io.Copy(dstFile, fileInArchive); err != nil {
|
bytesRead, err := io.Copy(dstFile, fileInArchive)
|
||||||
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unpackedBytes += bytesRead
|
||||||
|
progressBar.Value = float64(unpackedBytes) / float64(totalBytes) * 100
|
||||||
|
progressBar.Refresh()
|
||||||
|
|
||||||
dstFile.Close()
|
dstFile.Close()
|
||||||
fileInArchive.Close()
|
fileInArchive.Close()
|
||||||
}
|
}
|
||||||
|
@@ -19,7 +19,6 @@ type MenuHandler struct {
|
|||||||
menuView menu.ViewContract
|
menuView menu.ViewContract
|
||||||
localizerView localizer.ViewContract
|
localizerView localizer.ViewContract
|
||||||
localizerRepository localizer.RepositoryContract
|
localizerRepository localizer.RepositoryContract
|
||||||
localizerListener localizerListenerContract
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewMenuHandler(
|
func NewMenuHandler(
|
||||||
@@ -28,7 +27,6 @@ func NewMenuHandler(
|
|||||||
menuView menu.ViewContract,
|
menuView menu.ViewContract,
|
||||||
localizerView localizer.ViewContract,
|
localizerView localizer.ViewContract,
|
||||||
localizerRepository localizer.RepositoryContract,
|
localizerRepository localizer.RepositoryContract,
|
||||||
localizerListener localizerListenerContract,
|
|
||||||
) *MenuHandler {
|
) *MenuHandler {
|
||||||
return &MenuHandler{
|
return &MenuHandler{
|
||||||
app: app,
|
app: app,
|
||||||
@@ -36,7 +34,6 @@ func NewMenuHandler(
|
|||||||
menuView: menuView,
|
menuView: menuView,
|
||||||
localizerView: localizerView,
|
localizerView: localizerView,
|
||||||
localizerRepository: localizerRepository,
|
localizerRepository: localizerRepository,
|
||||||
localizerListener: localizerListener,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -52,22 +49,31 @@ func (h MenuHandler) getMenuSettings() *fyne.Menu {
|
|||||||
MessageID: "exit",
|
MessageID: "exit",
|
||||||
}), nil)
|
}), nil)
|
||||||
quit.IsQuit = true
|
quit.IsQuit = true
|
||||||
h.localizerListener.AddMenuItem("exit", quit)
|
h.app.GetLocalizerService().AddChangeCallback("exit", func(text string) {
|
||||||
|
quit.Label = text
|
||||||
|
})
|
||||||
|
|
||||||
languageSelection := fyne.NewMenuItem(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
languageSelection := fyne.NewMenuItem(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
MessageID: "changeLanguage",
|
MessageID: "changeLanguage",
|
||||||
}), h.LanguageSelection)
|
}), h.LanguageSelection)
|
||||||
h.localizerListener.AddMenuItem("changeLanguage", languageSelection)
|
h.app.GetLocalizerService().AddChangeCallback("changeLanguage", func(text string) {
|
||||||
|
languageSelection.Label = text
|
||||||
|
})
|
||||||
|
|
||||||
ffPathSelection := fyne.NewMenuItem(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
ffPathSelection := fyne.NewMenuItem(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
MessageID: "changeFFPath",
|
MessageID: "changeFFPath",
|
||||||
}), h.convertorHandler.FfPathSelection)
|
}), h.convertorHandler.FfPathSelection)
|
||||||
h.localizerListener.AddMenuItem("changeFFPath", ffPathSelection)
|
h.app.GetLocalizerService().AddChangeCallback("changeFFPath", func(text string) {
|
||||||
|
ffPathSelection.Label = text
|
||||||
|
})
|
||||||
|
|
||||||
settings := fyne.NewMenu(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
settings := fyne.NewMenu(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
MessageID: "settings",
|
MessageID: "settings",
|
||||||
}), languageSelection, ffPathSelection, quit)
|
}), languageSelection, ffPathSelection, quit)
|
||||||
h.localizerListener.AddMenu("settings", settings)
|
h.app.GetLocalizerService().AddChangeCallback("settings", func(text string) {
|
||||||
|
settings.Label = text
|
||||||
|
settings.Refresh()
|
||||||
|
})
|
||||||
|
|
||||||
return settings
|
return settings
|
||||||
}
|
}
|
||||||
@@ -76,12 +82,17 @@ func (h MenuHandler) getMenuHelp() *fyne.Menu {
|
|||||||
about := fyne.NewMenuItem(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
about := fyne.NewMenuItem(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
MessageID: "about",
|
MessageID: "about",
|
||||||
}), h.openAbout)
|
}), h.openAbout)
|
||||||
h.localizerListener.AddMenuItem("about", about)
|
h.app.GetLocalizerService().AddChangeCallback("about", func(text string) {
|
||||||
|
about.Label = text
|
||||||
|
})
|
||||||
|
|
||||||
help := fyne.NewMenu(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
help := fyne.NewMenu(h.app.GetLocalizerService().GetMessage(&i18n.LocalizeConfig{
|
||||||
MessageID: "help",
|
MessageID: "help",
|
||||||
}), about)
|
}), about)
|
||||||
h.localizerListener.AddMenu("help", help)
|
h.app.GetLocalizerService().AddChangeCallback("help", func(text string) {
|
||||||
|
help.Label = text
|
||||||
|
help.Refresh()
|
||||||
|
})
|
||||||
|
|
||||||
return help
|
return help
|
||||||
}
|
}
|
||||||
@@ -109,41 +120,3 @@ func (h MenuHandler) LanguageSelection() {
|
|||||||
h.convertorHandler.MainConvertor()
|
h.convertorHandler.MainConvertor()
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
type menuItems struct {
|
|
||||||
menuItem map[string]*fyne.MenuItem
|
|
||||||
menu map[string]*fyne.Menu
|
|
||||||
}
|
|
||||||
|
|
||||||
type LocalizerListener struct {
|
|
||||||
menuItems *menuItems
|
|
||||||
}
|
|
||||||
|
|
||||||
type localizerListenerContract interface {
|
|
||||||
AddMenu(messageID string, menu *fyne.Menu)
|
|
||||||
AddMenuItem(messageID string, menuItem *fyne.MenuItem)
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewLocalizerListener() *LocalizerListener {
|
|
||||||
return &LocalizerListener{
|
|
||||||
&menuItems{menuItem: map[string]*fyne.MenuItem{}, menu: map[string]*fyne.Menu{}},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l LocalizerListener) AddMenu(messageID string, menu *fyne.Menu) {
|
|
||||||
l.menuItems.menu[messageID] = menu
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l LocalizerListener) AddMenuItem(messageID string, menuItem *fyne.MenuItem) {
|
|
||||||
l.menuItems.menuItem[messageID] = menuItem
|
|
||||||
}
|
|
||||||
|
|
||||||
func (l LocalizerListener) Change(localizerService kernel.LocalizerContract) {
|
|
||||||
for messageID, menu := range l.menuItems.menuItem {
|
|
||||||
menu.Label = localizerService.GetMessage(&i18n.LocalizeConfig{MessageID: messageID})
|
|
||||||
}
|
|
||||||
for messageID, menu := range l.menuItems.menu {
|
|
||||||
menu.Label = localizerService.GetMessage(&i18n.LocalizeConfig{MessageID: messageID})
|
|
||||||
menu.Refresh()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 45 KiB After Width: | Height: | Size: 64 KiB |
@@ -1,8 +1,11 @@
|
|||||||
package kernel
|
package kernel
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bufio"
|
||||||
"errors"
|
"errors"
|
||||||
|
encoder2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/helper"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/helper"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel/encoder"
|
||||||
"io"
|
"io"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"regexp"
|
"regexp"
|
||||||
@@ -10,6 +13,19 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type File struct {
|
||||||
|
Path string
|
||||||
|
Name string
|
||||||
|
Ext string
|
||||||
|
}
|
||||||
|
|
||||||
|
type ConvertSetting struct {
|
||||||
|
VideoFileInput File
|
||||||
|
VideoFileOut File
|
||||||
|
OverwriteOutputFiles bool
|
||||||
|
Encoder encoder2.EncoderContract
|
||||||
|
}
|
||||||
|
|
||||||
type ConvertorContract interface {
|
type ConvertorContract interface {
|
||||||
RunConvert(setting ConvertSetting, progress ProgressContract) error
|
RunConvert(setting ConvertSetting, progress ProgressContract) error
|
||||||
GetTotalDuration(file *File) (float64, error)
|
GetTotalDuration(file *File) (float64, error)
|
||||||
@@ -18,6 +34,7 @@ type ConvertorContract interface {
|
|||||||
ChangeFFmpegPath(path string) (bool, error)
|
ChangeFFmpegPath(path string) (bool, error)
|
||||||
ChangeFFprobePath(path string) (bool, error)
|
ChangeFFprobePath(path string) (bool, error)
|
||||||
GetRunningProcesses() map[int]*exec.Cmd
|
GetRunningProcesses() map[int]*exec.Cmd
|
||||||
|
GetSupportFormats() (encoder.ConvertorFormatsContract, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
type ProgressContract interface {
|
type ProgressContract interface {
|
||||||
@@ -56,7 +73,9 @@ func (s Convertor) RunConvert(setting ConvertSetting, progress ProgressContract)
|
|||||||
if setting.OverwriteOutputFiles == true {
|
if setting.OverwriteOutputFiles == true {
|
||||||
overwriteOutputFiles = "-y"
|
overwriteOutputFiles = "-y"
|
||||||
}
|
}
|
||||||
args := []string{overwriteOutputFiles, "-i", setting.VideoFileInput.Path, "-c:v", "libx264", "-progress", progress.GetProtocole(), setting.VideoFileOut.Path}
|
args := []string{overwriteOutputFiles, "-i", setting.VideoFileInput.Path}
|
||||||
|
args = append(args, setting.Encoder.GetParams()...)
|
||||||
|
args = append(args, "-progress", progress.GetProtocole(), setting.VideoFileOut.Path)
|
||||||
cmd := exec.Command(s.ffPathUtilities.FFmpeg, args...)
|
cmd := exec.Command(s.ffPathUtilities.FFmpeg, args...)
|
||||||
helper.PrepareBackgroundCommand(cmd)
|
helper.PrepareBackgroundCommand(cmd)
|
||||||
|
|
||||||
@@ -103,7 +122,30 @@ func (s Convertor) GetTotalDuration(file *File) (duration float64, err error) {
|
|||||||
}
|
}
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
return strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
|
frames := strings.TrimSpace(string(out))
|
||||||
|
if len(frames) == 0 {
|
||||||
|
return s.getAlternativeTotalDuration(file)
|
||||||
|
}
|
||||||
|
return strconv.ParseFloat(frames, 64)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s Convertor) getAlternativeTotalDuration(file *File) (duration float64, err error) {
|
||||||
|
args := []string{"-v", "error", "-select_streams", "a:0", "-count_packets", "-show_entries", "stream=nb_read_packets", "-of", "csv=p=0", file.Path}
|
||||||
|
cmd := exec.Command(s.ffPathUtilities.FFprobe, args...)
|
||||||
|
helper.PrepareBackgroundCommand(cmd)
|
||||||
|
out, err := cmd.CombinedOutput()
|
||||||
|
if err != nil {
|
||||||
|
errString := strings.TrimSpace(string(out))
|
||||||
|
if len(errString) > 1 {
|
||||||
|
return 0, errors.New(errString)
|
||||||
|
}
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
frames := strings.TrimSpace(string(out))
|
||||||
|
if len(frames) == 0 {
|
||||||
|
return 0, errors.New("error getting number of frames")
|
||||||
|
}
|
||||||
|
return strconv.ParseFloat(frames, 64)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s Convertor) GetFFmpegVesrion() (string, error) {
|
func (s Convertor) GetFFmpegVesrion() (string, error) {
|
||||||
@@ -156,6 +198,46 @@ func (s Convertor) ChangeFFprobePath(path string) (bool, error) {
|
|||||||
return true, nil
|
return true, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s Convertor) GetSupportFormats() (encoder.ConvertorFormatsContract, error) {
|
||||||
|
formats := encoder.NewConvertorFormats()
|
||||||
|
cmd := exec.Command(s.ffPathUtilities.FFmpeg, "-encoders")
|
||||||
|
helper.PrepareBackgroundCommand(cmd)
|
||||||
|
|
||||||
|
stdOut, err := cmd.StdoutPipe()
|
||||||
|
if err != nil {
|
||||||
|
return formats, err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = cmd.Start()
|
||||||
|
if err != nil {
|
||||||
|
return formats, err
|
||||||
|
}
|
||||||
|
|
||||||
|
scannerErr := bufio.NewReader(stdOut)
|
||||||
|
for {
|
||||||
|
line, _, err := scannerErr.ReadLine()
|
||||||
|
if err != nil {
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
text := strings.Split(strings.TrimSpace(string(line)), " ")
|
||||||
|
encoderType := string(text[0][0])
|
||||||
|
if len(text) < 2 || (encoderType != "V" && encoderType != "A") {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
formats.NewEncoder(text[1])
|
||||||
|
}
|
||||||
|
|
||||||
|
err = cmd.Wait()
|
||||||
|
if err != nil {
|
||||||
|
return formats, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return formats, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (s Convertor) GetRunningProcesses() map[int]*exec.Cmd {
|
func (s Convertor) GetRunningProcesses() map[int]*exec.Cmd {
|
||||||
return s.runningProcesses.items
|
return s.runningProcesses.items
|
||||||
}
|
}
|
||||||
|
84
kernel/encoder/encoder.go
Normal file
84
kernel/encoder/encoder.go
Normal file
@@ -0,0 +1,84 @@
|
|||||||
|
package encoder
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ConvertorFormatContract interface {
|
||||||
|
GetTitle() string
|
||||||
|
AddEncoder(encoder encoder.EncoderDataContract)
|
||||||
|
GetFileType() encoder.FileTypeContract
|
||||||
|
GetEncoders() map[int]encoder.EncoderDataContract
|
||||||
|
}
|
||||||
|
|
||||||
|
type ConvertorFormat struct {
|
||||||
|
title string
|
||||||
|
fileType encoder.FileTypeContract
|
||||||
|
encoders map[int]encoder.EncoderDataContract
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewConvertorFormat(title string, fileType encoder.FileTypeContract) *ConvertorFormat {
|
||||||
|
return &ConvertorFormat{
|
||||||
|
title: title,
|
||||||
|
fileType: fileType,
|
||||||
|
encoders: map[int]encoder.EncoderDataContract{},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f ConvertorFormat) GetTitle() string {
|
||||||
|
return f.title
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f ConvertorFormat) AddEncoder(encoder encoder.EncoderDataContract) {
|
||||||
|
f.encoders[len(f.encoders)] = encoder
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f ConvertorFormat) GetEncoders() map[int]encoder.EncoderDataContract {
|
||||||
|
return f.encoders
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f ConvertorFormat) GetFileType() encoder.FileTypeContract {
|
||||||
|
return f.fileType
|
||||||
|
}
|
||||||
|
|
||||||
|
type ConvertorFormatsContract interface {
|
||||||
|
NewEncoder(encoderName string) bool
|
||||||
|
GetFormats() map[string]ConvertorFormatContract
|
||||||
|
GetFormat(format string) (ConvertorFormatContract, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
type ConvertorFormats struct {
|
||||||
|
formats map[string]ConvertorFormatContract
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewConvertorFormats() *ConvertorFormats {
|
||||||
|
return &ConvertorFormats{
|
||||||
|
formats: map[string]ConvertorFormatContract{},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f ConvertorFormats) NewEncoder(encoderName string) bool {
|
||||||
|
if supportEncoders[encoderName] == nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
data := supportEncoders[encoderName]()
|
||||||
|
for _, format := range data.GetFormats() {
|
||||||
|
if f.formats[format] == nil {
|
||||||
|
f.formats[format] = NewConvertorFormat(format, data.GetFileType())
|
||||||
|
}
|
||||||
|
f.formats[format].AddEncoder(data)
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f ConvertorFormats) GetFormats() map[string]ConvertorFormatContract {
|
||||||
|
return f.formats
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f ConvertorFormats) GetFormat(format string) (ConvertorFormatContract, error) {
|
||||||
|
if f.formats[format] == nil {
|
||||||
|
return ConvertorFormat{}, errors.New("not found ConvertorFormat")
|
||||||
|
}
|
||||||
|
return f.formats[format], nil
|
||||||
|
}
|
74
kernel/encoder/encoders.go
Normal file
74
kernel/encoder/encoders.go
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
package encoder
|
||||||
|
|
||||||
|
import (
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/apng"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/bmp"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/flv"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/gif"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/h264_nvenc"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libmp3lame"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libshine"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libtwolame"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libvpx"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libvpx_vp9"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libwebp"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libwebp_anim"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libx264"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libx265"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/libxvid"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/mjpeg"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/mp2"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/mp2fixed"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/mpeg1video"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/mpeg2video"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/mpeg4"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/msmpeg4"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/msmpeg4v2"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/msvideo1"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/png"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/qtrle"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/sgi"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/tiff"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/wmav1"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/wmav2"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/wmv1"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/wmv2"
|
||||||
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/encoder/xbm"
|
||||||
|
)
|
||||||
|
|
||||||
|
var supportEncoders = map[string]func() encoder.EncoderDataContract{
|
||||||
|
"libx264": libx264.NewData,
|
||||||
|
"h264_nvenc": h264_nvenc.NewData,
|
||||||
|
"libx265": libx265.NewData,
|
||||||
|
"png": png.NewData,
|
||||||
|
"gif": gif.NewData,
|
||||||
|
"flv": flv.NewData,
|
||||||
|
"apng": apng.NewData,
|
||||||
|
"bmp": bmp.NewData,
|
||||||
|
"mjpeg": mjpeg.NewData,
|
||||||
|
"mpeg1video": mpeg1video.NewData,
|
||||||
|
"mpeg2video": mpeg2video.NewData,
|
||||||
|
"mpeg4": mpeg4.NewData,
|
||||||
|
"libxvid": libxvid.NewData,
|
||||||
|
"msmpeg4v2": msmpeg4v2.NewData,
|
||||||
|
"msmpeg4": msmpeg4.NewData,
|
||||||
|
"msvideo1": msvideo1.NewData,
|
||||||
|
"qtrle": qtrle.NewData,
|
||||||
|
"tiff": tiff.NewData,
|
||||||
|
"sgi": sgi.NewData,
|
||||||
|
"libvpx": libvpx.NewData,
|
||||||
|
"libvpx-vp9": libvpx_vp9.NewData,
|
||||||
|
"libwebp_anim": libwebp_anim.NewData,
|
||||||
|
"libwebp": libwebp.NewData,
|
||||||
|
"wmv1": wmv1.NewData,
|
||||||
|
"wmv2": wmv2.NewData,
|
||||||
|
"xbm": xbm.NewData,
|
||||||
|
"mp2": mp2.NewData,
|
||||||
|
"mp2fixed": mp2fixed.NewData,
|
||||||
|
"libtwolame": libtwolame.NewData,
|
||||||
|
"libmp3lame": libmp3lame.NewData,
|
||||||
|
"libshine": libshine.NewData,
|
||||||
|
"wmav1": wmav1.NewData,
|
||||||
|
"wmav2": wmav2.NewData,
|
||||||
|
}
|
304
kernel/layout.go
304
kernel/layout.go
@@ -65,7 +65,7 @@ type QueueLayoutObject struct {
|
|||||||
container *fyne.Container
|
container *fyne.Container
|
||||||
items map[int]QueueLayoutItem
|
items map[int]QueueLayoutItem
|
||||||
localizerService LocalizerContract
|
localizerService LocalizerContract
|
||||||
layoutLocalizerListener LayoutLocalizerListenerContract
|
queueStatisticsFormat *queueStatisticsFormat
|
||||||
}
|
}
|
||||||
|
|
||||||
type QueueLayoutItem struct {
|
type QueueLayoutItem struct {
|
||||||
@@ -73,20 +73,31 @@ type QueueLayoutItem struct {
|
|||||||
ProgressBar *widget.ProgressBar
|
ProgressBar *widget.ProgressBar
|
||||||
StatusMessage *canvas.Text
|
StatusMessage *canvas.Text
|
||||||
MessageError *canvas.Text
|
MessageError *canvas.Text
|
||||||
|
|
||||||
|
status *StatusContract
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewQueueLayoutObject(queue QueueListContract, localizerService LocalizerContract, layoutLocalizerListener LayoutLocalizerListenerContract) *QueueLayoutObject {
|
func NewQueueLayoutObject(queue QueueListContract, localizerService LocalizerContract) *QueueLayoutObject {
|
||||||
title := widget.NewLabel(localizerService.GetMessage(&i18n.LocalizeConfig{MessageID: "queue"}) + ":")
|
title := widget.NewLabel(localizerService.GetMessage(&i18n.LocalizeConfig{MessageID: "queue"}))
|
||||||
title.TextStyle.Bold = true
|
title.TextStyle.Bold = true
|
||||||
|
|
||||||
layoutLocalizerListener.AddItem("queue", title)
|
localizerService.AddChangeCallback("queue", func(text string) {
|
||||||
|
title.Text = text
|
||||||
|
title.Refresh()
|
||||||
|
})
|
||||||
|
|
||||||
|
items := map[int]QueueLayoutItem{}
|
||||||
|
queueStatisticsFormat := newQueueStatisticsFormat(localizerService, &items)
|
||||||
|
|
||||||
queueLayoutObject := &QueueLayoutObject{
|
queueLayoutObject := &QueueLayoutObject{
|
||||||
queue: queue,
|
queue: queue,
|
||||||
container: container.NewVBox(title),
|
container: container.NewVBox(
|
||||||
items: map[int]QueueLayoutItem{},
|
container.NewHBox(title, queueStatisticsFormat.completed.widget, queueStatisticsFormat.error.widget),
|
||||||
|
container.NewHBox(queueStatisticsFormat.inProgress.widget, queueStatisticsFormat.waiting.widget, queueStatisticsFormat.total.widget),
|
||||||
|
),
|
||||||
|
items: items,
|
||||||
localizerService: localizerService,
|
localizerService: localizerService,
|
||||||
layoutLocalizerListener: layoutLocalizerListener,
|
queueStatisticsFormat: queueStatisticsFormat,
|
||||||
}
|
}
|
||||||
|
|
||||||
queue.AddListener(queueLayoutObject)
|
queue.AddListener(queueLayoutObject)
|
||||||
@@ -118,11 +129,18 @@ func (o QueueLayoutObject) Add(id int, queue *Queue) {
|
|||||||
canvas.NewLine(theme.FocusColor()),
|
canvas.NewLine(theme.FocusColor()),
|
||||||
container.NewPadded(),
|
container.NewPadded(),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
o.queueStatisticsFormat.addQueue()
|
||||||
|
if o.queueStatisticsFormat.isChecked(queue.Status) == false {
|
||||||
|
content.Hide()
|
||||||
|
}
|
||||||
|
|
||||||
o.items[id] = QueueLayoutItem{
|
o.items[id] = QueueLayoutItem{
|
||||||
CanvasObject: content,
|
CanvasObject: content,
|
||||||
ProgressBar: progressBar,
|
ProgressBar: progressBar,
|
||||||
StatusMessage: statusMessage,
|
StatusMessage: statusMessage,
|
||||||
MessageError: messageError,
|
MessageError: messageError,
|
||||||
|
status: &queue.Status,
|
||||||
}
|
}
|
||||||
o.container.Add(content)
|
o.container.Add(content)
|
||||||
}
|
}
|
||||||
@@ -130,6 +148,7 @@ func (o QueueLayoutObject) Add(id int, queue *Queue) {
|
|||||||
func (o QueueLayoutObject) Remove(id int) {
|
func (o QueueLayoutObject) Remove(id int) {
|
||||||
if item, ok := o.items[id]; ok {
|
if item, ok := o.items[id]; ok {
|
||||||
o.container.Remove(item.CanvasObject)
|
o.container.Remove(item.CanvasObject)
|
||||||
|
o.queueStatisticsFormat.removeQueue(*item.status)
|
||||||
o.items[id] = QueueLayoutItem{}
|
o.items[id] = QueueLayoutItem{}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -145,6 +164,12 @@ func (o QueueLayoutObject) ChangeQueueStatus(queueId int, queue *Queue) {
|
|||||||
item.MessageError.Color = statusColor
|
item.MessageError.Color = statusColor
|
||||||
item.MessageError.Refresh()
|
item.MessageError.Refresh()
|
||||||
}
|
}
|
||||||
|
if o.queueStatisticsFormat.isChecked(queue.Status) == false && item.CanvasObject.Visible() == true {
|
||||||
|
item.CanvasObject.Hide()
|
||||||
|
} else if item.CanvasObject.Visible() == false {
|
||||||
|
item.CanvasObject.Show()
|
||||||
|
}
|
||||||
|
o.queueStatisticsFormat.changeQueue(queue.Status)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -161,7 +186,7 @@ func (o QueueLayoutObject) getStatusColor(status StatusContract) color.Color {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (o QueueLayoutObject) getStatusTitle(status StatusContract) string {
|
func (o QueueLayoutObject) getStatusTitle(status StatusContract) string {
|
||||||
return o.localizerService.GetMessage(&i18n.LocalizeConfig{MessageID: status.name()})
|
return o.localizerService.GetMessage(&i18n.LocalizeConfig{MessageID: status.Name() + "Queue"})
|
||||||
}
|
}
|
||||||
|
|
||||||
type Progress struct {
|
type Progress struct {
|
||||||
@@ -254,35 +279,256 @@ func (p Progress) Run(stdOut io.ReadCloser, stdErr io.ReadCloser) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
type LayoutLocalizerItem struct {
|
type queueStatistics struct {
|
||||||
messageID string
|
widget *widget.Check
|
||||||
object *widget.Label
|
title string
|
||||||
|
count *int64
|
||||||
|
}
|
||||||
|
type queueStatisticsFormat struct {
|
||||||
|
waiting *queueStatistics
|
||||||
|
inProgress *queueStatistics
|
||||||
|
completed *queueStatistics
|
||||||
|
error *queueStatistics
|
||||||
|
total *queueStatistics
|
||||||
}
|
}
|
||||||
|
|
||||||
type LayoutLocalizerListener struct {
|
func newQueueStatisticsFormat(localizerService LocalizerContract, queueItems *map[int]QueueLayoutItem) *queueStatisticsFormat {
|
||||||
itemCurrentId int
|
checkWaiting := newQueueStatistics("waitingQueue", localizerService)
|
||||||
items map[int]*LayoutLocalizerItem
|
checkInProgress := newQueueStatistics("inProgressQueue", localizerService)
|
||||||
|
checkCompleted := newQueueStatistics("completedQueue", localizerService)
|
||||||
|
checkError := newQueueStatistics("errorQueue", localizerService)
|
||||||
|
checkTotal := newQueueStatistics("total", localizerService)
|
||||||
|
|
||||||
|
queueStatisticsFormat := &queueStatisticsFormat{
|
||||||
|
waiting: checkWaiting,
|
||||||
|
inProgress: checkInProgress,
|
||||||
|
completed: checkCompleted,
|
||||||
|
error: checkError,
|
||||||
|
total: checkTotal,
|
||||||
|
}
|
||||||
|
|
||||||
|
checkTotal.widget.OnChanged = func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
queueStatisticsFormat.allCheckboxChecked()
|
||||||
|
} else {
|
||||||
|
queueStatisticsFormat.allUnCheckboxChecked()
|
||||||
|
}
|
||||||
|
queueStatisticsFormat.redrawingQueueItems(queueItems)
|
||||||
|
}
|
||||||
|
|
||||||
|
queueStatisticsFormat.waiting.widget.OnChanged = func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
queueStatisticsFormat.checkboxChecked()
|
||||||
|
} else {
|
||||||
|
queueStatisticsFormat.unCheckboxChecked()
|
||||||
|
}
|
||||||
|
queueStatisticsFormat.redrawingQueueItems(queueItems)
|
||||||
|
}
|
||||||
|
|
||||||
|
queueStatisticsFormat.inProgress.widget.OnChanged = func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
queueStatisticsFormat.checkboxChecked()
|
||||||
|
} else {
|
||||||
|
queueStatisticsFormat.unCheckboxChecked()
|
||||||
|
}
|
||||||
|
queueStatisticsFormat.redrawingQueueItems(queueItems)
|
||||||
|
}
|
||||||
|
|
||||||
|
queueStatisticsFormat.completed.widget.OnChanged = func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
queueStatisticsFormat.checkboxChecked()
|
||||||
|
} else {
|
||||||
|
queueStatisticsFormat.unCheckboxChecked()
|
||||||
|
}
|
||||||
|
queueStatisticsFormat.redrawingQueueItems(queueItems)
|
||||||
|
}
|
||||||
|
|
||||||
|
queueStatisticsFormat.error.widget.OnChanged = func(b bool) {
|
||||||
|
if b == true {
|
||||||
|
queueStatisticsFormat.checkboxChecked()
|
||||||
|
} else {
|
||||||
|
queueStatisticsFormat.unCheckboxChecked()
|
||||||
|
}
|
||||||
|
queueStatisticsFormat.redrawingQueueItems(queueItems)
|
||||||
|
}
|
||||||
|
|
||||||
|
return queueStatisticsFormat
|
||||||
}
|
}
|
||||||
|
|
||||||
type LayoutLocalizerListenerContract interface {
|
func (f queueStatisticsFormat) redrawingQueueItems(queueItems *map[int]QueueLayoutItem) {
|
||||||
AddItem(messageID string, object *widget.Label)
|
for _, item := range *queueItems {
|
||||||
}
|
if f.isChecked(*item.status) == true && item.CanvasObject.Visible() == false {
|
||||||
|
item.CanvasObject.Show()
|
||||||
func NewLayoutLocalizerListener() *LayoutLocalizerListener {
|
continue
|
||||||
return &LayoutLocalizerListener{
|
}
|
||||||
itemCurrentId: 0,
|
if f.isChecked(*item.status) == false && item.CanvasObject.Visible() == true {
|
||||||
items: map[int]*LayoutLocalizerItem{},
|
item.CanvasObject.Hide()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l LayoutLocalizerListener) AddItem(messageID string, object *widget.Label) {
|
func (f queueStatisticsFormat) isChecked(status StatusContract) bool {
|
||||||
l.itemCurrentId += 1
|
if status == StatusType(InProgress) {
|
||||||
l.items[l.itemCurrentId] = &LayoutLocalizerItem{messageID: messageID, object: object}
|
return f.inProgress.widget.Checked
|
||||||
|
}
|
||||||
|
if status == StatusType(Completed) {
|
||||||
|
return f.completed.widget.Checked
|
||||||
|
}
|
||||||
|
if status == StatusType(Error) {
|
||||||
|
return f.error.widget.Checked
|
||||||
|
}
|
||||||
|
if status == StatusType(Waiting) {
|
||||||
|
return f.waiting.widget.Checked
|
||||||
|
}
|
||||||
|
|
||||||
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l LayoutLocalizerListener) Change(localizerService LocalizerContract) {
|
func (f queueStatisticsFormat) addQueue() {
|
||||||
for _, item := range l.items {
|
f.waiting.add()
|
||||||
item.object.Text = localizerService.GetMessage(&i18n.LocalizeConfig{MessageID: item.messageID})
|
f.total.add()
|
||||||
item.object.Refresh()
|
}
|
||||||
|
|
||||||
|
func (f queueStatisticsFormat) changeQueue(status StatusContract) {
|
||||||
|
if status == StatusType(InProgress) {
|
||||||
|
f.waiting.remove()
|
||||||
|
f.inProgress.add()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if status == StatusType(Completed) {
|
||||||
|
f.inProgress.remove()
|
||||||
|
f.completed.add()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if status == StatusType(Error) {
|
||||||
|
f.inProgress.remove()
|
||||||
|
f.error.add()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f queueStatisticsFormat) removeQueue(status StatusContract) {
|
||||||
|
f.total.remove()
|
||||||
|
|
||||||
|
if status == StatusType(Completed) {
|
||||||
|
f.completed.remove()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if status == StatusType(Error) {
|
||||||
|
f.error.remove()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if status == StatusType(InProgress) {
|
||||||
|
f.inProgress.remove()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if status == StatusType(Waiting) {
|
||||||
|
f.waiting.remove()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f queueStatisticsFormat) checkboxChecked() {
|
||||||
|
if f.total.widget.Checked == true {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.waiting.widget.Checked == false {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.inProgress.widget.Checked == false {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.completed.widget.Checked == false {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.error.widget.Checked == false {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
f.total.widget.Checked = true
|
||||||
|
f.total.widget.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f queueStatisticsFormat) unCheckboxChecked() {
|
||||||
|
if f.total.widget.Checked == false {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
f.total.widget.Checked = false
|
||||||
|
f.total.widget.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f queueStatisticsFormat) allCheckboxChecked() {
|
||||||
|
f.waiting.widget.Checked = true
|
||||||
|
f.waiting.widget.Refresh()
|
||||||
|
f.inProgress.widget.Checked = true
|
||||||
|
f.inProgress.widget.Refresh()
|
||||||
|
f.completed.widget.Checked = true
|
||||||
|
f.completed.widget.Refresh()
|
||||||
|
f.error.widget.Checked = true
|
||||||
|
f.error.widget.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f queueStatisticsFormat) allUnCheckboxChecked() {
|
||||||
|
f.waiting.widget.Checked = false
|
||||||
|
f.waiting.widget.Refresh()
|
||||||
|
f.inProgress.widget.Checked = false
|
||||||
|
f.inProgress.widget.Refresh()
|
||||||
|
f.completed.widget.Checked = false
|
||||||
|
f.completed.widget.Refresh()
|
||||||
|
f.error.widget.Checked = false
|
||||||
|
f.error.widget.Refresh()
|
||||||
|
}
|
||||||
|
|
||||||
|
func newQueueStatistics(messaigeID string, localizerService LocalizerContract) *queueStatistics {
|
||||||
|
checkbox := widget.NewCheck("", nil)
|
||||||
|
checkbox.Checked = true
|
||||||
|
|
||||||
|
count := int64(0)
|
||||||
|
|
||||||
|
title := localizerService.GetMessage(&i18n.LocalizeConfig{MessageID: messaigeID})
|
||||||
|
queueStatistics := &queueStatistics{
|
||||||
|
widget: checkbox,
|
||||||
|
title: strings.ToLower(title),
|
||||||
|
count: &count,
|
||||||
|
}
|
||||||
|
|
||||||
|
queueStatistics.formatText(false)
|
||||||
|
|
||||||
|
localizerService.AddChangeCallback(messaigeID, func(text string) {
|
||||||
|
queueStatistics.title = strings.ToLower(text)
|
||||||
|
queueStatistics.formatText(true)
|
||||||
|
queueStatistics.widget.Refresh()
|
||||||
|
})
|
||||||
|
|
||||||
|
return queueStatistics
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s queueStatistics) add() {
|
||||||
|
*s.count += 1
|
||||||
|
s.formatText(true)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s queueStatistics) remove() {
|
||||||
|
if *s.count == 0 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
*s.count -= 1
|
||||||
|
s.formatText(true)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s queueStatistics) formatText(refresh bool) {
|
||||||
|
s.widget.Text = s.title + ": " + strconv.FormatInt(*s.count, 10)
|
||||||
|
if refresh == true {
|
||||||
|
s.widget.Refresh()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -16,11 +16,7 @@ type LocalizerContract interface {
|
|||||||
SetCurrentLanguage(lang Lang) error
|
SetCurrentLanguage(lang Lang) error
|
||||||
SetCurrentLanguageByCode(code string) error
|
SetCurrentLanguageByCode(code string) error
|
||||||
GetCurrentLanguage() *CurrentLanguage
|
GetCurrentLanguage() *CurrentLanguage
|
||||||
AddListener(listener LocalizerListenerContract)
|
AddChangeCallback(messageID string, callback func(text string))
|
||||||
}
|
|
||||||
|
|
||||||
type LocalizerListenerContract interface {
|
|
||||||
Change(localizerService LocalizerContract)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type Lang struct {
|
type Lang struct {
|
||||||
@@ -34,11 +30,16 @@ type CurrentLanguage struct {
|
|||||||
localizerDefault *i18n.Localizer
|
localizerDefault *i18n.Localizer
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type changeCallback struct {
|
||||||
|
messageID string
|
||||||
|
callback func(text string)
|
||||||
|
}
|
||||||
|
|
||||||
type Localizer struct {
|
type Localizer struct {
|
||||||
bundle *i18n.Bundle
|
bundle *i18n.Bundle
|
||||||
languages []Lang
|
languages []Lang
|
||||||
currentLanguage *CurrentLanguage
|
currentLanguage *CurrentLanguage
|
||||||
localizerListener map[int]LocalizerListenerContract
|
changeCallbacks map[int]*changeCallback
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewLocalizer(directory string, languageDefault language.Tag) (*Localizer, error) {
|
func NewLocalizer(directory string, languageDefault language.Tag) (*Localizer, error) {
|
||||||
@@ -63,7 +64,7 @@ func NewLocalizer(directory string, languageDefault language.Tag) (*Localizer, e
|
|||||||
localizer: localizerDefault,
|
localizer: localizerDefault,
|
||||||
localizerDefault: localizerDefault,
|
localizerDefault: localizerDefault,
|
||||||
},
|
},
|
||||||
localizerListener: map[int]LocalizerListenerContract{},
|
changeCallbacks: map[int]*changeCallback{},
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -123,13 +124,14 @@ func (l Localizer) GetCurrentLanguage() *CurrentLanguage {
|
|||||||
return l.currentLanguage
|
return l.currentLanguage
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l Localizer) AddListener(listener LocalizerListenerContract) {
|
func (l Localizer) AddChangeCallback(messageID string, callback func(text string)) {
|
||||||
l.localizerListener[len(l.localizerListener)] = listener
|
l.changeCallbacks[len(l.changeCallbacks)] = &changeCallback{messageID: messageID, callback: callback}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l Localizer) eventSetCurrentLanguage() {
|
func (l Localizer) eventSetCurrentLanguage() {
|
||||||
for _, listener := range l.localizerListener {
|
for _, changeCallback := range l.changeCallbacks {
|
||||||
listener.Change(l)
|
text := l.GetMessage(&i18n.LocalizeConfig{MessageID: changeCallback.messageID})
|
||||||
|
changeCallback.callback(text)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -10,21 +10,9 @@ type Queue struct {
|
|||||||
Error error
|
Error error
|
||||||
}
|
}
|
||||||
|
|
||||||
type File struct {
|
|
||||||
Path string
|
|
||||||
Name string
|
|
||||||
Ext string
|
|
||||||
}
|
|
||||||
|
|
||||||
type ConvertSetting struct {
|
|
||||||
VideoFileInput File
|
|
||||||
VideoFileOut File
|
|
||||||
OverwriteOutputFiles bool
|
|
||||||
}
|
|
||||||
|
|
||||||
type StatusContract interface {
|
type StatusContract interface {
|
||||||
name() string
|
Name() string
|
||||||
ordinal() int
|
Ordinal() int
|
||||||
}
|
}
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@@ -43,11 +31,11 @@ var statusTypeStrings = []string{
|
|||||||
"error",
|
"error",
|
||||||
}
|
}
|
||||||
|
|
||||||
func (status StatusType) name() string {
|
func (status StatusType) Name() string {
|
||||||
return statusTypeStrings[status]
|
return statusTypeStrings[status]
|
||||||
}
|
}
|
||||||
|
|
||||||
func (status StatusType) ordinal() int {
|
func (status StatusType) Ordinal() int {
|
||||||
return int(status)
|
return int(status)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -22,7 +22,8 @@ type Window struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func newWindow(w fyne.Window, layout LayoutContract) Window {
|
func newWindow(w fyne.Window, layout LayoutContract) Window {
|
||||||
w.Resize(fyne.Size{Width: 1039, Height: 599})
|
windowSize := fyne.Size{Width: 1039, Height: 599}
|
||||||
|
w.Resize(windowSize)
|
||||||
w.CenterOnScreen()
|
w.CenterOnScreen()
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
@@ -30,11 +31,10 @@ func newWindow(w fyne.Window, layout LayoutContract) Window {
|
|||||||
* Bug fixed.
|
* Bug fixed.
|
||||||
* When starting the program, sometimes the window was displayed incorrectly.
|
* When starting the program, sometimes the window was displayed incorrectly.
|
||||||
*/
|
*/
|
||||||
|
windowSize.Width += 1
|
||||||
|
windowSize.Height += 1
|
||||||
time.Sleep(time.Millisecond * 500)
|
time.Sleep(time.Millisecond * 500)
|
||||||
size := w.Canvas().Size()
|
w.Resize(windowSize)
|
||||||
size.Width += 1
|
|
||||||
size.Height += 1
|
|
||||||
w.Resize(size)
|
|
||||||
}()
|
}()
|
||||||
|
|
||||||
return Window{
|
return Window{
|
||||||
|
1
languages/.gitignore
vendored
Normal file
1
languages/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
translate.*.toml
|
@@ -15,8 +15,8 @@ hash = "sha1-c223c2e15171156192bc3146aee91e6094bb475b"
|
|||||||
other = "Download FFmpeg automatically"
|
other = "Download FFmpeg automatically"
|
||||||
|
|
||||||
[buttonForSelectedDirTitle]
|
[buttonForSelectedDirTitle]
|
||||||
hash = "sha1-52b13f1b13e82d22e8c4102332db5d4ec551247b"
|
hash = "sha1-8cbe5c67bcf89e4624635a79cbea104227faedda"
|
||||||
other = "Folder where it will be saved:"
|
other = "Save to folder:"
|
||||||
|
|
||||||
[cancel]
|
[cancel]
|
||||||
hash = "sha1-0ec753be8df955a117404fb634b01b45eb386e2a"
|
hash = "sha1-0ec753be8df955a117404fb634b01b45eb386e2a"
|
||||||
@@ -38,7 +38,7 @@ other = "Allow file to be overwritten"
|
|||||||
hash = "sha1-f60bb5f761024d973834b5e9d25ceebce2c85f94"
|
hash = "sha1-f60bb5f761024d973834b5e9d25ceebce2c85f94"
|
||||||
other = "choose"
|
other = "choose"
|
||||||
|
|
||||||
[completed]
|
[completedQueue]
|
||||||
hash = "sha1-398c7d4f7b0d522afb930769c0fbb1a9f4b61fbe"
|
hash = "sha1-398c7d4f7b0d522afb930769c0fbb1a9f4b61fbe"
|
||||||
other = "Completed"
|
other = "Completed"
|
||||||
|
|
||||||
@@ -47,8 +47,8 @@ hash = "sha1-7ac460f3c24c9952082f2db6e4d62f752598709c"
|
|||||||
other = "Convert"
|
other = "Convert"
|
||||||
|
|
||||||
[converterVideoFilesTitle]
|
[converterVideoFilesTitle]
|
||||||
hash = "sha1-4d972809e4c7f9c9ff2c110a126bbc183c9429ce"
|
hash = "sha1-1ab29597cc9dfefab08e54ea5442e7ffa15f0394"
|
||||||
other = "Converter video files to mp4"
|
other = "Video, audio and picture converter"
|
||||||
|
|
||||||
[download]
|
[download]
|
||||||
hash = "sha1-fe8f79f29da457de2f6bc9531de6e536e0c426ad"
|
hash = "sha1-fe8f79f29da457de2f6bc9531de6e536e0c426ad"
|
||||||
@@ -62,6 +62,150 @@ other = "Will be downloaded from the site:"
|
|||||||
hash = "sha1-55f87f114628fa2d5d8e67d1e1cda22c0e4f9271"
|
hash = "sha1-55f87f114628fa2d5d8e67d1e1cda22c0e4f9271"
|
||||||
other = "Downloading..."
|
other = "Downloading..."
|
||||||
|
|
||||||
|
[encoderGroupAudio]
|
||||||
|
hash = "sha1-24321cb5400df96be8f3e2131918bebdb3a01bba"
|
||||||
|
other = "Audio"
|
||||||
|
|
||||||
|
[encoderGroupImage]
|
||||||
|
hash = "sha1-a7e528bc7ac9538aec87d1593c38b80be95d4745"
|
||||||
|
other = "Images"
|
||||||
|
|
||||||
|
[encoderGroupVideo]
|
||||||
|
hash = "sha1-8e7b9894c7ef0f57ac0bf910f6a8aac1c8a53683"
|
||||||
|
other = "Video"
|
||||||
|
|
||||||
|
[encoder_apng]
|
||||||
|
hash = "sha1-1cbd9abfef96d5614a7e569161b41bd6ad87bbaf"
|
||||||
|
other = "APNG image"
|
||||||
|
|
||||||
|
[encoder_bmp]
|
||||||
|
hash = "sha1-e0b9c16b016961a5abdc2217e8ffd1ba7ddebc40"
|
||||||
|
other = "BMP image"
|
||||||
|
|
||||||
|
[encoder_flv]
|
||||||
|
hash = "sha1-3602bbf1cc90e48254f81975c7879b5fc0c4d602"
|
||||||
|
other = "FLV"
|
||||||
|
|
||||||
|
[encoder_gif]
|
||||||
|
hash = "sha1-d092a779172291b5215aa095390a5b11659128a4"
|
||||||
|
other = "GIF image"
|
||||||
|
|
||||||
|
[encoder_h264_nvenc]
|
||||||
|
hash = "sha1-169389f8c4a2518410159c363378ab5c978c32e5"
|
||||||
|
other = "H.264 with NVIDIA support"
|
||||||
|
|
||||||
|
[encoder_libmp3lame]
|
||||||
|
hash = "sha1-cd2c8d6f246c8bc18554b7105cb50b78d3cb2b98"
|
||||||
|
other = "libmp3lame MP3 (MPEG audio layer 3)"
|
||||||
|
|
||||||
|
[encoder_libshine]
|
||||||
|
hash = "sha1-891d56c85857e5d83ef5a1fe077c1f1540788f49"
|
||||||
|
other = "libshine MP3 (MPEG audio layer 3)"
|
||||||
|
|
||||||
|
[encoder_libtwolame]
|
||||||
|
hash = "sha1-b2f53be810b74edc3c454ac75de7ddecfee322ca"
|
||||||
|
other = "libtwolame MP2 (MPEG audio layer 2)"
|
||||||
|
|
||||||
|
[encoder_libvpx]
|
||||||
|
hash = "sha1-b85c923aecfb48de0e87e71b6a21bfc2c547c70e"
|
||||||
|
other = "libvpx VP8 (codec vp8)"
|
||||||
|
|
||||||
|
[encoder_libvpx-vp9]
|
||||||
|
hash = "sha1-3106417bd89bee87daa691e87614caf78cb934fe"
|
||||||
|
other = "libvpx VP9 (codec vp9)"
|
||||||
|
|
||||||
|
[encoder_libwebp]
|
||||||
|
hash = "sha1-1d590d47d46f7880246061fce0e0de6d743db39e"
|
||||||
|
other = "libwebp WebP image"
|
||||||
|
|
||||||
|
[encoder_libwebp_anim]
|
||||||
|
hash = "sha1-f141a9c8f23d79c13d44c30d8f34e05b363771ad"
|
||||||
|
other = "libwebp_anim WebP image"
|
||||||
|
|
||||||
|
[encoder_libx264]
|
||||||
|
hash = "sha1-6d764ac459c0bf3c819d76618418cdfbb7a749eb"
|
||||||
|
other = "H.264 libx264"
|
||||||
|
|
||||||
|
[encoder_libx265]
|
||||||
|
hash = "sha1-55544c166b1e15fd71a58096518e528109599eea"
|
||||||
|
other = "H.265 libx265"
|
||||||
|
|
||||||
|
[encoder_libxvid]
|
||||||
|
hash = "sha1-d4bed46d6cdd2bfa8fd1689801164a83ab10c3f5"
|
||||||
|
other = "libxvidcore MPEG-4 part 2"
|
||||||
|
|
||||||
|
[encoder_mjpeg]
|
||||||
|
hash = "sha1-94ba63a322b493a04da65e566781fe1cf8bb0d50"
|
||||||
|
other = "MJPEG (Motion JPEG)"
|
||||||
|
|
||||||
|
[encoder_mp2]
|
||||||
|
hash = "sha1-a9154b7203349e5d6fbfd67d1ea97715f54b2065"
|
||||||
|
other = "MP2 (MPEG audio layer 2)"
|
||||||
|
|
||||||
|
[encoder_mp2fixed]
|
||||||
|
hash = "sha1-dd2ee670d8bc8a60a96a717ebd26f16b5748cf3f"
|
||||||
|
other = "MP2 fixed point (MPEG audio layer 2)"
|
||||||
|
|
||||||
|
[encoder_mpeg1video]
|
||||||
|
hash = "sha1-30043660719a3cb19dab5c33450665a8a9cc1c01"
|
||||||
|
other = "MPEG-1"
|
||||||
|
|
||||||
|
[encoder_mpeg2video]
|
||||||
|
hash = "sha1-ccb2dcd8510cfdc9d52e5258af1863e5f2c51e77"
|
||||||
|
other = "MPEG-2"
|
||||||
|
|
||||||
|
[encoder_mpeg4]
|
||||||
|
hash = "sha1-67fe42f18421b2f6c90fcdc579f9199bfca4b182"
|
||||||
|
other = "MPEG-4 part 2"
|
||||||
|
|
||||||
|
[encoder_msmpeg4]
|
||||||
|
hash = "sha1-313ee597e4f0d9bd63a2bc6ac1618f028aef76f4"
|
||||||
|
other = "MPEG-4 part 2 Microsoft variant version 3"
|
||||||
|
|
||||||
|
[encoder_msmpeg4v2]
|
||||||
|
hash = "sha1-adc442ce88f2717693b2da3010a1937d77ee522f"
|
||||||
|
other = "MPEG-4 part 2 Microsoft variant version 2"
|
||||||
|
|
||||||
|
[encoder_msvideo1]
|
||||||
|
hash = "sha1-00f43ac0dc162bca10e0d98d6b70c0c6a902f66f"
|
||||||
|
other = "Microsoft Video-1"
|
||||||
|
|
||||||
|
[encoder_png]
|
||||||
|
hash = "sha1-6715d4b82f5d9dfe3e53e30b402ffa1a6fbf30a5"
|
||||||
|
other = "PNG image"
|
||||||
|
|
||||||
|
[encoder_qtrle]
|
||||||
|
hash = "sha1-31bf155cffaf6842ebc54084e4337ca08fdd9848"
|
||||||
|
other = "QuickTime Animation (RLE) video"
|
||||||
|
|
||||||
|
[encoder_sgi]
|
||||||
|
hash = "sha1-f4510e237f7fc3c02caa728f9e500f4b069f9c11"
|
||||||
|
other = "SGI image"
|
||||||
|
|
||||||
|
[encoder_tiff]
|
||||||
|
hash = "sha1-ed09d78c38e0b17ed695f35740c756dd7340eeac"
|
||||||
|
other = "TIFF image"
|
||||||
|
|
||||||
|
[encoder_wmav1]
|
||||||
|
hash = "sha1-cd4a4c5eeac694b6699d55d0f9b477b3b50f18c7"
|
||||||
|
other = "Windows Media Audio 1"
|
||||||
|
|
||||||
|
[encoder_wmav2]
|
||||||
|
hash = "sha1-eb2e5306cb33a702577ecfbdca0461862c66c053"
|
||||||
|
other = "Windows Media Audio 2"
|
||||||
|
|
||||||
|
[encoder_wmv1]
|
||||||
|
hash = "sha1-f9b748554c590c36a56bcba2cd317196b7bdeddb"
|
||||||
|
other = "Windows Media Video 7"
|
||||||
|
|
||||||
|
[encoder_wmv2]
|
||||||
|
hash = "sha1-5b21c87f5c6104797ead60b488b2948428f6b1b7"
|
||||||
|
other = "Windows Media Video 8"
|
||||||
|
|
||||||
|
[encoder_xbm]
|
||||||
|
hash = "sha1-2dfc35881da62e9a1379d8238cf7839b24f79566"
|
||||||
|
other = "XBM (X BitMap) image"
|
||||||
|
|
||||||
[error]
|
[error]
|
||||||
hash = "sha1-a7df8f8b5d754f226ac4cb320577fe692b33e483"
|
hash = "sha1-a7df8f8b5d754f226ac4cb320577fe692b33e483"
|
||||||
other = "An error has occurred!"
|
other = "An error has occurred!"
|
||||||
@@ -90,9 +234,21 @@ other = "this is not FFprobe"
|
|||||||
hash = "sha1-da7b37d7df3fafbd153665b13888413d52b24c17"
|
hash = "sha1-da7b37d7df3fafbd153665b13888413d52b24c17"
|
||||||
other = "Failed to determine FFprobe version"
|
other = "Failed to determine FFprobe version"
|
||||||
|
|
||||||
|
[errorQueue]
|
||||||
|
hash = "sha1-72aecd9ad85642d84d62dbbf3cf70953c5f696c7"
|
||||||
|
other = "Error"
|
||||||
|
|
||||||
|
[errorSelectedEncoder]
|
||||||
|
hash = "sha1-33ed1aaf4cb3c2ee9d8f8c325b9b75d16ddf9979"
|
||||||
|
other = "Converter not selected"
|
||||||
|
|
||||||
[errorSelectedFolderSave]
|
[errorSelectedFolderSave]
|
||||||
hash = "sha1-83da899677cdc90e4344e3b94ee03c46b51bee4c"
|
hash = "sha1-16f3ef93ee36813fdd79d8fb9bb7fc02acbb94a8"
|
||||||
other = "You haven't selected a folder to save!"
|
other = "No save folder selected!"
|
||||||
|
|
||||||
|
[errorSelectedFormat]
|
||||||
|
hash = "sha1-cda92c56a1ef1aabc92bbfc405ede8ab13087e66"
|
||||||
|
other = "File extension not selected"
|
||||||
|
|
||||||
[exit]
|
[exit]
|
||||||
hash = "sha1-c42457057d1ab7950cea00719cbe0b078891775f"
|
hash = "sha1-c42457057d1ab7950cea00719cbe0b078891775f"
|
||||||
@@ -106,15 +262,19 @@ other = "This software uses libraries from the **FFmpeg** project under the **[L
|
|||||||
hash = "sha1-45f772b2eca5098cd6d31f2d1dc6edec1987a617"
|
hash = "sha1-45f772b2eca5098cd6d31f2d1dc6edec1987a617"
|
||||||
other = "**FFmpeg** is a trademark of **[Fabrice Bellard](http://bellard.org/)**, originator of the **[FFmpeg](https://ffmpeg.org/about.html)** project."
|
other = "**FFmpeg** is a trademark of **[Fabrice Bellard](http://bellard.org/)**, originator of the **[FFmpeg](https://ffmpeg.org/about.html)** project."
|
||||||
|
|
||||||
[fileVideoForConversionTitle]
|
[fileForConversionTitle]
|
||||||
hash = "sha1-5e727d4a2ff3f21080e51e81641595b2e668f3be"
|
hash = "sha1-96ac799e1086b31fd8f5f8d4c801829d6c853f08"
|
||||||
other = "File for conversion:"
|
other = "File:"
|
||||||
|
|
||||||
|
[formPreset]
|
||||||
|
hash = "sha1-7759891ba1ef9f7adc70defc7ac18fbf149c1a68"
|
||||||
|
other = "Preset"
|
||||||
|
|
||||||
[help]
|
[help]
|
||||||
hash = "sha1-6a45cef900c668effcb2ab10da05855c1fd10f6f"
|
hash = "sha1-6a45cef900c668effcb2ab10da05855c1fd10f6f"
|
||||||
other = "Help"
|
other = "Help"
|
||||||
|
|
||||||
[inProgress]
|
[inProgressQueue]
|
||||||
hash = "sha1-eff79c40e2100ae5fadf3a7d99336025edcca8b5"
|
hash = "sha1-eff79c40e2100ae5fadf3a7d99336025edcca8b5"
|
||||||
other = "In Progress"
|
other = "In Progress"
|
||||||
|
|
||||||
@@ -134,6 +294,10 @@ other = "License information"
|
|||||||
hash = "sha1-359fff328717c05104e51a2d29f05bf1875d26b7"
|
hash = "sha1-359fff328717c05104e51a2d29f05bf1875d26b7"
|
||||||
other = "Licenses from other products used in the program"
|
other = "Licenses from other products used in the program"
|
||||||
|
|
||||||
|
[parameterCheckbox]
|
||||||
|
hash = "sha1-9e35221d454870996fd51d576249cf47d1784a3c"
|
||||||
|
other = "Enable option"
|
||||||
|
|
||||||
[pathToFfmpeg]
|
[pathToFfmpeg]
|
||||||
hash = "sha1-fafc50f1db0f720fe83a96cd70a9e1ad824e96b6"
|
hash = "sha1-fafc50f1db0f720fe83a96cd70a9e1ad824e96b6"
|
||||||
other = "Path to FFmpeg:"
|
other = "Path to FFmpeg:"
|
||||||
@@ -142,6 +306,46 @@ other = "Path to FFmpeg:"
|
|||||||
hash = "sha1-b872edc9633a2e81ef678dc46fe46a7e91732024"
|
hash = "sha1-b872edc9633a2e81ef678dc46fe46a7e91732024"
|
||||||
other = "Path to FFprobe:"
|
other = "Path to FFprobe:"
|
||||||
|
|
||||||
|
[preset_fast]
|
||||||
|
hash = "sha1-935e1ac9d3c8ba4478326c909ba66662acb0540e"
|
||||||
|
other = "fast (slower than \"faster\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_faster]
|
||||||
|
hash = "sha1-98620b73c896440c39ea6ec4b9b19d41301c9a7e"
|
||||||
|
other = "faster (slower than \"veryfast\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_medium]
|
||||||
|
hash = "sha1-f7d1c30135c22c2f07c247075c0df103bb3c3ea5"
|
||||||
|
other = "medium (slower than \"fast\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_placebo]
|
||||||
|
hash = "sha1-7bcff099104bb192881139e6404981bd426b3f91"
|
||||||
|
other = "placebo (not recommended)"
|
||||||
|
|
||||||
|
[preset_slow]
|
||||||
|
hash = "sha1-681bf587275a45b48af49bb2ad8f0947919530e7"
|
||||||
|
other = "slow (slower than \"medium\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_slower]
|
||||||
|
hash = "sha1-d1c692ee2b7643ae2c71a48bea880327a3c6b1e3"
|
||||||
|
other = "slower (slower than \"slow\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_superfast]
|
||||||
|
hash = "sha1-41c39959e8f1547cc9259a5b459c4ccbf368cc23"
|
||||||
|
other = "superfast (slower than \"ultrafast\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_ultrafast]
|
||||||
|
hash = "sha1-dfed981573ac2046832f9a9450bc9388958753fa"
|
||||||
|
other = "ultrafast (fast, but the file will weigh a lot)"
|
||||||
|
|
||||||
|
[preset_veryfast]
|
||||||
|
hash = "sha1-370b82509887d02d7a2ef9b110df4616b16123ce"
|
||||||
|
other = "veryfast (slower than \"superfast\", but the file will weigh less)"
|
||||||
|
|
||||||
|
[preset_veryslow]
|
||||||
|
hash = "sha1-d428bfa6deea9dd5c7c1f80ceba24e123ae96d0d"
|
||||||
|
other = "veryslow (slower than \"slower\", but the file will weigh less)"
|
||||||
|
|
||||||
[programmLink]
|
[programmLink]
|
||||||
hash = "sha1-18f9a3fad6aacefe1b05eed23122800b391ff5ca"
|
hash = "sha1-18f9a3fad6aacefe1b05eed23122800b391ff5ca"
|
||||||
other = "Project website"
|
other = "Project website"
|
||||||
@@ -158,10 +362,18 @@ other = "Queue"
|
|||||||
hash = "sha1-4864057d626a868fa60f999bed3191d61d045ddc"
|
hash = "sha1-4864057d626a868fa60f999bed3191d61d045ddc"
|
||||||
other = "Save"
|
other = "Save"
|
||||||
|
|
||||||
|
[selectEncoder]
|
||||||
|
hash = "sha1-88f3670b09758a3336057520a215058d61006abd"
|
||||||
|
other = "Encoder:"
|
||||||
|
|
||||||
[selectFFPathTitle]
|
[selectFFPathTitle]
|
||||||
hash = "sha1-95581446a28d968ff1a027c623159a7eb08654cf"
|
hash = "sha1-95581446a28d968ff1a027c623159a7eb08654cf"
|
||||||
other = "Specify the path to FFmpeg and FFprobe"
|
other = "Specify the path to FFmpeg and FFprobe"
|
||||||
|
|
||||||
|
[selectFormat]
|
||||||
|
hash = "sha1-f3809b0b48886570cd4cf1d7099de6da5b6d4524"
|
||||||
|
other = "File extension:"
|
||||||
|
|
||||||
[settings]
|
[settings]
|
||||||
hash = "sha1-7f17c7c62a7fd8d1a508481f4778688927734c2f"
|
hash = "sha1-7f17c7c62a7fd8d1a508481f4778688927734c2f"
|
||||||
other = "Settings"
|
other = "Settings"
|
||||||
@@ -174,10 +386,14 @@ other = "Checking FFmpeg for serviceability..."
|
|||||||
hash = "sha1-92df86371f6c3a06ca1e4754f113142776a32d49"
|
hash = "sha1-92df86371f6c3a06ca1e4754f113142776a32d49"
|
||||||
other = "You can download it from here"
|
other = "You can download it from here"
|
||||||
|
|
||||||
|
[total]
|
||||||
|
hash = "sha1-3b5143902e0c5c84459aedf918e17604d9735b94"
|
||||||
|
other = "Total"
|
||||||
|
|
||||||
[unzipRun]
|
[unzipRun]
|
||||||
hash = "sha1-c554dad13026668a1f6adf3171837c5d51bbac36"
|
hash = "sha1-c554dad13026668a1f6adf3171837c5d51bbac36"
|
||||||
other = "Unpacked..."
|
other = "Unpacked..."
|
||||||
|
|
||||||
[waiting]
|
[waitingQueue]
|
||||||
hash = "sha1-307429dd84150877080c4bbff2b340d1e7dadff2"
|
hash = "sha1-307429dd84150877080c4bbff2b340d1e7dadff2"
|
||||||
other = "Waiting"
|
other = "Waiting"
|
||||||
|
@@ -15,8 +15,8 @@ hash = "sha1-c223c2e15171156192bc3146aee91e6094bb475b"
|
|||||||
other = "FFmpeg автоматты түрде жүктеп алыңыз"
|
other = "FFmpeg автоматты түрде жүктеп алыңыз"
|
||||||
|
|
||||||
[buttonForSelectedDirTitle]
|
[buttonForSelectedDirTitle]
|
||||||
hash = "sha1-52b13f1b13e82d22e8c4102332db5d4ec551247b"
|
hash = "sha1-8cbe5c67bcf89e4624635a79cbea104227faedda"
|
||||||
other = "Файлды сақтауға арналған каталог:"
|
other = "Қалтаға сақтаңыз:"
|
||||||
|
|
||||||
[cancel]
|
[cancel]
|
||||||
hash = "sha1-0ec753be8df955a117404fb634b01b45eb386e2a"
|
hash = "sha1-0ec753be8df955a117404fb634b01b45eb386e2a"
|
||||||
@@ -38,7 +38,7 @@ other = "Файлды қайта жазуға рұқсат беріңіз"
|
|||||||
hash = "sha1-f60bb5f761024d973834b5e9d25ceebce2c85f94"
|
hash = "sha1-f60bb5f761024d973834b5e9d25ceebce2c85f94"
|
||||||
other = "таңдау"
|
other = "таңдау"
|
||||||
|
|
||||||
[completed]
|
[completedQueue]
|
||||||
hash = "sha1-398c7d4f7b0d522afb930769c0fbb1a9f4b61fbe"
|
hash = "sha1-398c7d4f7b0d522afb930769c0fbb1a9f4b61fbe"
|
||||||
other = "Дайын"
|
other = "Дайын"
|
||||||
|
|
||||||
@@ -47,8 +47,8 @@ hash = "sha1-7ac460f3c24c9952082f2db6e4d62f752598709c"
|
|||||||
other = "Файлды түрлендіру"
|
other = "Файлды түрлендіру"
|
||||||
|
|
||||||
[converterVideoFilesTitle]
|
[converterVideoFilesTitle]
|
||||||
hash = "sha1-4d972809e4c7f9c9ff2c110a126bbc183c9429ce"
|
hash = "sha1-1ab29597cc9dfefab08e54ea5442e7ffa15f0394"
|
||||||
other = "Бейне файлдарын mp4 форматына түрлендіру"
|
other = "Бейне, аудио және суретті түрлендіргіш"
|
||||||
|
|
||||||
[download]
|
[download]
|
||||||
hash = "sha1-fe8f79f29da457de2f6bc9531de6e536e0c426ad"
|
hash = "sha1-fe8f79f29da457de2f6bc9531de6e536e0c426ad"
|
||||||
@@ -62,6 +62,150 @@ other = "Сайттан жүктеледі:"
|
|||||||
hash = "sha1-55f87f114628fa2d5d8e67d1e1cda22c0e4f9271"
|
hash = "sha1-55f87f114628fa2d5d8e67d1e1cda22c0e4f9271"
|
||||||
other = "Жүктеп алынуда..."
|
other = "Жүктеп алынуда..."
|
||||||
|
|
||||||
|
[encoderGroupAudio]
|
||||||
|
hash = "sha1-24321cb5400df96be8f3e2131918bebdb3a01bba"
|
||||||
|
other = "Аудио"
|
||||||
|
|
||||||
|
[encoderGroupImage]
|
||||||
|
hash = "sha1-a7e528bc7ac9538aec87d1593c38b80be95d4745"
|
||||||
|
other = "Суреттер"
|
||||||
|
|
||||||
|
[encoderGroupVideo]
|
||||||
|
hash = "sha1-8e7b9894c7ef0f57ac0bf910f6a8aac1c8a53683"
|
||||||
|
other = "Бейне"
|
||||||
|
|
||||||
|
[encoder_apng]
|
||||||
|
hash = "sha1-1cbd9abfef96d5614a7e569161b41bd6ad87bbaf"
|
||||||
|
other = "APNG image"
|
||||||
|
|
||||||
|
[encoder_bmp]
|
||||||
|
hash = "sha1-e0b9c16b016961a5abdc2217e8ffd1ba7ddebc40"
|
||||||
|
other = "BMP image"
|
||||||
|
|
||||||
|
[encoder_flv]
|
||||||
|
hash = "sha1-3602bbf1cc90e48254f81975c7879b5fc0c4d602"
|
||||||
|
other = "FLV"
|
||||||
|
|
||||||
|
[encoder_gif]
|
||||||
|
hash = "sha1-d092a779172291b5215aa095390a5b11659128a4"
|
||||||
|
other = "GIF image"
|
||||||
|
|
||||||
|
[encoder_h264_nvenc]
|
||||||
|
hash = "sha1-169389f8c4a2518410159c363378ab5c978c32e5"
|
||||||
|
other = "NVIDIA қолдауымен H.264"
|
||||||
|
|
||||||
|
[encoder_libmp3lame]
|
||||||
|
hash = "sha1-cd2c8d6f246c8bc18554b7105cb50b78d3cb2b98"
|
||||||
|
other = "libmp3lame MP3 (MPEG audio layer 3)"
|
||||||
|
|
||||||
|
[encoder_libshine]
|
||||||
|
hash = "sha1-891d56c85857e5d83ef5a1fe077c1f1540788f49"
|
||||||
|
other = "libshine MP3 (MPEG audio layer 3)"
|
||||||
|
|
||||||
|
[encoder_libtwolame]
|
||||||
|
hash = "sha1-b2f53be810b74edc3c454ac75de7ddecfee322ca"
|
||||||
|
other = "libtwolame MP2 (MPEG audio layer 2)"
|
||||||
|
|
||||||
|
[encoder_libvpx]
|
||||||
|
hash = "sha1-b85c923aecfb48de0e87e71b6a21bfc2c547c70e"
|
||||||
|
other = "libvpx VP8 (codec vp8)"
|
||||||
|
|
||||||
|
[encoder_libvpx-vp9]
|
||||||
|
hash = "sha1-3106417bd89bee87daa691e87614caf78cb934fe"
|
||||||
|
other = "libvpx VP9 (codec vp9)"
|
||||||
|
|
||||||
|
[encoder_libwebp]
|
||||||
|
hash = "sha1-1d590d47d46f7880246061fce0e0de6d743db39e"
|
||||||
|
other = "libwebp WebP image"
|
||||||
|
|
||||||
|
[encoder_libwebp_anim]
|
||||||
|
hash = "sha1-f141a9c8f23d79c13d44c30d8f34e05b363771ad"
|
||||||
|
other = "libwebp_anim WebP image"
|
||||||
|
|
||||||
|
[encoder_libx264]
|
||||||
|
hash = "sha1-6d764ac459c0bf3c819d76618418cdfbb7a749eb"
|
||||||
|
other = "H.264 libx264"
|
||||||
|
|
||||||
|
[encoder_libx265]
|
||||||
|
hash = "sha1-55544c166b1e15fd71a58096518e528109599eea"
|
||||||
|
other = "H.265 libx265"
|
||||||
|
|
||||||
|
[encoder_libxvid]
|
||||||
|
hash = "sha1-d4bed46d6cdd2bfa8fd1689801164a83ab10c3f5"
|
||||||
|
other = "libxvidcore MPEG-4 part 2"
|
||||||
|
|
||||||
|
[encoder_mjpeg]
|
||||||
|
hash = "sha1-94ba63a322b493a04da65e566781fe1cf8bb0d50"
|
||||||
|
other = "MJPEG (Motion JPEG)"
|
||||||
|
|
||||||
|
[encoder_mp2]
|
||||||
|
hash = "sha1-a9154b7203349e5d6fbfd67d1ea97715f54b2065"
|
||||||
|
other = "MP2 (MPEG audio layer 2)"
|
||||||
|
|
||||||
|
[encoder_mp2fixed]
|
||||||
|
hash = "sha1-dd2ee670d8bc8a60a96a717ebd26f16b5748cf3f"
|
||||||
|
other = "MP2 fixed point (MPEG audio layer 2)"
|
||||||
|
|
||||||
|
[encoder_mpeg1video]
|
||||||
|
hash = "sha1-30043660719a3cb19dab5c33450665a8a9cc1c01"
|
||||||
|
other = "MPEG-1"
|
||||||
|
|
||||||
|
[encoder_mpeg2video]
|
||||||
|
hash = "sha1-ccb2dcd8510cfdc9d52e5258af1863e5f2c51e77"
|
||||||
|
other = "MPEG-2"
|
||||||
|
|
||||||
|
[encoder_mpeg4]
|
||||||
|
hash = "sha1-67fe42f18421b2f6c90fcdc579f9199bfca4b182"
|
||||||
|
other = "MPEG-4 part 2"
|
||||||
|
|
||||||
|
[encoder_msmpeg4]
|
||||||
|
hash = "sha1-313ee597e4f0d9bd63a2bc6ac1618f028aef76f4"
|
||||||
|
other = "MPEG-4 part 2 Microsoft variant version 3"
|
||||||
|
|
||||||
|
[encoder_msmpeg4v2]
|
||||||
|
hash = "sha1-adc442ce88f2717693b2da3010a1937d77ee522f"
|
||||||
|
other = "MPEG-4 part 2 Microsoft variant version 2"
|
||||||
|
|
||||||
|
[encoder_msvideo1]
|
||||||
|
hash = "sha1-00f43ac0dc162bca10e0d98d6b70c0c6a902f66f"
|
||||||
|
other = "Microsoft Video-1"
|
||||||
|
|
||||||
|
[encoder_png]
|
||||||
|
hash = "sha1-6715d4b82f5d9dfe3e53e30b402ffa1a6fbf30a5"
|
||||||
|
other = "PNG image"
|
||||||
|
|
||||||
|
[encoder_qtrle]
|
||||||
|
hash = "sha1-31bf155cffaf6842ebc54084e4337ca08fdd9848"
|
||||||
|
other = "QuickTime Animation (RLE) video"
|
||||||
|
|
||||||
|
[encoder_sgi]
|
||||||
|
hash = "sha1-f4510e237f7fc3c02caa728f9e500f4b069f9c11"
|
||||||
|
other = "SGI image"
|
||||||
|
|
||||||
|
[encoder_tiff]
|
||||||
|
hash = "sha1-ed09d78c38e0b17ed695f35740c756dd7340eeac"
|
||||||
|
other = "TIFF image"
|
||||||
|
|
||||||
|
[encoder_wmav1]
|
||||||
|
hash = "sha1-cd4a4c5eeac694b6699d55d0f9b477b3b50f18c7"
|
||||||
|
other = "Windows Media Audio 1"
|
||||||
|
|
||||||
|
[encoder_wmav2]
|
||||||
|
hash = "sha1-eb2e5306cb33a702577ecfbdca0461862c66c053"
|
||||||
|
other = "Windows Media Audio 2"
|
||||||
|
|
||||||
|
[encoder_wmv1]
|
||||||
|
hash = "sha1-f9b748554c590c36a56bcba2cd317196b7bdeddb"
|
||||||
|
other = "Windows Media Video 7"
|
||||||
|
|
||||||
|
[encoder_wmv2]
|
||||||
|
hash = "sha1-5b21c87f5c6104797ead60b488b2948428f6b1b7"
|
||||||
|
other = "Windows Media Video 8"
|
||||||
|
|
||||||
|
[encoder_xbm]
|
||||||
|
hash = "sha1-2dfc35881da62e9a1379d8238cf7839b24f79566"
|
||||||
|
other = "XBM (X BitMap) image"
|
||||||
|
|
||||||
[error]
|
[error]
|
||||||
hash = "sha1-a7df8f8b5d754f226ac4cb320577fe692b33e483"
|
hash = "sha1-a7df8f8b5d754f226ac4cb320577fe692b33e483"
|
||||||
other = "Қате орын алды!"
|
other = "Қате орын алды!"
|
||||||
@@ -90,9 +234,21 @@ other = "бұл FFprobe емес"
|
|||||||
hash = "sha1-da7b37d7df3fafbd153665b13888413d52b24c17"
|
hash = "sha1-da7b37d7df3fafbd153665b13888413d52b24c17"
|
||||||
other = "FFprobe нұсқасын анықтау мүмкін болмады"
|
other = "FFprobe нұсқасын анықтау мүмкін болмады"
|
||||||
|
|
||||||
|
[errorQueue]
|
||||||
|
hash = "sha1-72aecd9ad85642d84d62dbbf3cf70953c5f696c7"
|
||||||
|
other = "Қате"
|
||||||
|
|
||||||
|
[errorSelectedEncoder]
|
||||||
|
hash = "sha1-33ed1aaf4cb3c2ee9d8f8c325b9b75d16ddf9979"
|
||||||
|
other = "Түрлендіргіш таңдалмаған"
|
||||||
|
|
||||||
[errorSelectedFolderSave]
|
[errorSelectedFolderSave]
|
||||||
hash = "sha1-83da899677cdc90e4344e3b94ee03c46b51bee4c"
|
hash = "sha1-16f3ef93ee36813fdd79d8fb9bb7fc02acbb94a8"
|
||||||
other = "Сіз сақталатын қалтаны таңдамадыңыз!"
|
other = "Сақтау қалтасы таңдалмаған!"
|
||||||
|
|
||||||
|
[errorSelectedFormat]
|
||||||
|
hash = "sha1-cda92c56a1ef1aabc92bbfc405ede8ab13087e66"
|
||||||
|
other = "Файл кеңейтімі таңдалмаған"
|
||||||
|
|
||||||
[exit]
|
[exit]
|
||||||
hash = "sha1-c42457057d1ab7950cea00719cbe0b078891775f"
|
hash = "sha1-c42457057d1ab7950cea00719cbe0b078891775f"
|
||||||
@@ -106,15 +262,19 @@ other = "Бұл бағдарламалық құрал **[LGPLv2.1](http://www.gn
|
|||||||
hash = "sha1-45f772b2eca5098cd6d31f2d1dc6edec1987a617"
|
hash = "sha1-45f772b2eca5098cd6d31f2d1dc6edec1987a617"
|
||||||
other = "FFmpeg — **[FFmpeg](https://ffmpeg.org/about.html)** жобасын жасаушы **[Fabrice Bellard](http://bellard.org/)** сауда белгісі."
|
other = "FFmpeg — **[FFmpeg](https://ffmpeg.org/about.html)** жобасын жасаушы **[Fabrice Bellard](http://bellard.org/)** сауда белгісі."
|
||||||
|
|
||||||
[fileVideoForConversionTitle]
|
[fileForConversionTitle]
|
||||||
hash = "sha1-5e727d4a2ff3f21080e51e81641595b2e668f3be"
|
hash = "sha1-96ac799e1086b31fd8f5f8d4c801829d6c853f08"
|
||||||
other = "Түрлендіруге арналған файл:"
|
other = "Файл:"
|
||||||
|
|
||||||
|
[formPreset]
|
||||||
|
hash = "sha1-7759891ba1ef9f7adc70defc7ac18fbf149c1a68"
|
||||||
|
other = "Алдын ала орнатылған"
|
||||||
|
|
||||||
[help]
|
[help]
|
||||||
hash = "sha1-6a45cef900c668effcb2ab10da05855c1fd10f6f"
|
hash = "sha1-6a45cef900c668effcb2ab10da05855c1fd10f6f"
|
||||||
other = "Анықтама"
|
other = "Анықтама"
|
||||||
|
|
||||||
[inProgress]
|
[inProgressQueue]
|
||||||
hash = "sha1-eff79c40e2100ae5fadf3a7d99336025edcca8b5"
|
hash = "sha1-eff79c40e2100ae5fadf3a7d99336025edcca8b5"
|
||||||
other = "Орындалуда"
|
other = "Орындалуда"
|
||||||
|
|
||||||
@@ -134,6 +294,10 @@ other = "Лицензия туралы ақпарат"
|
|||||||
hash = "sha1-359fff328717c05104e51a2d29f05bf1875d26b7"
|
hash = "sha1-359fff328717c05104e51a2d29f05bf1875d26b7"
|
||||||
other = "Бағдарламада пайдаланылатын басқа өнімдердің лицензиялары"
|
other = "Бағдарламада пайдаланылатын басқа өнімдердің лицензиялары"
|
||||||
|
|
||||||
|
[parameterCheckbox]
|
||||||
|
hash = "sha1-9e35221d454870996fd51d576249cf47d1784a3c"
|
||||||
|
other = "Опцияны қосу"
|
||||||
|
|
||||||
[pathToFfmpeg]
|
[pathToFfmpeg]
|
||||||
hash = "sha1-fafc50f1db0f720fe83a96cd70a9e1ad824e96b6"
|
hash = "sha1-fafc50f1db0f720fe83a96cd70a9e1ad824e96b6"
|
||||||
other = "FFmpeg жол:"
|
other = "FFmpeg жол:"
|
||||||
@@ -142,6 +306,46 @@ other = "FFmpeg жол:"
|
|||||||
hash = "sha1-b872edc9633a2e81ef678dc46fe46a7e91732024"
|
hash = "sha1-b872edc9633a2e81ef678dc46fe46a7e91732024"
|
||||||
other = "FFprobe жол:"
|
other = "FFprobe жол:"
|
||||||
|
|
||||||
|
[preset_fast]
|
||||||
|
hash = "sha1-935e1ac9d3c8ba4478326c909ba66662acb0540e"
|
||||||
|
other = "fast («faster» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_faster]
|
||||||
|
hash = "sha1-98620b73c896440c39ea6ec4b9b19d41301c9a7e"
|
||||||
|
other = "faster («veryfast» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_medium]
|
||||||
|
hash = "sha1-f7d1c30135c22c2f07c247075c0df103bb3c3ea5"
|
||||||
|
other = "medium («fast» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_placebo]
|
||||||
|
hash = "sha1-7bcff099104bb192881139e6404981bd426b3f91"
|
||||||
|
other = "placebo (ұсынылмайды)"
|
||||||
|
|
||||||
|
[preset_slow]
|
||||||
|
hash = "sha1-681bf587275a45b48af49bb2ad8f0947919530e7"
|
||||||
|
other = "slow («medium» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_slower]
|
||||||
|
hash = "sha1-d1c692ee2b7643ae2c71a48bea880327a3c6b1e3"
|
||||||
|
other = "slower («slow» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_superfast]
|
||||||
|
hash = "sha1-41c39959e8f1547cc9259a5b459c4ccbf368cc23"
|
||||||
|
other = "superfast («ultrafast» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_ultrafast]
|
||||||
|
hash = "sha1-dfed981573ac2046832f9a9450bc9388958753fa"
|
||||||
|
other = "ultrafast (жылдам, бірақ файлдың салмағы көп болады)"
|
||||||
|
|
||||||
|
[preset_veryfast]
|
||||||
|
hash = "sha1-370b82509887d02d7a2ef9b110df4616b16123ce"
|
||||||
|
other = "veryfast («superfast» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
|
[preset_veryslow]
|
||||||
|
hash = "sha1-d428bfa6deea9dd5c7c1f80ceba24e123ae96d0d"
|
||||||
|
other = "veryslow («slower» қарағанда баяуырақ, бірақ файлдың салмағы аз болады)"
|
||||||
|
|
||||||
[programmLink]
|
[programmLink]
|
||||||
hash = "sha1-18f9a3fad6aacefe1b05eed23122800b391ff5ca"
|
hash = "sha1-18f9a3fad6aacefe1b05eed23122800b391ff5ca"
|
||||||
other = "Жобаның веб-сайты"
|
other = "Жобаның веб-сайты"
|
||||||
@@ -158,10 +362,18 @@ other = "Кезек"
|
|||||||
hash = "sha1-4864057d626a868fa60f999bed3191d61d045ddc"
|
hash = "sha1-4864057d626a868fa60f999bed3191d61d045ddc"
|
||||||
other = "Сақтау"
|
other = "Сақтау"
|
||||||
|
|
||||||
|
[selectEncoder]
|
||||||
|
hash = "sha1-88f3670b09758a3336057520a215058d61006abd"
|
||||||
|
other = "Кодировщик:"
|
||||||
|
|
||||||
[selectFFPathTitle]
|
[selectFFPathTitle]
|
||||||
hash = "sha1-95581446a28d968ff1a027c623159a7eb08654cf"
|
hash = "sha1-95581446a28d968ff1a027c623159a7eb08654cf"
|
||||||
other = "FFmpeg және FFprobe жолын көрсетіңіз"
|
other = "FFmpeg және FFprobe жолын көрсетіңіз"
|
||||||
|
|
||||||
|
[selectFormat]
|
||||||
|
hash = "sha1-f3809b0b48886570cd4cf1d7099de6da5b6d4524"
|
||||||
|
other = "Файл кеңейтімі:"
|
||||||
|
|
||||||
[settings]
|
[settings]
|
||||||
hash = "sha1-7f17c7c62a7fd8d1a508481f4778688927734c2f"
|
hash = "sha1-7f17c7c62a7fd8d1a508481f4778688927734c2f"
|
||||||
other = "Параметрлер"
|
other = "Параметрлер"
|
||||||
@@ -174,10 +386,14 @@ other = "FFmpeg функционалдығы тексерілуде..."
|
|||||||
hash = "sha1-92df86371f6c3a06ca1e4754f113142776a32d49"
|
hash = "sha1-92df86371f6c3a06ca1e4754f113142776a32d49"
|
||||||
other = "Сіз оны осы жерден жүктей аласыз"
|
other = "Сіз оны осы жерден жүктей аласыз"
|
||||||
|
|
||||||
|
[total]
|
||||||
|
hash = "sha1-3b5143902e0c5c84459aedf918e17604d9735b94"
|
||||||
|
other = "Барлығы"
|
||||||
|
|
||||||
[unzipRun]
|
[unzipRun]
|
||||||
hash = "sha1-c554dad13026668a1f6adf3171837c5d51bbac36"
|
hash = "sha1-c554dad13026668a1f6adf3171837c5d51bbac36"
|
||||||
other = "Орамнан шығарылуда..."
|
other = "Орамнан шығарылуда..."
|
||||||
|
|
||||||
[waiting]
|
[waitingQueue]
|
||||||
hash = "sha1-307429dd84150877080c4bbff2b340d1e7dadff2"
|
hash = "sha1-307429dd84150877080c4bbff2b340d1e7dadff2"
|
||||||
other = "Күту"
|
other = "Күту"
|
||||||
|
@@ -2,18 +2,54 @@ AlsoUsedProgram = "Также в программе используется:"
|
|||||||
about = "О программе"
|
about = "О программе"
|
||||||
aboutText = "Простенький интерфейс для консольной утилиты FFmpeg. \nНо я не являюсь автором самой утилиты FFmpeg."
|
aboutText = "Простенький интерфейс для консольной утилиты FFmpeg. \nНо я не являюсь автором самой утилиты FFmpeg."
|
||||||
buttonDownloadFFmpeg = "Скачать автоматически FFmpeg"
|
buttonDownloadFFmpeg = "Скачать автоматически FFmpeg"
|
||||||
buttonForSelectedDirTitle = "Папка куда будет сохраняться:"
|
buttonForSelectedDirTitle = "Сохранить в папку:"
|
||||||
cancel = "Отмена"
|
cancel = "Отмена"
|
||||||
changeFFPath = "FFmpeg и FFprobe"
|
changeFFPath = "FFmpeg и FFprobe"
|
||||||
changeLanguage = "Поменять язык"
|
changeLanguage = "Поменять язык"
|
||||||
checkboxOverwriteOutputFilesTitle = "Разрешить перезаписать файл"
|
checkboxOverwriteOutputFilesTitle = "Разрешить перезаписать файл"
|
||||||
choose = "выбрать"
|
choose = "выбрать"
|
||||||
completed = "Готово"
|
completedQueue = "Готово"
|
||||||
converterVideoFilesSubmitTitle = "Конвертировать"
|
converterVideoFilesSubmitTitle = "Конвертировать"
|
||||||
converterVideoFilesTitle = "Конвертор видео файлов в mp4"
|
converterVideoFilesTitle = "Конвертер видео, аудио и картинок"
|
||||||
download = "Скачать"
|
download = "Скачать"
|
||||||
downloadFFmpegFromSite = "Будет скачано с сайта:"
|
downloadFFmpegFromSite = "Будет скачано с сайта:"
|
||||||
downloadRun = "Скачивается..."
|
downloadRun = "Скачивается..."
|
||||||
|
encoderGroupAudio = "Аудио"
|
||||||
|
encoderGroupImage = "Картинки"
|
||||||
|
encoderGroupVideo = "Видео"
|
||||||
|
encoder_apng = "APNG image"
|
||||||
|
encoder_bmp = "BMP image"
|
||||||
|
encoder_flv = "FLV"
|
||||||
|
encoder_gif = "GIF image"
|
||||||
|
encoder_h264_nvenc = "H.264 с поддержкой NVIDIA"
|
||||||
|
encoder_libmp3lame = "libmp3lame MP3 (MPEG audio layer 3)"
|
||||||
|
encoder_libshine = "libshine MP3 (MPEG audio layer 3)"
|
||||||
|
encoder_libtwolame = "libtwolame MP2 (MPEG audio layer 2)"
|
||||||
|
encoder_libvpx = "libvpx VP8 (codec vp8)"
|
||||||
|
encoder_libvpx-vp9 = "libvpx VP9 (codec vp9)"
|
||||||
|
encoder_libwebp = "libwebp WebP image"
|
||||||
|
encoder_libwebp_anim = "libwebp_anim WebP image"
|
||||||
|
encoder_libx264 = "H.264 libx264"
|
||||||
|
encoder_libx265 = "H.265 libx265"
|
||||||
|
encoder_libxvid = "libxvidcore MPEG-4 part 2"
|
||||||
|
encoder_mjpeg = "MJPEG (Motion JPEG)"
|
||||||
|
encoder_mp2 = "MP2 (MPEG audio layer 2)"
|
||||||
|
encoder_mp2fixed = "MP2 fixed point (MPEG audio layer 2)"
|
||||||
|
encoder_mpeg1video = "MPEG-1"
|
||||||
|
encoder_mpeg2video = "MPEG-2"
|
||||||
|
encoder_mpeg4 = "MPEG-4 part 2"
|
||||||
|
encoder_msmpeg4 = "MPEG-4 part 2 Microsoft variant version 3"
|
||||||
|
encoder_msmpeg4v2 = "MPEG-4 part 2 Microsoft variant version 2"
|
||||||
|
encoder_msvideo1 = "Microsoft Video-1"
|
||||||
|
encoder_png = "PNG image"
|
||||||
|
encoder_qtrle = "QuickTime Animation (RLE) video"
|
||||||
|
encoder_sgi = "SGI image"
|
||||||
|
encoder_tiff = "TIFF image"
|
||||||
|
encoder_wmav1 = "Windows Media Audio 1"
|
||||||
|
encoder_wmav2 = "Windows Media Audio 2"
|
||||||
|
encoder_wmv1 = "Windows Media Video 7"
|
||||||
|
encoder_wmv2 = "Windows Media Video 8"
|
||||||
|
encoder_xbm = "XBM (X BitMap) image"
|
||||||
error = "Произошла ошибка!"
|
error = "Произошла ошибка!"
|
||||||
errorConverter = "не смогли отконвертировать видео"
|
errorConverter = "не смогли отконвертировать видео"
|
||||||
errorDatabase = "не смогли создать файл 'database' в папке 'data'"
|
errorDatabase = "не смогли создать файл 'database' в папке 'data'"
|
||||||
@@ -21,26 +57,44 @@ errorFFmpeg = "это не FFmpeg"
|
|||||||
errorFFmpegVersion = "Не смогли определить версию FFmpeg"
|
errorFFmpegVersion = "Не смогли определить версию FFmpeg"
|
||||||
errorFFprobe = "это не FFprobe"
|
errorFFprobe = "это не FFprobe"
|
||||||
errorFFprobeVersion = "Не смогли определить версию FFprobe"
|
errorFFprobeVersion = "Не смогли определить версию FFprobe"
|
||||||
errorSelectedFolderSave = "Не выбрали папку для сохранения!"
|
errorQueue = "Ошибка"
|
||||||
|
errorSelectedEncoder = "Конвертер не выбран"
|
||||||
|
errorSelectedFolderSave = "Папка для сохранения не выбрана!"
|
||||||
|
errorSelectedFormat = "Расширение файла не выбрана"
|
||||||
exit = "Выход"
|
exit = "Выход"
|
||||||
ffmpegLGPL = "Это программное обеспечение использует библиотеки из проекта **FFmpeg** под **[LGPLv2.1](http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html)**."
|
ffmpegLGPL = "Это программное обеспечение использует библиотеки из проекта **FFmpeg** под **[LGPLv2.1](http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html)**."
|
||||||
ffmpegTrademark = "**FFmpeg** — торговая марка **[Fabrice Bellard](http://bellard.org/)** , создателя проекта **[FFmpeg](https://ffmpeg.org/about.html)**."
|
ffmpegTrademark = "**FFmpeg** — торговая марка **[Fabrice Bellard](http://bellard.org/)** , создателя проекта **[FFmpeg](https://ffmpeg.org/about.html)**."
|
||||||
fileVideoForConversionTitle = "Файл для ковертации:"
|
fileForConversionTitle = "Файл:"
|
||||||
|
formPreset = "Предустановка"
|
||||||
help = "Справка"
|
help = "Справка"
|
||||||
inProgress = "Выполняется"
|
inProgressQueue = "Выполняется"
|
||||||
languageSelectionFormHead = "Переключить язык"
|
languageSelectionFormHead = "Переключить язык"
|
||||||
languageSelectionHead = "Выберите язык"
|
languageSelectionHead = "Выберите язык"
|
||||||
licenseLink = "Сведения о лицензии"
|
licenseLink = "Сведения о лицензии"
|
||||||
licenseLinkOther = "Лицензии от других продуктов, которые используются в программе"
|
licenseLinkOther = "Лицензии от других продуктов, которые используются в программе"
|
||||||
|
parameterCheckbox = "Включить параметр"
|
||||||
pathToFfmpeg = "Путь к FFmpeg:"
|
pathToFfmpeg = "Путь к FFmpeg:"
|
||||||
pathToFfprobe = "Путь к FFprobe:"
|
pathToFfprobe = "Путь к FFprobe:"
|
||||||
|
preset_fast = "fast (медленней чем faster, но будет файл и меньше весить)"
|
||||||
|
preset_faster = "faster (медленней чем veryfast, но будет файл и меньше весить)"
|
||||||
|
preset_medium = "medium (медленней чем fast, но будет файл и меньше весить)"
|
||||||
|
preset_placebo = "placebo (не рекомендуется)"
|
||||||
|
preset_slow = "slow (медленней чем medium, но будет файл и меньше весить)"
|
||||||
|
preset_slower = "slower (медленней чем slow, но будет файл и меньше весить)"
|
||||||
|
preset_superfast = "superfast (медленней чем ultrafast, но будет файл и меньше весить)"
|
||||||
|
preset_ultrafast = "ultrafast (быстро, но файл будет много весить)"
|
||||||
|
preset_veryfast = "veryfast (медленней чем superfast, но будет файл и меньше весить)"
|
||||||
|
preset_veryslow = "veryslow (медленней чем slower, но будет файл и меньше весить)"
|
||||||
programmLink = "Сайт проекта"
|
programmLink = "Сайт проекта"
|
||||||
programmVersion = "**Версия программы:** {{.Version}}"
|
programmVersion = "**Версия программы:** {{.Version}}"
|
||||||
queue = "Очередь"
|
queue = "Очередь"
|
||||||
save = "Сохранить"
|
save = "Сохранить"
|
||||||
|
selectEncoder = "Кодировщик:"
|
||||||
selectFFPathTitle = "Укажите путь к FFmpeg и к FFprobe"
|
selectFFPathTitle = "Укажите путь к FFmpeg и к FFprobe"
|
||||||
|
selectFormat = "Расширение файла:"
|
||||||
settings = "Настройки"
|
settings = "Настройки"
|
||||||
testFF = "Проверка FFmpeg на работоспособность..."
|
testFF = "Проверка FFmpeg на работоспособность..."
|
||||||
titleDownloadLink = "Скачать можно от сюда"
|
titleDownloadLink = "Скачать можно от сюда"
|
||||||
|
total = "Всего"
|
||||||
unzipRun = "Распаковывается..."
|
unzipRun = "Распаковывается..."
|
||||||
waiting = "В очереди"
|
waitingQueue = "В очереди"
|
||||||
|
@@ -1,15 +0,0 @@
|
|||||||
[completed]
|
|
||||||
hash = "sha1-398c7d4f7b0d522afb930769c0fbb1a9f4b61fbe"
|
|
||||||
other = "Completed"
|
|
||||||
|
|
||||||
[inProgress]
|
|
||||||
hash = "sha1-eff79c40e2100ae5fadf3a7d99336025edcca8b5"
|
|
||||||
other = "In Progress"
|
|
||||||
|
|
||||||
[queue]
|
|
||||||
hash = "sha1-aec93b16baeaf55fed871075c9494a460e4a91b8"
|
|
||||||
other = "Queue"
|
|
||||||
|
|
||||||
[waiting]
|
|
||||||
hash = "sha1-307429dd84150877080c4bbff2b340d1e7dadff2"
|
|
||||||
other = "Waiting"
|
|
@@ -1,15 +0,0 @@
|
|||||||
[completed]
|
|
||||||
hash = "sha1-398c7d4f7b0d522afb930769c0fbb1a9f4b61fbe"
|
|
||||||
other = "Дайын"
|
|
||||||
|
|
||||||
[inProgress]
|
|
||||||
hash = "sha1-eff79c40e2100ae5fadf3a7d99336025edcca8b5"
|
|
||||||
other = "Орындалуда"
|
|
||||||
|
|
||||||
[queue]
|
|
||||||
hash = "sha1-aec93b16baeaf55fed871075c9494a460e4a91b8"
|
|
||||||
other = "Кезек"
|
|
||||||
|
|
||||||
[waiting]
|
|
||||||
hash = "sha1-307429dd84150877080c4bbff2b340d1e7dadff2"
|
|
||||||
other = "Күту"
|
|
34
main.go
34
main.go
@@ -4,6 +4,7 @@ import (
|
|||||||
"errors"
|
"errors"
|
||||||
"fyne.io/fyne/v2"
|
"fyne.io/fyne/v2"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/convertor"
|
||||||
|
dberror "git.kor-elf.net/kor-elf/gui-for-ffmpeg/db"
|
||||||
error2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/error"
|
error2 "git.kor-elf.net/kor-elf/gui-for-ffmpeg/error"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/handler"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/handler"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/kernel"
|
||||||
@@ -12,10 +13,10 @@ import (
|
|||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/migration"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/migration"
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/setting"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/setting"
|
||||||
_ "github.com/mattn/go-sqlite3"
|
_ "github.com/mattn/go-sqlite3"
|
||||||
|
"go.etcd.io/bbolt"
|
||||||
"golang.org/x/text/language"
|
"golang.org/x/text/language"
|
||||||
"gorm.io/driver/sqlite"
|
|
||||||
"gorm.io/gorm"
|
|
||||||
"os"
|
"os"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
var application kernel.AppContract
|
var application kernel.AppContract
|
||||||
@@ -26,7 +27,7 @@ func init() {
|
|||||||
appMetadata := &fyne.AppMetadata{
|
appMetadata := &fyne.AppMetadata{
|
||||||
ID: "net.kor-elf.projects.gui-for-ffmpeg",
|
ID: "net.kor-elf.projects.gui-for-ffmpeg",
|
||||||
Name: "GUI for FFmpeg",
|
Name: "GUI for FFmpeg",
|
||||||
Version: "0.4.0",
|
Version: "0.7.0",
|
||||||
Icon: iconResource,
|
Icon: iconResource,
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -37,35 +38,33 @@ func init() {
|
|||||||
|
|
||||||
ffPathUtilities = &kernel.FFPathUtilities{FFmpeg: "", FFprobe: ""}
|
ffPathUtilities = &kernel.FFPathUtilities{FFmpeg: "", FFprobe: ""}
|
||||||
convertorService := kernel.NewService(ffPathUtilities)
|
convertorService := kernel.NewService(ffPathUtilities)
|
||||||
layoutLocalizerListener := kernel.NewLayoutLocalizerListener()
|
|
||||||
localizerService.AddListener(layoutLocalizerListener)
|
|
||||||
|
|
||||||
queue := kernel.NewQueueList()
|
queue := kernel.NewQueueList()
|
||||||
application = kernel.NewApp(
|
application = kernel.NewApp(
|
||||||
appMetadata,
|
appMetadata,
|
||||||
localizerService,
|
localizerService,
|
||||||
queue,
|
queue,
|
||||||
kernel.NewQueueLayoutObject(queue, localizerService, layoutLocalizerListener),
|
kernel.NewQueueLayoutObject(queue, localizerService),
|
||||||
convertorService,
|
convertorService,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
errorView := error2.NewView(application)
|
errorView := error2.NewView(application)
|
||||||
if canCreateFile("data/database") != true {
|
if canCreateFile("data/database.db") != true {
|
||||||
errorView.PanicErrorWriteDirectoryData()
|
errorView.PanicErrorWriteDirectoryData()
|
||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
db, err := gorm.Open(sqlite.Open("data/database"), &gorm.Config{})
|
db, err := bbolt.Open("data/database.db", 0600, &bbolt.Options{Timeout: 3 * time.Second})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
errorView.PanicError(err)
|
errorView.PanicError(err)
|
||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
defer appCloseWithDb(db)
|
defer db.Close()
|
||||||
|
|
||||||
err = migration.Run(db)
|
err = migration.Run(db)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -77,7 +76,7 @@ func main() {
|
|||||||
settingRepository := setting.NewRepository(db)
|
settingRepository := setting.NewRepository(db)
|
||||||
convertorRepository := convertor.NewRepository(settingRepository)
|
convertorRepository := convertor.NewRepository(settingRepository)
|
||||||
pathFFmpeg, err := convertorRepository.GetPathFfmpeg()
|
pathFFmpeg, err := convertorRepository.GetPathFfmpeg()
|
||||||
if err != nil && errors.Is(err, gorm.ErrRecordNotFound) == false {
|
if err != nil && errors.Is(err, dberror.ErrRecordNotFound) == false {
|
||||||
errorView.PanicError(err)
|
errorView.PanicError(err)
|
||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
return
|
return
|
||||||
@@ -85,7 +84,7 @@ func main() {
|
|||||||
ffPathUtilities.FFmpeg = pathFFmpeg
|
ffPathUtilities.FFmpeg = pathFFmpeg
|
||||||
|
|
||||||
pathFFprobe, err := convertorRepository.GetPathFfprobe()
|
pathFFprobe, err := convertorRepository.GetPathFfprobe()
|
||||||
if err != nil && errors.Is(err, gorm.ErrRecordNotFound) == false {
|
if err != nil && errors.Is(err, dberror.ErrRecordNotFound) == false {
|
||||||
errorView.PanicError(err)
|
errorView.PanicError(err)
|
||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
return
|
return
|
||||||
@@ -97,13 +96,11 @@ func main() {
|
|||||||
|
|
||||||
localizerView := localizer.NewView(application)
|
localizerView := localizer.NewView(application)
|
||||||
convertorView := convertor.NewView(application)
|
convertorView := convertor.NewView(application)
|
||||||
convertorHandler := handler.NewConvertorHandler(application, convertorView, convertorRepository)
|
convertorHandler := handler.NewConvertorHandler(application, convertorView, errorView, convertorRepository)
|
||||||
|
|
||||||
localizerRepository := localizer.NewRepository(settingRepository)
|
localizerRepository := localizer.NewRepository(settingRepository)
|
||||||
menuView := menu.NewView(application)
|
menuView := menu.NewView(application)
|
||||||
localizerListener := handler.NewLocalizerListener()
|
mainMenu := handler.NewMenuHandler(application, convertorHandler, menuView, localizerView, localizerRepository)
|
||||||
application.GetLocalizerService().AddListener(localizerListener)
|
|
||||||
mainMenu := handler.NewMenuHandler(application, convertorHandler, menuView, localizerView, localizerRepository, localizerListener)
|
|
||||||
|
|
||||||
mainHandler := handler.NewMainHandler(application, convertorHandler, mainMenu, localizerRepository)
|
mainHandler := handler.NewMainHandler(application, convertorHandler, mainMenu, localizerRepository)
|
||||||
mainHandler.Start()
|
mainHandler.Start()
|
||||||
@@ -112,13 +109,6 @@ func main() {
|
|||||||
application.GetWindow().ShowAndRun()
|
application.GetWindow().ShowAndRun()
|
||||||
}
|
}
|
||||||
|
|
||||||
func appCloseWithDb(db *gorm.DB) {
|
|
||||||
sqlDB, err := db.DB()
|
|
||||||
if err == nil {
|
|
||||||
_ = sqlDB.Close()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func canCreateFile(path string) bool {
|
func canCreateFile(path string) bool {
|
||||||
file, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY, 0666)
|
file, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY, 0666)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@@ -1,15 +1,12 @@
|
|||||||
package migration
|
package migration
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/setting"
|
"go.etcd.io/bbolt"
|
||||||
"gorm.io/gorm"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func Run(db *gorm.DB) error {
|
func Run(db *bbolt.DB) error {
|
||||||
err := db.AutoMigrate(&setting.Setting{})
|
return db.Update(func(tx *bbolt.Tx) error {
|
||||||
if err != nil {
|
_, err := tx.CreateBucketIfNotExists([]byte("settings"))
|
||||||
return err
|
return err
|
||||||
}
|
})
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
@@ -1,7 +1,6 @@
|
|||||||
package setting
|
package setting
|
||||||
|
|
||||||
type Setting struct {
|
type Setting struct {
|
||||||
ID uint `gorm:"primary_key"`
|
Code string `json:"code"`
|
||||||
Code string `gorm:"type:varchar(100);uniqueIndex;not null"`
|
Value string `json:"value"`
|
||||||
Value string `gorm:"type:text"`
|
|
||||||
}
|
}
|
||||||
|
@@ -1,8 +1,10 @@
|
|||||||
package setting
|
package setting
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"gorm.io/gorm"
|
"git.kor-elf.net/kor-elf/gui-for-ffmpeg/db"
|
||||||
|
"go.etcd.io/bbolt"
|
||||||
)
|
)
|
||||||
|
|
||||||
type RepositoryContract interface {
|
type RepositoryContract interface {
|
||||||
@@ -12,44 +14,69 @@ type RepositoryContract interface {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type Repository struct {
|
type Repository struct {
|
||||||
db *gorm.DB
|
db *bbolt.DB
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewRepository(db *gorm.DB) *Repository {
|
func NewRepository(db *bbolt.DB) *Repository {
|
||||||
return &Repository{db}
|
return &Repository{db}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r Repository) GetValue(code string) (value string, err error) {
|
func (r Repository) GetValue(code string) (value string, err error) {
|
||||||
var setting Setting
|
var setting Setting
|
||||||
err = r.db.Where("code = ?", code).First(&setting).Error
|
|
||||||
|
err = r.db.View(func(tx *bbolt.Tx) error {
|
||||||
|
b := tx.Bucket([]byte("settings"))
|
||||||
|
if b == nil {
|
||||||
|
return errors.New("bucket 'settings' not found")
|
||||||
|
}
|
||||||
|
val := b.Get([]byte(code))
|
||||||
|
if val == nil {
|
||||||
|
return db.ErrRecordNotFound
|
||||||
|
}
|
||||||
|
return json.Unmarshal(val, &setting)
|
||||||
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
return setting.Value, err
|
|
||||||
|
return setting.Value, nil
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r Repository) Create(setting Setting) (Setting, error) {
|
func (r Repository) Create(setting Setting) (Setting, error) {
|
||||||
err := r.db.Create(&setting).Error
|
err := r.db.Update(func(tx *bbolt.Tx) error {
|
||||||
if err != nil {
|
b := tx.Bucket([]byte("settings"))
|
||||||
return setting, err
|
if b == nil {
|
||||||
|
return errors.New("bucket 'settings' not found")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
data, err := json.Marshal(setting)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return b.Put([]byte(setting.Code), data)
|
||||||
|
})
|
||||||
return setting, err
|
return setting, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r Repository) CreateOrUpdate(code string, value string) (Setting, error) {
|
func (r Repository) CreateOrUpdate(code string, value string) (Setting, error) {
|
||||||
var setting Setting
|
var setting Setting
|
||||||
err := r.db.Where("code = ?", code).First(&setting).Error
|
setting.Code = code
|
||||||
|
setting.Value = value
|
||||||
|
|
||||||
|
err := r.db.Update(func(tx *bbolt.Tx) error {
|
||||||
|
b := tx.Bucket([]byte("settings"))
|
||||||
|
if b == nil {
|
||||||
|
return errors.New("bucket 'settings' not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
data, err := json.Marshal(setting)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if errors.Is(err, gorm.ErrRecordNotFound) == true {
|
return err
|
||||||
setting = Setting{Code: code, Value: value}
|
|
||||||
return r.Create(setting)
|
|
||||||
} else {
|
|
||||||
return setting, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
err = r.db.Model(&setting).UpdateColumn("value", value).Error
|
|
||||||
if err != nil {
|
|
||||||
return setting, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return b.Put([]byte(code), data)
|
||||||
|
})
|
||||||
return setting, err
|
return setting, err
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user