mirror of
https://github.com/HIllya51/LunaTranslator.git
synced 2025-01-07 21:14:13 +08:00
94 lines
3.0 KiB
C++
94 lines
3.0 KiB
C++
|
|
|||
|
#include "ebyroid.h"
|
|||
|
#include<Windows.h>
|
|||
|
#include"api_adapter.h"
|
|||
|
#include "ebyutil.h"
|
|||
|
#include <io.h>
|
|||
|
#include <fcntl.h>
|
|||
|
using ebyroid::Ebyroid;
|
|||
|
#include"types.h"
|
|||
|
#pragma comment(lib,"winmm.lib")
|
|||
|
|
|||
|
int voiceroid2wmain(int argc,wchar_t *wargv[]) {
|
|||
|
UINT codepage = GetACP();
|
|||
|
|
|||
|
char** argv = new char* [argc];
|
|||
|
for (int i = 0; i < argc; i++)
|
|||
|
{
|
|||
|
int length = WideCharToMultiByte(codepage, 0, wargv[i], -1, NULL, 0, NULL, NULL);
|
|||
|
argv[i] = new char[length];
|
|||
|
WideCharToMultiByte(codepage, 0, wargv[i], -1, argv[i], length, NULL, NULL);
|
|||
|
}
|
|||
|
|
|||
|
HANDLE hPipe = CreateNamedPipeA(argv[7], PIPE_ACCESS_DUPLEX, PIPE_TYPE_MESSAGE | PIPE_READMODE_MESSAGE | PIPE_WAIT
|
|||
|
, PIPE_UNLIMITED_INSTANCES, 65535, 65535, NMPWAIT_WAIT_FOREVER, 0);
|
|||
|
|
|||
|
Ebyroid* ebyroid;
|
|||
|
|
|||
|
printf("argc %d \n", argc);
|
|||
|
for (int i = 0; i < argc; i++) {
|
|||
|
printf("%d %s\n", i, argv[i]);
|
|||
|
}
|
|||
|
ebyroid = Ebyroid::Create((const char*)argv[1],//"C:\\dataH\\Yukari2",
|
|||
|
(const char*)argv[2],
|
|||
|
(const char*)argv[3],//"yukari_emo_44",
|
|||
|
2, //<2F>̶<EFBFBD><CCB6><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
atof((const char*)argv[5]));//1); //0.1-2,0.5-4
|
|||
|
SECURITY_DESCRIPTOR sd = {};
|
|||
|
InitializeSecurityDescriptor(&sd, SECURITY_DESCRIPTOR_REVISION);
|
|||
|
SetSecurityDescriptorDacl(&sd, TRUE, NULL, FALSE);
|
|||
|
SECURITY_ATTRIBUTES allAccess = SECURITY_ATTRIBUTES{ sizeof(SECURITY_ATTRIBUTES), &sd, FALSE };
|
|||
|
SetEvent(CreateEventA(&allAccess, FALSE, FALSE, argv[8]));
|
|||
|
if (ConnectNamedPipe(hPipe, NULL) != NULL) {
|
|||
|
DWORD len = 0;
|
|||
|
|
|||
|
}
|
|||
|
int freq1 = atoi(argv[4]);
|
|||
|
printf("pipe connected");
|
|||
|
int II = 0;
|
|||
|
while (true) {
|
|||
|
II += 1;
|
|||
|
unsigned char* out;
|
|||
|
size_t output_size;
|
|||
|
int16_t* out2;
|
|||
|
|
|||
|
unsigned char input_j[4096] = { 0 };
|
|||
|
DWORD _;
|
|||
|
if(!ReadFile(hPipe, input_j,4096, &_, NULL))break;
|
|||
|
|
|||
|
printf("%s\n", input_j);
|
|||
|
//int result = ebyroid->Hiragana((const unsigned char*)UnicodeToShift_jis(input), &out, &output_size);
|
|||
|
int result = ebyroid->Hiragana((const unsigned char*)input_j, &out, &output_size);
|
|||
|
|
|||
|
printf("%s\n", out);
|
|||
|
result = ebyroid->Speech(out, &out2, &output_size);
|
|||
|
char newname[1024] = { 0 };
|
|||
|
sprintf(newname, "%s%d.wav", argv[6], II);
|
|||
|
FILE* F = fopen(newname , "wb");
|
|||
|
|
|||
|
|
|||
|
int fsize = output_size + 44;
|
|||
|
fseek(F, 0, SEEK_SET);
|
|||
|
fwrite("RIFF", 1, 4, F);
|
|||
|
fwrite(&fsize, 4, 1, F);
|
|||
|
fwrite("WAVEfmt ", 1, 8, F);
|
|||
|
fwrite("\x10\x00\x00\x00\x01\x00\x01\x00", 1, 8, F);
|
|||
|
int freq = freq1;
|
|||
|
fwrite(&freq, 4, 1, F);
|
|||
|
freq = freq * 2;
|
|||
|
fwrite(&freq, 4, 1, F);
|
|||
|
fwrite("\x02\x00\x10\x00", 1, 4, F);
|
|||
|
fwrite("data", 1, 4, F);
|
|||
|
int sz = fsize - 44;
|
|||
|
fwrite(&sz, 4, 1, F);
|
|||
|
printf("%d \n", ftell(F));
|
|||
|
fwrite((char*)out2, 1, output_size, F);
|
|||
|
fclose(F);
|
|||
|
WriteFile(hPipe, newname, strlen(newname), &_, NULL);
|
|||
|
free(out);
|
|||
|
free(out2);
|
|||
|
}
|
|||
|
//sndPlaySound((const char*)argv[6], SND_SYNC);
|
|||
|
return 0;
|
|||
|
}
|