twainui解决其他模态窗口可能的卡住问题

This commit is contained in:
luoliangyi 2023-11-21 09:26:31 +08:00
parent 461020ea72
commit df6eff0638
2 changed files with 146 additions and 135 deletions

View File

@ -23,17 +23,17 @@ Manager::Manager()
qRegisterMetaType<HGImage>("HGImage"); qRegisterMetaType<HGImage>("HGImage");
connect(this, SIGNAL(init()), this, SLOT(on_init())); connect(this, SIGNAL(init()), this, SLOT(on_init()));
connect(this, SIGNAL(createDeviceSelect(unsigned int)), this, SLOT(on_createDeviceSelect(unsigned int))); connect(this, SIGNAL(createDeviceSelect(void *)), this, SLOT(on_createDeviceSelect(void *)));
connect(this, SIGNAL(createSettingUi(unsigned int)), this, SLOT(on_createSettingUi(unsigned int))); connect(this, SIGNAL(createSettingUi(void *)), this, SLOT(on_createSettingUi(void *)));
connect(this, SIGNAL(createProgressUi(void *)), this, SLOT(on_createProgressUi(void *))); connect(this, SIGNAL(createProgressUi(void *)), this, SLOT(on_createProgressUi(void *)));
connect(this, SIGNAL(createMessageBoxUi(unsigned int)), this, SLOT(on_createMessageBoxUi(unsigned int))); connect(this, SIGNAL(createMessageBoxUi(void *)), this, SLOT(on_createMessageBoxUi(void *)));
connect(this, SIGNAL(createTwainSrcUi(unsigned int)), this, SLOT(on_createTwainSrcUi(unsigned int))); connect(this, SIGNAL(createTwainSrcUi(void *)), this, SLOT(on_createTwainSrcUi(void *)));
connect(this, SIGNAL(createSaneSrcUi(unsigned int)), this, SLOT(on_createSaneSrcUi(unsigned int))); connect(this, SIGNAL(createSaneSrcUi(void *)), this, SLOT(on_createSaneSrcUi(void *)));
connect(this, SIGNAL(createAbnormalImgUi(unsigned int, HGImage)), this, SLOT(on_createAbnormalImgUi(unsigned int, HGImage))); connect(this, SIGNAL(createAbnormalImgUi(void *, HGImage)), this, SLOT(on_createAbnormalImgUi(void *, HGImage)));
connect(this, SIGNAL(deleteSettingUi(unsigned int)), this, SLOT(on_deleteSettingUi(unsigned int))); connect(this, SIGNAL(deleteSettingUi(void *)), this, SLOT(on_deleteSettingUi(void *)));
connect(this, SIGNAL(deleteProgressUi(unsigned int)), this, SLOT(on_deleteProgressUi(unsigned int))); connect(this, SIGNAL(deleteProgressUi(void *)), this, SLOT(on_deleteProgressUi(void *)));
connect(this, SIGNAL(deleteMessageBoxUi(unsigned int)), this, SLOT(on_deleteMessageBoxUi(unsigned int))); connect(this, SIGNAL(deleteMessageBoxUi(void *)), this, SLOT(on_deleteMessageBoxUi(void *)));
emit init(); emit init();
} }
@ -50,22 +50,21 @@ int Manager::showDeviceSelect(const std::vector<DEVQUEUI>& devs)
// param // param
m_DeviceSelectDevs = devs; m_DeviceSelectDevs = devs;
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
ThreadId = GetCurrentThreadId(); {
hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
}
#endif #endif
emit createDeviceSelect(ThreadId); emit createDeviceSelect(hStopEvent);
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hStopEvent)
{ {
MSG msg; msgLoop(hStopEvent);
while (GetMessage(&msg, NULL, 0, 0)) CloseHandle(hStopEvent);
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
} }
#endif #endif
@ -84,16 +83,15 @@ int Manager::showSettingUi(SANE_Handle device, HWND parent, LPSANEAPI api, const
m_with_scan = with_scan; m_with_scan = with_scan;
m_settingUiCallback = callback; m_settingUiCallback = callback;
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
{ {
ThreadId = GetCurrentThreadId(); hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
HGBase_WriteInfo(HGBASE_INFOTYPE_DESC, "[Manager::showSettingUi] qApp->thread() != QThread::currentThread(), ThreadId=%u", ThreadId);
} }
#endif #endif
emit createSettingUi(ThreadId); emit createSettingUi(hStopEvent);
HGBase_WriteInfo(HGBASE_INFOTYPE_DESC, "[Manager::showSettingUi] emit createSettingUi(ThreadId)"); HGBase_WriteInfo(HGBASE_INFOTYPE_DESC, "[Manager::showSettingUi] emit createSettingUi(ThreadId)");
return 0; return 0;
} }
@ -119,31 +117,7 @@ int Manager::showProgressUi(HWND parent, std::function<void (ui_result)> callbac
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (nullptr != hStopEvent) if (nullptr != hStopEvent)
{ {
while (1) msgLoop(hStopEvent);
{
MSG msg;
while (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
HANDLE arEvents[1] = { hStopEvent };
DWORD result = MsgWaitForMultipleObjectsEx(1, arEvents, INFINITE, QS_ALLINPUT, MWMO_ALERTABLE);
if (result == WAIT_OBJECT_0 + 1) // msg received
{
continue;
}
else if (result == WAIT_OBJECT_0)
{
break;
}
else if (result == WAIT_IO_COMPLETION)
{
break;
}
}
CloseHandle(hStopEvent); CloseHandle(hStopEvent);
} }
#endif #endif
@ -160,22 +134,21 @@ int Manager::showMessageBoxUi(HWND parent, int event, void *msg, int flag)
m_message = (char*)msg; m_message = (char*)msg;
m_flag = flag; m_flag = flag;
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
ThreadId = GetCurrentThreadId(); {
hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
}
#endif #endif
emit createMessageBoxUi(ThreadId); emit createMessageBoxUi(hStopEvent);
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hStopEvent)
{ {
MSG msg; msgLoop(hStopEvent);
while (GetMessage(&msg, NULL, 0, 0)) CloseHandle(hStopEvent);
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
} }
#endif #endif
@ -193,22 +166,21 @@ int Manager::showTwainSrcUi(const TW_IDENTITY *vds, HGUInt count, const char* de
m_defDsName = defDevName; m_defDsName = defDevName;
memset(&m_ds, 0, sizeof(TW_IDENTITY)); memset(&m_ds, 0, sizeof(TW_IDENTITY));
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
ThreadId = GetCurrentThreadId(); {
hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
}
#endif #endif
emit createTwainSrcUi(ThreadId); emit createTwainSrcUi(hStopEvent);
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hStopEvent)
{ {
MSG msg; msgLoop(hStopEvent);
while (GetMessage(&msg, NULL, 0, 0)) CloseHandle(hStopEvent);
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
} }
#endif #endif
@ -239,22 +211,21 @@ int Manager::showSaneSrcUi(const char **manuNames, const char **sanePaths, HGWin
memset(&m_saneApi, 0, sizeof(SANEAPI)); memset(&m_saneApi, 0, sizeof(SANEAPI));
m_saneManuName.clear(); m_saneManuName.clear();
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
ThreadId = GetCurrentThreadId(); {
hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
}
#endif #endif
emit createSaneSrcUi(ThreadId); emit createSaneSrcUi(hStopEvent);
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hStopEvent)
{ {
MSG msg; msgLoop(hStopEvent);
while (GetMessage(&msg, NULL, 0, 0)) CloseHandle(hStopEvent);
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
} }
#endif #endif
@ -287,22 +258,21 @@ int Manager::showAbnormalImgUi(SANE_Image *img)
HGImage image = NULL; HGImage image = NULL;
HGBase_CreateImageWithData(img->data, &imgInfo, &image); HGBase_CreateImageWithData(img->data, &imgInfo, &image);
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
ThreadId = GetCurrentThreadId(); {
hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
}
#endif #endif
emit createAbnormalImgUi(ThreadId, image); emit createAbnormalImgUi(hStopEvent, image);
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hStopEvent)
{ {
MSG msg; msgLoop(hStopEvent);
while (GetMessage(&msg, NULL, 0, 0)) CloseHandle(hStopEvent);
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
} }
#endif #endif
@ -313,35 +283,41 @@ int Manager::showAbnormalImgUi(SANE_Image *img)
void Manager::closeSettingUi() void Manager::closeSettingUi()
{ {
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
ThreadId = GetCurrentThreadId(); {
hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
}
#endif #endif
emit deleteSettingUi(ThreadId); emit deleteSettingUi(hStopEvent);
} }
void Manager::closeProgressUi() void Manager::closeProgressUi()
{ {
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
ThreadId = GetCurrentThreadId(); {
hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
}
#endif #endif
emit deleteProgressUi(ThreadId); emit deleteProgressUi(hStopEvent);
} }
void Manager::closeMessageBoxUi() void Manager::closeMessageBoxUi()
{ {
unsigned int ThreadId = 0; void *hStopEvent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (qApp->thread() != QThread::currentThread()) if (qApp->thread() != QThread::currentThread())
ThreadId = GetCurrentThreadId(); {
hStopEvent = ::CreateEvent(0, FALSE, FALSE, 0);
}
#endif #endif
emit deleteMessageBoxUi(ThreadId); emit deleteMessageBoxUi(hStopEvent);
} }
void Manager::clear_functions(void) void Manager::clear_functions(void)
@ -355,6 +331,38 @@ void Manager::clear_functions(void)
m_settingUi->clear_callback(); m_settingUi->clear_callback();
} }
void Manager::msgLoop(void *hEvent)
{
#ifdef HG_CMP_MSC
assert(nullptr != hEvent);
while (1)
{
MSG msg;
while (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
HANDLE arEvents[1] = { hEvent };
DWORD result = MsgWaitForMultipleObjectsEx(1, arEvents, INFINITE, QS_ALLINPUT, MWMO_ALERTABLE);
if (result == WAIT_OBJECT_0 + 1) // msg received
{
continue;
}
else if (result == WAIT_OBJECT_0)
{
break;
}
else if (result == WAIT_IO_COMPLETION)
{
break;
}
}
#endif
}
void Manager::on_init() void Manager::on_init()
{ {
m_langCode = lang_get_cur_code_page(); m_langCode = lang_get_cur_code_page();
@ -373,21 +381,21 @@ void Manager::on_init()
QCoreApplication::installTranslator(&m_translator_qt); QCoreApplication::installTranslator(&m_translator_qt);
} }
void Manager::on_createDeviceSelect(unsigned int ThreadId) void Manager::on_createDeviceSelect(void *hEvent)
{ {
Dialog_device_select dlg(m_DeviceSelectDevs); Dialog_device_select dlg(m_DeviceSelectDevs);
dlg.exec(); dlg.exec();
m_DeviceSelectResult = dlg.getDevId(); m_DeviceSelectResult = dlg.getDevId();
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hEvent)
{ {
::PostThreadMessage(ThreadId, WM_QUIT, 0, 0); SetEvent((HANDLE)hEvent);
} }
#endif #endif
} }
void Manager::on_createSettingUi(unsigned int ThreadId) void Manager::on_createSettingUi(void *hEvent)
{ {
QWidget *qParent = nullptr; QWidget *qParent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
@ -448,8 +456,8 @@ void Manager::on_createProgressUi(void *hEvent)
m_progressUi = new Dialog_progress_ui(this, close_prog, m_notify, qParent); m_progressUi = new Dialog_progress_ui(this, close_prog, m_notify, qParent);
m_progressUi->setModal(true); m_progressUi->setModal(true);
m_progressUi->show(); m_progressUi->show();
HGBase_WriteInfo(HGBASE_INFOTYPE_DESC, "[Manager::on_createProgressUi] m_progressUi->show()"); HGBase_WriteInfo(HGBASE_INFOTYPE_DESC, "[Manager::on_createProgressUi] m_progressUi->show()");
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (nullptr != hEvent) if (nullptr != hEvent)
{ {
@ -458,7 +466,7 @@ void Manager::on_createProgressUi(void *hEvent)
#endif #endif
} }
void Manager::on_createMessageBoxUi(unsigned int ThreadId) void Manager::on_createMessageBoxUi(void *hEvent)
{ {
QWidget *qParent = nullptr; QWidget *qParent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
@ -477,14 +485,14 @@ void Manager::on_createMessageBoxUi(unsigned int ThreadId)
dlg.exec(); dlg.exec();
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hEvent)
{ {
::PostThreadMessage(ThreadId, WM_QUIT, 0, 0); SetEvent((HANDLE)hEvent);
} }
#endif #endif
} }
void Manager::on_createTwainSrcUi(unsigned int ThreadId) void Manager::on_createTwainSrcUi(void *hEvent)
{ {
QWidget *qParent = nullptr; QWidget *qParent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
@ -505,14 +513,14 @@ void Manager::on_createTwainSrcUi(unsigned int ThreadId)
} }
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hEvent)
{ {
::PostThreadMessage(ThreadId, WM_QUIT, 0, 0); SetEvent((HANDLE)hEvent);
} }
#endif #endif
} }
void Manager::on_createSaneSrcUi(unsigned int ThreadId) void Manager::on_createSaneSrcUi(void *hEvent)
{ {
QWidget *qParent = nullptr; QWidget *qParent = nullptr;
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
@ -535,28 +543,28 @@ void Manager::on_createSaneSrcUi(unsigned int ThreadId)
} }
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hEvent)
{ {
::PostThreadMessage(ThreadId, WM_QUIT, 0, 0); SetEvent((HANDLE)hEvent);
} }
#endif #endif
} }
void Manager::on_createAbnormalImgUi(unsigned int ThreadId, HGImage image) void Manager::on_createAbnormalImgUi(void *hEvent, HGImage image)
{ {
Dialog_abnormal_img_select dlg(image, m_progressUi); Dialog_abnormal_img_select dlg(image, m_progressUi);
dlg.exec(); dlg.exec();
m_abnormalImgResult = dlg.getUserSelect(); m_abnormalImgResult = dlg.getUserSelect();
#ifdef HG_CMP_MSC #ifdef HG_CMP_MSC
if (0 != ThreadId) if (nullptr != hEvent)
{ {
::PostThreadMessage(ThreadId, WM_QUIT, 0, 0); SetEvent((HANDLE)hEvent);
} }
#endif #endif
} }
void Manager::on_deleteSettingUi(unsigned int ThreadId) void Manager::on_deleteSettingUi(void *hEvent)
{ {
if (m_settingUi != nullptr) if (m_settingUi != nullptr)
{ {
@ -566,7 +574,7 @@ void Manager::on_deleteSettingUi(unsigned int ThreadId)
} }
} }
void Manager::on_deleteProgressUi(unsigned int ThreadId) void Manager::on_deleteProgressUi(void *hEvent)
{ {
if (m_progressUi != nullptr) if (m_progressUi != nullptr)
{ {
@ -576,7 +584,7 @@ void Manager::on_deleteProgressUi(unsigned int ThreadId)
} }
} }
void Manager::on_deleteMessageBoxUi(unsigned int ThreadId) void Manager::on_deleteMessageBoxUi(void *hEvent)
{ {
} }

View File

@ -32,33 +32,36 @@ public:
void clear_functions(void); void clear_functions(void);
private:
void msgLoop(void *hEvent);
signals: signals:
void init(); void init();
void createDeviceSelect(unsigned int ThreadId); void createDeviceSelect(void *hEvent);
void createSettingUi(unsigned int ThreadId); void createSettingUi(void *hEvent);
void createProgressUi(void *hEvent); void createProgressUi(void *hEvent);
void createMessageBoxUi(unsigned int ThreadId); void createMessageBoxUi(void *hEvent);
void createTwainSrcUi(unsigned int ThreadId); void createTwainSrcUi(void *hEvent);
void createSaneSrcUi(unsigned int ThreadId); void createSaneSrcUi(void *hEvent);
void createAbnormalImgUi(unsigned int ThreadId, HGImage image); void createAbnormalImgUi(void *hEvent, HGImage image);
void deleteSettingUi(unsigned int ThreadId); void deleteSettingUi(void *hEvent);
void deleteProgressUi(unsigned int ThreadId); void deleteProgressUi(void *hEvent);
void deleteMessageBoxUi(unsigned int ThreadId); void deleteMessageBoxUi(void *hEvent);
private slots: private slots:
void on_init(); void on_init();
void on_createDeviceSelect(unsigned int ThreadId); void on_createDeviceSelect(void *hEvent);
void on_createSettingUi(unsigned int ThreadId); void on_createSettingUi(void *hEvent);
void on_createProgressUi(void *hEvent); void on_createProgressUi(void *hEvent);
void on_createMessageBoxUi(unsigned int ThreadId); void on_createMessageBoxUi(void *hEvent);
void on_createTwainSrcUi(unsigned int ThreadId); void on_createTwainSrcUi(void *hEvent);
void on_createSaneSrcUi(unsigned int ThreadId); void on_createSaneSrcUi(void *hEvent);
void on_createAbnormalImgUi(unsigned int ThreadId, HGImage image); void on_createAbnormalImgUi(void *hEvent, HGImage image);
void on_deleteSettingUi(unsigned int ThreadId); void on_deleteSettingUi(void *hEvent);
void on_deleteProgressUi(unsigned int ThreadId); void on_deleteProgressUi(void *hEvent);
void on_deleteMessageBoxUi(unsigned int ThreadId); void on_deleteMessageBoxUi(void *hEvent);
public: public:
QTranslator m_translator; QTranslator m_translator;