forked from openlp/openlp
head
This commit is contained in:
commit
87998687a8
@ -2,6 +2,7 @@
|
|||||||
*.*~
|
*.*~
|
||||||
\#*\#
|
\#*\#
|
||||||
*.eric4project
|
*.eric4project
|
||||||
|
*.eric5project
|
||||||
*.ropeproject
|
*.ropeproject
|
||||||
*.e4*
|
*.e4*
|
||||||
.eric4project
|
.eric4project
|
||||||
|
@ -1 +1 @@
|
|||||||
2.0.1
|
2.0.3
|
||||||
|
@ -129,9 +129,10 @@ sup {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function show_text(newtext){
|
function show_text(newtext){
|
||||||
|
var fade_direction = 0;
|
||||||
var match = /-webkit-text-fill-color:[^;\"]+/gi;
|
var match = /-webkit-text-fill-color:[^;\"]+/gi;
|
||||||
if(timer != null)
|
if (timer != null)
|
||||||
clearTimeout(timer);
|
clearInterval(timer);
|
||||||
/*
|
/*
|
||||||
QtWebkit bug with outlines and justify causing outline alignment
|
QtWebkit bug with outlines and justify causing outline alignment
|
||||||
problems. (Bug 859950) Surround each word with a <span> to workaround,
|
problems. (Bug 859950) Surround each word with a <span> to workaround,
|
||||||
@ -150,39 +151,45 @@ sup {
|
|||||||
newtext = '<span>' + newtext + '</span>';
|
newtext = '<span>' + newtext + '</span>';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
text_fade('lyricsmain', newtext);
|
text_fade('lyricsmain', newtext);
|
||||||
text_fade('lyricsoutline', newtext);
|
text_fade('lyricsoutline', newtext);
|
||||||
text_fade('lyricsshadow', newtext.replace(match, ''));
|
text_fade('lyricsshadow', newtext.replace(match, ''));
|
||||||
if(text_opacity() == 1) return;
|
if(text_opacity() == 1) return;
|
||||||
timer = setTimeout(function(){
|
timer = setInterval(function(){
|
||||||
show_text(newtext);
|
text_fade('lyricsmain', newtext);
|
||||||
|
text_fade('lyricsoutline', newtext);
|
||||||
|
text_fade('lyricsshadow', newtext.replace(match, ''));
|
||||||
|
if(text_opacity() == 1) clearInterval(timer);
|
||||||
}, 100);
|
}, 100);
|
||||||
}
|
|
||||||
|
|
||||||
function text_fade(id, newtext){
|
function text_fade(id, newtext){
|
||||||
/*
|
/*
|
||||||
Using -webkit-transition: opacity 1s linear; would have been preferred
|
Using -webkit-transition: opacity 1s linear; would have been preferred
|
||||||
but it isn't currently quick enough when animating multiple layers of
|
but it isn't currently quick enough when animating multiple layers of
|
||||||
large areas of large text. Therefore do it manually as best we can.
|
large areas of large text. Therefore do it manually as best we can.
|
||||||
Hopefully in the future we can revisit and do more interesting
|
Hopefully in the future we can revisit and do more interesting
|
||||||
transitions using -webkit-transition and -webkit-transform.
|
transitions using -webkit-transition and -webkit-transform.
|
||||||
However we need to ensure interrupted transitions (quickly change 2
|
However we need to ensure interrupted transitions (quickly change 2
|
||||||
slides) still looks pretty and is zippy.
|
slides) still looks pretty and is zippy.
|
||||||
*/
|
*/
|
||||||
var text = document.getElementById(id);
|
var text = document.getElementById(id);
|
||||||
if(text == null) return;
|
if(text == null) return;
|
||||||
if(!transition){
|
if(!transition){
|
||||||
text.innerHTML = newtext;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if(newtext == text.innerHTML){
|
|
||||||
text.style.opacity = parseFloat(text.style.opacity) + 0.3;
|
|
||||||
if(text.style.opacity > 0.7)
|
|
||||||
text.style.opacity = 1;
|
|
||||||
} else {
|
|
||||||
text.style.opacity = parseFloat(text.style.opacity) - 0.3;
|
|
||||||
if(text.style.opacity <= 0.1){
|
|
||||||
text.innerHTML = newtext;
|
text.innerHTML = newtext;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(fade_direction != 1){
|
||||||
|
text.style.opacity = parseFloat(text.style.opacity) - 0.3;
|
||||||
|
if(text.style.opacity <= 0.1){
|
||||||
|
text.innerHTML = newtext;
|
||||||
|
fade_direction = 1;
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
text.style.opacity = parseFloat(text.style.opacity) + 0.3;
|
||||||
|
if(text.style.opacity > 0.7){
|
||||||
|
text.style.opacity = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -317,7 +317,7 @@ class ServiceItem(object):
|
|||||||
self.add_icon(header[u'icon'])
|
self.add_icon(header[u'icon'])
|
||||||
self.raw_footer = header[u'footer']
|
self.raw_footer = header[u'footer']
|
||||||
self.audit = header[u'audit']
|
self.audit = header[u'audit']
|
||||||
self.notes = header[u'notes']
|
self.notes = unicode(header[u'notes'])
|
||||||
self.from_plugin = header[u'from_plugin']
|
self.from_plugin = header[u'from_plugin']
|
||||||
self.capabilities = header[u'capabilities']
|
self.capabilities = header[u'capabilities']
|
||||||
# Added later so may not be present in older services.
|
# Added later so may not be present in older services.
|
||||||
|
@ -175,8 +175,10 @@ class MainDisplay(Display):
|
|||||||
def setTransparency(self, enabled):
|
def setTransparency(self, enabled):
|
||||||
if enabled:
|
if enabled:
|
||||||
self.setAutoFillBackground(False)
|
self.setAutoFillBackground(False)
|
||||||
|
self.setStyleSheet("QGraphicsView {background: transparent; border: 0px;}")
|
||||||
else:
|
else:
|
||||||
self.setAttribute(QtCore.Qt.WA_NoSystemBackground, False)
|
self.setAttribute(QtCore.Qt.WA_NoSystemBackground, False)
|
||||||
|
self.setStyleSheet("QGraphicsView {}")
|
||||||
self.setAttribute(QtCore.Qt.WA_TranslucentBackground, enabled)
|
self.setAttribute(QtCore.Qt.WA_TranslucentBackground, enabled)
|
||||||
self.repaint()
|
self.repaint()
|
||||||
|
|
||||||
|
@ -423,10 +423,11 @@ class MediaController(object):
|
|||||||
controller.volumeSlider.blockSignals(False)
|
controller.volumeSlider.blockSignals(False)
|
||||||
return False
|
return False
|
||||||
if status:
|
if status:
|
||||||
display.frame.evaluateJavaScript(u'show_blank("desktop");')
|
if not controller.media_info.is_background:
|
||||||
|
display.frame.evaluateJavaScript(u'show_blank("desktop");')
|
||||||
self.curDisplayMediaPlayer[display].set_visible(display,
|
self.curDisplayMediaPlayer[display].set_visible(display,
|
||||||
True)
|
True)
|
||||||
if controller.isLive:
|
if controller.isLive and not controller.media_info.is_background:
|
||||||
if controller.hideMenu.defaultAction().isChecked():
|
if controller.hideMenu.defaultAction().isChecked():
|
||||||
controller.hideMenu.defaultAction().trigger()
|
controller.hideMenu.defaultAction().trigger()
|
||||||
# Start Timer for ui updates
|
# Start Timer for ui updates
|
||||||
|
@ -79,7 +79,7 @@ class ShortcutListForm(QtGui.QDialog, Ui_ShortcutListDialog):
|
|||||||
self.keyReleaseEvent(event)
|
self.keyReleaseEvent(event)
|
||||||
elif self.primaryPushButton.isChecked() or \
|
elif self.primaryPushButton.isChecked() or \
|
||||||
self.alternatePushButton.isChecked():
|
self.alternatePushButton.isChecked():
|
||||||
event.ignore()
|
self.keyReleaseEvent(event)
|
||||||
elif event.key() == QtCore.Qt.Key_Escape:
|
elif event.key() == QtCore.Qt.Key_Escape:
|
||||||
event.accept()
|
event.accept()
|
||||||
self.close()
|
self.close()
|
||||||
|
@ -293,7 +293,7 @@ class BiblesTab(SettingsTab):
|
|||||||
translate('BiblesPlugin.BiblesTab', 'English'))
|
translate('BiblesPlugin.BiblesTab', 'English'))
|
||||||
|
|
||||||
def onBibleThemeComboBoxChanged(self):
|
def onBibleThemeComboBoxChanged(self):
|
||||||
self.bible_theme = self.bibleThemeComboBox.currentText()
|
self.bible_theme = unicode(self.bibleThemeComboBox.currentText())
|
||||||
|
|
||||||
def onDisplayStyleComboBoxChanged(self):
|
def onDisplayStyleComboBoxChanged(self):
|
||||||
self.display_style = self.displayStyleComboBox.currentIndex()
|
self.display_style = self.displayStyleComboBox.currentIndex()
|
||||||
|
@ -153,7 +153,7 @@ class PresentationMediaItem(MediaManagerItem):
|
|||||||
if self.controllers[item].enabled():
|
if self.controllers[item].enabled():
|
||||||
self.displayTypeComboBox.addItem(item)
|
self.displayTypeComboBox.addItem(item)
|
||||||
if self.displayTypeComboBox.count() > 1:
|
if self.displayTypeComboBox.count() > 1:
|
||||||
self.displayTypeComboBox.insertItem(0, self.Automatic)
|
self.displayTypeComboBox.insertItem(0, self.Automatic, userData=u'automatic')
|
||||||
self.displayTypeComboBox.setCurrentIndex(0)
|
self.displayTypeComboBox.setCurrentIndex(0)
|
||||||
if Settings().value(self.settingsSection + u'/override app',
|
if Settings().value(self.settingsSection + u'/override app',
|
||||||
QtCore.QVariant(QtCore.Qt.Unchecked)) == QtCore.Qt.Checked:
|
QtCore.QVariant(QtCore.Qt.Unchecked)) == QtCore.Qt.Checked:
|
||||||
@ -277,13 +277,13 @@ class PresentationMediaItem(MediaManagerItem):
|
|||||||
service_item.shortname = unicode(self.displayTypeComboBox.currentText())
|
service_item.shortname = unicode(self.displayTypeComboBox.currentText())
|
||||||
service_item.add_capability(ItemCapabilities.ProvidesOwnDisplay)
|
service_item.add_capability(ItemCapabilities.ProvidesOwnDisplay)
|
||||||
service_item.add_capability(ItemCapabilities.HasDetailedTitleDisplay)
|
service_item.add_capability(ItemCapabilities.HasDetailedTitleDisplay)
|
||||||
shortname = service_item.shortname
|
if not service_item.shortname:
|
||||||
if not shortname:
|
|
||||||
return False
|
return False
|
||||||
for bitem in items:
|
for bitem in items:
|
||||||
filename = unicode(bitem.data(QtCore.Qt.UserRole).toString())
|
filename = unicode(bitem.data(QtCore.Qt.UserRole).toString())
|
||||||
if os.path.exists(filename):
|
if os.path.exists(filename):
|
||||||
if shortname == self.Automatic:
|
if self.displayTypeComboBox.itemData(
|
||||||
|
self.displayTypeComboBox.currentIndex()) == u'automatic':
|
||||||
service_item.shortname = self.findControllerByType(filename)
|
service_item.shortname = self.findControllerByType(filename)
|
||||||
if not service_item.shortname:
|
if not service_item.shortname:
|
||||||
return False
|
return False
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
import os
|
import os
|
||||||
import logging
|
import logging
|
||||||
|
import sys
|
||||||
|
|
||||||
if os.name == u'nt':
|
if os.name == u'nt':
|
||||||
from ctypes import cdll
|
from ctypes import cdll
|
||||||
@ -125,11 +126,16 @@ class PptviewDocument(PresentationDocument):
|
|||||||
renderer = self.controller.plugin.renderer
|
renderer = self.controller.plugin.renderer
|
||||||
rect = renderer.screens.current[u'size']
|
rect = renderer.screens.current[u'size']
|
||||||
rect = RECT(rect.x(), rect.y(), rect.right(), rect.bottom())
|
rect = RECT(rect.x(), rect.y(), rect.right(), rect.bottom())
|
||||||
filepath = str(self.filepath.replace(u'/', u'\\'))
|
file_system_encoding = 'utf-16-le'
|
||||||
|
file_path = os.path.normpath(self.filepath)
|
||||||
|
preview_path = os.path.join(self.get_temp_folder(), u'slide')
|
||||||
|
# Ensure that the paths are null terminated
|
||||||
|
file_path = file_path.encode(file_system_encoding) + '\0'
|
||||||
|
preview_path = preview_path.encode(file_system_encoding) + '\0'
|
||||||
if not os.path.isdir(self.get_temp_folder()):
|
if not os.path.isdir(self.get_temp_folder()):
|
||||||
os.makedirs(self.get_temp_folder())
|
os.makedirs(self.get_temp_folder())
|
||||||
self.pptid = self.controller.process.OpenPPT(filepath, None, rect,
|
self.pptid = self.controller.process.OpenPPT(file_path, None, rect,
|
||||||
str(self.get_temp_folder()) + '\\slide')
|
preview_path)
|
||||||
if self.pptid >= 0:
|
if self.pptid >= 0:
|
||||||
self.create_thumbnails()
|
self.create_thumbnails()
|
||||||
self.stop_presentation()
|
self.stop_presentation()
|
||||||
|
@ -27,7 +27,9 @@
|
|||||||
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from PyQt4 import QtGui, QtCore
|
from PyQt4 import QtGui, QtCore
|
||||||
from ctypes import *
|
from ctypes import *
|
||||||
from ctypes.wintypes import RECT
|
from ctypes.wintypes import RECT
|
||||||
@ -172,9 +174,8 @@ class PPTViewer(QtGui.QWidget):
|
|||||||
oldid = self.pptid;
|
oldid = self.pptid;
|
||||||
rect = RECT(int(self.xEdit.text()), int(self.yEdit.text()),
|
rect = RECT(int(self.xEdit.text()), int(self.yEdit.text()),
|
||||||
int(self.widthEdit.text()), int(self.heightEdit.text()))
|
int(self.widthEdit.text()), int(self.heightEdit.text()))
|
||||||
filename = str(self.pptEdit.text().replace(u'/', u'\\'))
|
filename = os.path.normpath(unicode(self.pptEdit.text())).encode('utf-16-le') + '\0'
|
||||||
folder = str(self.folderEdit.text().replace(u'/', u'\\'))
|
folder = os.path.normpath(unicode(self.folderEdit.text())).encode('utf-16-le') + '\0'
|
||||||
print filename, folder
|
|
||||||
self.pptid = self.pptdll.OpenPPT(filename, None, rect, folder)
|
self.pptid = self.pptdll.OpenPPT(filename, None, rect, folder)
|
||||||
print u'id: ' + unicode(self.pptid)
|
print u'id: ' + unicode(self.pptid)
|
||||||
if oldid >= 0:
|
if oldid >= 0:
|
||||||
|
@ -61,18 +61,18 @@ BOOL APIENTRY DllMain(HMODULE hModule, DWORD ulReasonForCall,
|
|||||||
switch(ulReasonForCall)
|
switch(ulReasonForCall)
|
||||||
{
|
{
|
||||||
case DLL_PROCESS_ATTACH:
|
case DLL_PROCESS_ATTACH:
|
||||||
DEBUG("PROCESS_ATTACH\n");
|
DEBUG(L"PROCESS_ATTACH\n");
|
||||||
break;
|
break;
|
||||||
case DLL_THREAD_ATTACH:
|
case DLL_THREAD_ATTACH:
|
||||||
//DEBUG("THREAD_ATTACH\n");
|
//DEBUG(L"THREAD_ATTACH\n");
|
||||||
break;
|
break;
|
||||||
case DLL_THREAD_DETACH:
|
case DLL_THREAD_DETACH:
|
||||||
//DEBUG("THREAD_DETACH\n");
|
//DEBUG(L"THREAD_DETACH\n");
|
||||||
break;
|
break;
|
||||||
case DLL_PROCESS_DETACH:
|
case DLL_PROCESS_DETACH:
|
||||||
// Clean up... hopefully there is only the one process attached?
|
// Clean up... hopefully there is only the one process attached?
|
||||||
// We'll find out soon enough during tests!
|
// We'll find out soon enough during tests!
|
||||||
DEBUG("PROCESS_DETACH\n");
|
DEBUG(L"PROCESS_DETACH\n");
|
||||||
for (int i = 0; i < MAX_PPTS; i++)
|
for (int i = 0; i < MAX_PPTS; i++)
|
||||||
ClosePPT(i);
|
ClosePPT(i);
|
||||||
break;
|
break;
|
||||||
@ -84,18 +84,18 @@ DllExport void SetDebug(BOOL onOff)
|
|||||||
{
|
{
|
||||||
printf("SetDebug\n");
|
printf("SetDebug\n");
|
||||||
debug = onOff;
|
debug = onOff;
|
||||||
DEBUG("enabled\n");
|
DEBUG(L"enabled\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
DllExport BOOL CheckInstalled()
|
DllExport BOOL CheckInstalled()
|
||||||
{
|
{
|
||||||
char cmdLine[MAX_PATH * 2];
|
wchar_t cmdLine[MAX_PATH * 2];
|
||||||
|
|
||||||
DEBUG("CheckInstalled\n");
|
DEBUG(L"CheckInstalled\n");
|
||||||
BOOL found = GetPPTViewerPath(cmdLine, sizeof(cmdLine));
|
BOOL found = GetPPTViewerPath(cmdLine, sizeof(cmdLine));
|
||||||
if(found)
|
if(found)
|
||||||
{
|
{
|
||||||
DEBUG("Exe: %s\n", cmdLine);
|
DEBUG(L"Exe: %s\n", cmdLine);
|
||||||
}
|
}
|
||||||
return found;
|
return found;
|
||||||
}
|
}
|
||||||
@ -106,20 +106,20 @@ DllExport BOOL CheckInstalled()
|
|||||||
// "<n>.bmp" will be appended to complete the path. E.g. "c:\temp\slide" would
|
// "<n>.bmp" will be appended to complete the path. E.g. "c:\temp\slide" would
|
||||||
// create "c:\temp\slide1.bmp" slide2.bmp, slide3.bmp etc.
|
// create "c:\temp\slide1.bmp" slide2.bmp, slide3.bmp etc.
|
||||||
// It will also create a *info.txt containing information about the ppt
|
// It will also create a *info.txt containing information about the ppt
|
||||||
DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
DllExport int OpenPPT(wchar_t *filename, HWND hParentWnd, RECT rect,
|
||||||
char *previewPath)
|
wchar_t *previewPath)
|
||||||
{
|
{
|
||||||
STARTUPINFO si;
|
STARTUPINFO si;
|
||||||
PROCESS_INFORMATION pi;
|
PROCESS_INFORMATION pi;
|
||||||
char cmdLine[MAX_PATH * 2];
|
wchar_t cmdLine[MAX_PATH * 2];
|
||||||
int id;
|
int id;
|
||||||
|
|
||||||
DEBUG("OpenPPT start: %s; %s\n", filename, previewPath);
|
DEBUG(L"OpenPPT start: %s; %s\n", filename, previewPath);
|
||||||
DEBUG("OpenPPT start: %u; %i, %i, %i, %i\n", hParentWnd, rect.top,
|
DEBUG(L"OpenPPT start: %u; %i, %i, %i, %i\n", hParentWnd, rect.top,
|
||||||
rect.left, rect.bottom, rect.right);
|
rect.left, rect.bottom, rect.right);
|
||||||
if (GetPPTViewerPath(cmdLine, sizeof(cmdLine)) == FALSE)
|
if (GetPPTViewerPath(cmdLine, sizeof(cmdLine)) == FALSE)
|
||||||
{
|
{
|
||||||
DEBUG("OpenPPT: GetPPTViewerPath failed\n");
|
DEBUG(L"OpenPPT: GetPPTViewerPath failed\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
id = -1;
|
id = -1;
|
||||||
@ -133,12 +133,12 @@ DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
|||||||
}
|
}
|
||||||
if (id < 0)
|
if (id < 0)
|
||||||
{
|
{
|
||||||
DEBUG("OpenPPT: Too many PPTs\n");
|
DEBUG(L"OpenPPT: Too many PPTs\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
memset(&pptView[id], 0, sizeof(PPTVIEW));
|
memset(&pptView[id], 0, sizeof(PPTVIEW));
|
||||||
strcpy_s(pptView[id].filename, MAX_PATH, filename);
|
wcscpy_s(pptView[id].filename, MAX_PATH, filename);
|
||||||
strcpy_s(pptView[id].previewPath, MAX_PATH, previewPath);
|
wcscpy_s(pptView[id].previewPath, MAX_PATH, previewPath);
|
||||||
pptView[id].state = PPT_CLOSED;
|
pptView[id].state = PPT_CLOSED;
|
||||||
pptView[id].slideCount = 0;
|
pptView[id].slideCount = 0;
|
||||||
pptView[id].currentSlide = 0;
|
pptView[id].currentSlide = 0;
|
||||||
@ -169,9 +169,9 @@ DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
|||||||
pptView[id].rect.bottom = rect.bottom;
|
pptView[id].rect.bottom = rect.bottom;
|
||||||
pptView[id].rect.right = rect.right;
|
pptView[id].rect.right = rect.right;
|
||||||
}
|
}
|
||||||
strcat_s(cmdLine, MAX_PATH * 2, " /F /S \"");
|
wcscat_s(cmdLine, MAX_PATH * 2, L" /F /S \"");
|
||||||
strcat_s(cmdLine, MAX_PATH * 2, filename);
|
wcscat_s(cmdLine, MAX_PATH * 2, filename);
|
||||||
strcat_s(cmdLine, MAX_PATH * 2, "\"");
|
wcscat_s(cmdLine, MAX_PATH * 2, L"\"");
|
||||||
memset(&si, 0, sizeof(si));
|
memset(&si, 0, sizeof(si));
|
||||||
memset(&pi, 0, sizeof(pi));
|
memset(&pi, 0, sizeof(pi));
|
||||||
BOOL gotInfo = GetPPTInfo(id);
|
BOOL gotInfo = GetPPTInfo(id);
|
||||||
@ -190,7 +190,7 @@ DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
|||||||
globalHook = SetWindowsHookEx(WH_CBT, CbtProc, hInstance, NULL);
|
globalHook = SetWindowsHookEx(WH_CBT, CbtProc, hInstance, NULL);
|
||||||
if (globalHook == 0)
|
if (globalHook == 0)
|
||||||
{
|
{
|
||||||
DEBUG("OpenPPT: SetWindowsHookEx failed\n");
|
DEBUG(L"OpenPPT: SetWindowsHookEx failed\n");
|
||||||
ClosePPT(id);
|
ClosePPT(id);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -198,7 +198,7 @@ DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
|||||||
Sleep(10);
|
Sleep(10);
|
||||||
if (!CreateProcess(NULL, cmdLine, NULL, NULL, FALSE, 0, 0, NULL, &si, &pi))
|
if (!CreateProcess(NULL, cmdLine, NULL, NULL, FALSE, 0, 0, NULL, &si, &pi))
|
||||||
{
|
{
|
||||||
DEBUG("OpenPPT: CreateProcess failed: %s\n", cmdLine);
|
DEBUG(L"OpenPPT: CreateProcess failed: %s\n", cmdLine);
|
||||||
ClosePPT(id);
|
ClosePPT(id);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -210,13 +210,13 @@ DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
|||||||
Sleep(10);
|
Sleep(10);
|
||||||
if (gotInfo)
|
if (gotInfo)
|
||||||
{
|
{
|
||||||
DEBUG("OpenPPT: Info loaded, no refresh\n");
|
DEBUG(L"OpenPPT: Info loaded, no refresh\n");
|
||||||
pptView[id].state = PPT_LOADED;
|
pptView[id].state = PPT_LOADED;
|
||||||
Resume(id);
|
Resume(id);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
DEBUG("OpenPPT: Get info\n");
|
DEBUG(L"OpenPPT: Get info\n");
|
||||||
pptView[id].steps = 0;
|
pptView[id].steps = 0;
|
||||||
int steps = 0;
|
int steps = 0;
|
||||||
while (pptView[id].state == PPT_OPENED)
|
while (pptView[id].state == PPT_OPENED)
|
||||||
@ -224,18 +224,18 @@ DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
|||||||
if (steps <= pptView[id].steps)
|
if (steps <= pptView[id].steps)
|
||||||
{
|
{
|
||||||
Sleep(20);
|
Sleep(20);
|
||||||
DEBUG("OpenPPT: Step %d/%d\n", steps, pptView[id].steps);
|
DEBUG(L"OpenPPT: Step %d/%d\n", steps, pptView[id].steps);
|
||||||
steps++;
|
steps++;
|
||||||
NextStep(id);
|
NextStep(id);
|
||||||
}
|
}
|
||||||
Sleep(10);
|
Sleep(10);
|
||||||
}
|
}
|
||||||
DEBUG("OpenPPT: Slides %d, Steps %d, first slide steps %d\n",
|
DEBUG(L"OpenPPT: Slides %d, Steps %d, first slide steps %d\n",
|
||||||
pptView[id].slideCount, pptView[id].steps,
|
pptView[id].slideCount, pptView[id].steps,
|
||||||
pptView[id].firstSlideSteps);
|
pptView[id].firstSlideSteps);
|
||||||
for(int i = 1; i <= pptView[id].slideCount; i++)
|
for(int i = 1; i <= pptView[id].slideCount; i++)
|
||||||
{
|
{
|
||||||
DEBUG("OpenPPT: Slide %d = %d\n", i, pptView[id].slideNos[i]);
|
DEBUG(L"OpenPPT: Slide %d = %d\n", i, pptView[id].slideNos[i]);
|
||||||
}
|
}
|
||||||
SavePPTInfo(id);
|
SavePPTInfo(id);
|
||||||
if (pptView[id].state == PPT_CLOSING
|
if (pptView[id].state == PPT_CLOSING
|
||||||
@ -257,7 +257,7 @@ DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
|||||||
}
|
}
|
||||||
pptView[id].msgHook = NULL;
|
pptView[id].msgHook = NULL;
|
||||||
}
|
}
|
||||||
DEBUG("OpenPPT: Exit: id=%i\n", id);
|
DEBUG(L"OpenPPT: Exit: id=%i\n", id);
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
// Load information about the ppt from an info.txt file.
|
// Load information about the ppt from an info.txt file.
|
||||||
@ -270,75 +270,75 @@ DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
|||||||
BOOL GetPPTInfo(int id)
|
BOOL GetPPTInfo(int id)
|
||||||
{
|
{
|
||||||
struct _stat fileStats;
|
struct _stat fileStats;
|
||||||
char info[MAX_PATH];
|
wchar_t info[MAX_PATH];
|
||||||
FILE* pFile;
|
FILE* pFile;
|
||||||
char buf[100];
|
wchar_t buf[100];
|
||||||
|
|
||||||
DEBUG("GetPPTInfo: start\n");
|
DEBUG(L"GetPPTInfo: start\n");
|
||||||
if (_stat(pptView[id].filename, &fileStats) != 0)
|
if (_wstat(pptView[id].filename, &fileStats) != 0)
|
||||||
{
|
{
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
sprintf_s(info, MAX_PATH, "%sinfo.txt", pptView[id].previewPath);
|
swprintf_s(info, MAX_PATH, L"%sinfo.txt", pptView[id].previewPath);
|
||||||
int err = fopen_s(&pFile, info, "r");
|
int err = _wfopen_s(&pFile, info, L"r");
|
||||||
if (err != 0)
|
if (err != 0)
|
||||||
{
|
{
|
||||||
DEBUG("GetPPTInfo: file open failed - %d\n", err);
|
DEBUG(L"GetPPTInfo: file open failed - %d\n", err);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
fgets(buf, 100, pFile); // version == 1
|
fgetws(buf, 100, pFile); // version == 1
|
||||||
fgets(buf, 100, pFile);
|
fgetws(buf, 100, pFile);
|
||||||
if (fileStats.st_mtime != atoi(buf))
|
if (fileStats.st_mtime != _wtoi(buf))
|
||||||
{
|
{
|
||||||
DEBUG("GetPPTInfo: date changed\n");
|
DEBUG(L"GetPPTInfo: date changed\n");
|
||||||
fclose (pFile);
|
fclose (pFile);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
fgets(buf, 100, pFile);
|
fgetws(buf, 100, pFile);
|
||||||
if (fileStats.st_size != atoi(buf))
|
if (fileStats.st_size != _wtoi(buf))
|
||||||
{
|
{
|
||||||
DEBUG("GetPPTInfo: size changed\n");
|
DEBUG(L"GetPPTInfo: size changed\n");
|
||||||
fclose (pFile);
|
fclose (pFile);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
fgets(buf, 100, pFile); // slidecount
|
fgetws(buf, 100, pFile); // slidecount
|
||||||
int slideCount = atoi(buf);
|
int slideCount = _wtoi(buf);
|
||||||
fgets(buf, 100, pFile); // first slide steps
|
fgetws(buf, 100, pFile); // first slide steps
|
||||||
int firstSlideSteps = atoi(buf);
|
int firstSlideSteps = _wtoi(buf);
|
||||||
// check all the preview images still exist
|
// check all the preview images still exist
|
||||||
for (int i = 1; i <= slideCount; i++)
|
for (int i = 1; i <= slideCount; i++)
|
||||||
{
|
{
|
||||||
sprintf_s(info, MAX_PATH, "%s%i.bmp", pptView[id].previewPath, i);
|
swprintf_s(info, MAX_PATH, L"%s%i.bmp", pptView[id].previewPath, i);
|
||||||
if (GetFileAttributes(info) == INVALID_FILE_ATTRIBUTES)
|
if (GetFileAttributes(info) == INVALID_FILE_ATTRIBUTES)
|
||||||
{
|
{
|
||||||
DEBUG("GetPPTInfo: bmp not found\n");
|
DEBUG(L"GetPPTInfo: bmp not found\n");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fclose(pFile);
|
fclose(pFile);
|
||||||
pptView[id].slideCount = slideCount;
|
pptView[id].slideCount = slideCount;
|
||||||
pptView[id].firstSlideSteps = firstSlideSteps;
|
pptView[id].firstSlideSteps = firstSlideSteps;
|
||||||
DEBUG("GetPPTInfo: exit ok\n");
|
DEBUG(L"GetPPTInfo: exit ok\n");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL SavePPTInfo(int id)
|
BOOL SavePPTInfo(int id)
|
||||||
{
|
{
|
||||||
struct _stat fileStats;
|
struct _stat fileStats;
|
||||||
char info[MAX_PATH];
|
wchar_t info[MAX_PATH];
|
||||||
FILE* pFile;
|
FILE* pFile;
|
||||||
|
|
||||||
DEBUG("SavePPTInfo: start\n");
|
DEBUG(L"SavePPTInfo: start\n");
|
||||||
if (_stat(pptView[id].filename, &fileStats) != 0)
|
if (_wstat(pptView[id].filename, &fileStats) != 0)
|
||||||
{
|
{
|
||||||
DEBUG("SavePPTInfo: stat of %s failed\n", pptView[id].filename);
|
DEBUG(L"SavePPTInfo: stat of %s failed\n", pptView[id].filename);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
sprintf_s(info, MAX_PATH, "%sinfo.txt", pptView[id].previewPath);
|
swprintf_s(info, MAX_PATH, L"%sinfo.txt", pptView[id].previewPath);
|
||||||
int err = fopen_s(&pFile, info, "w");
|
int err = _wfopen_s(&pFile, info, L"w");
|
||||||
if (err != 0)
|
if (err != 0)
|
||||||
{
|
{
|
||||||
DEBUG("SavePPTInfo: fopen of %s failed%i\n", info, err);
|
DEBUG(L"SavePPTInfo: fopen of %s failed%i\n", info, err);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
fprintf(pFile, "1\n");
|
fprintf(pFile, "1\n");
|
||||||
@ -347,21 +347,21 @@ BOOL SavePPTInfo(int id)
|
|||||||
fprintf(pFile, "%u\n", pptView[id].slideCount);
|
fprintf(pFile, "%u\n", pptView[id].slideCount);
|
||||||
fprintf(pFile, "%u\n", pptView[id].firstSlideSteps);
|
fprintf(pFile, "%u\n", pptView[id].firstSlideSteps);
|
||||||
fclose(pFile);
|
fclose(pFile);
|
||||||
DEBUG("SavePPTInfo: exit ok\n");
|
DEBUG(L"SavePPTInfo: exit ok\n");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the path of the PowerPoint viewer from the registry
|
// Get the path of the PowerPoint viewer from the registry
|
||||||
BOOL GetPPTViewerPath(char *pptViewerPath, int stringSize)
|
BOOL GetPPTViewerPath(wchar_t *pptViewerPath, int stringSize)
|
||||||
{
|
{
|
||||||
char cwd[MAX_PATH];
|
wchar_t cwd[MAX_PATH];
|
||||||
|
|
||||||
DEBUG("GetPPTViewerPath: start\n");
|
DEBUG(L"GetPPTViewerPath: start\n");
|
||||||
if(GetPPTViewerPathFromReg(pptViewerPath, stringSize))
|
if(GetPPTViewerPathFromReg(pptViewerPath, stringSize))
|
||||||
{
|
{
|
||||||
if(_access(pptViewerPath, 0) != -1)
|
if(_waccess(pptViewerPath, 0) != -1)
|
||||||
{
|
{
|
||||||
DEBUG("GetPPTViewerPath: exit registry\n");
|
DEBUG(L"GetPPTViewerPath: exit registry\n");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -370,37 +370,37 @@ BOOL GetPPTViewerPath(char *pptViewerPath, int stringSize)
|
|||||||
// upset those who like to put things somewhere else
|
// upset those who like to put things somewhere else
|
||||||
|
|
||||||
// Viewer 2007 in 64bit Windows:
|
// Viewer 2007 in 64bit Windows:
|
||||||
if(_access("C:\\Program Files (x86)\\Microsoft Office\\Office12\\PPTVIEW.EXE",
|
if(_waccess(L"C:\\Program Files (x86)\\Microsoft Office\\Office12\\PPTVIEW.EXE",
|
||||||
0) != -1)
|
0) != -1)
|
||||||
{
|
{
|
||||||
strcpy_s(
|
wcscpy_s(
|
||||||
"C:\\Program Files (x86)\\Microsoft Office\\Office12\\PPTVIEW.EXE",
|
L"C:\\Program Files (x86)\\Microsoft Office\\Office12\\PPTVIEW.EXE",
|
||||||
stringSize, pptViewerPath);
|
stringSize, pptViewerPath);
|
||||||
DEBUG("GetPPTViewerPath: exit 64bit 2007\n");
|
DEBUG(L"GetPPTViewerPath: exit 64bit 2007\n");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
// Viewer 2007 in 32bit Windows:
|
// Viewer 2007 in 32bit Windows:
|
||||||
if(_access("C:\\Program Files\\Microsoft Office\\Office12\\PPTVIEW.EXE", 0)
|
if(_waccess(L"C:\\Program Files\\Microsoft Office\\Office12\\PPTVIEW.EXE", 0)
|
||||||
!= -1)
|
!= -1)
|
||||||
{
|
{
|
||||||
strcpy_s("C:\\Program Files\\Microsoft Office\\Office12\\PPTVIEW.EXE",
|
wcscpy_s(L"C:\\Program Files\\Microsoft Office\\Office12\\PPTVIEW.EXE",
|
||||||
stringSize, pptViewerPath);
|
stringSize, pptViewerPath);
|
||||||
DEBUG("GetPPTViewerPath: exit 32bit 2007\n");
|
DEBUG(L"GetPPTViewerPath: exit 32bit 2007\n");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
// Give them the opportunity to place it in the same folder as the app
|
// Give them the opportunity to place it in the same folder as the app
|
||||||
_getcwd(cwd, MAX_PATH);
|
_wgetcwd(cwd, MAX_PATH);
|
||||||
strcat_s(cwd, MAX_PATH, "\\PPTVIEW.EXE");
|
wcscat_s(cwd, MAX_PATH, L"\\PPTVIEW.EXE");
|
||||||
if(_access(cwd, 0) != -1)
|
if(_waccess(cwd, 0) != -1)
|
||||||
{
|
{
|
||||||
strcpy_s(pptViewerPath, stringSize, cwd);
|
wcscpy_s(pptViewerPath, stringSize, cwd);
|
||||||
DEBUG("GetPPTViewerPath: exit local\n");
|
DEBUG(L"GetPPTViewerPath: exit local\n");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
DEBUG("GetPPTViewerPath: exit fail\n");
|
DEBUG(L"GetPPTViewerPath: exit fail\n");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
BOOL GetPPTViewerPathFromReg(char *pptViewerPath, int stringSize)
|
BOOL GetPPTViewerPathFromReg(wchar_t *pptViewerPath, int stringSize)
|
||||||
{
|
{
|
||||||
HKEY hKey;
|
HKEY hKey;
|
||||||
DWORD dwType, dwSize;
|
DWORD dwType, dwSize;
|
||||||
@ -411,17 +411,17 @@ BOOL GetPPTViewerPathFromReg(char *pptViewerPath, int stringSize)
|
|||||||
// PPT Viewer 2003 (recent versions)
|
// PPT Viewer 2003 (recent versions)
|
||||||
// PPT Viewer 2003 (older versions)
|
// PPT Viewer 2003 (older versions)
|
||||||
// PPT Viewer 97
|
// PPT Viewer 97
|
||||||
if ((RegOpenKeyEx(HKEY_CLASSES_ROOT,
|
if ((RegOpenKeyExW(HKEY_CLASSES_ROOT,
|
||||||
"PowerPointViewer.Show.12\\shell\\Show\\command", 0, KEY_READ, &hKey)
|
L"PowerPointViewer.Show.12\\shell\\Show\\command", 0, KEY_READ, &hKey)
|
||||||
!= ERROR_SUCCESS)
|
!= ERROR_SUCCESS)
|
||||||
&& (RegOpenKeyEx(HKEY_CLASSES_ROOT,
|
&& (RegOpenKeyExW(HKEY_CLASSES_ROOT,
|
||||||
"PowerPointViewer.Show.11\\shell\\Show\\command", 0, KEY_READ, &hKey)
|
L"PowerPointViewer.Show.11\\shell\\Show\\command", 0, KEY_READ, &hKey)
|
||||||
!= ERROR_SUCCESS)
|
!= ERROR_SUCCESS)
|
||||||
&& (RegOpenKeyEx(HKEY_CLASSES_ROOT,
|
&& (RegOpenKeyExW(HKEY_CLASSES_ROOT,
|
||||||
"Applications\\PPTVIEW.EXE\\shell\\open\\command", 0, KEY_READ, &hKey)
|
L"Applications\\PPTVIEW.EXE\\shell\\open\\command", 0, KEY_READ, &hKey)
|
||||||
!= ERROR_SUCCESS)
|
!= ERROR_SUCCESS)
|
||||||
&& (RegOpenKeyEx(HKEY_CLASSES_ROOT,
|
&& (RegOpenKeyExW(HKEY_CLASSES_ROOT,
|
||||||
"Applications\\PPTVIEW.EXE\\shell\\Show\\command", 0, KEY_READ, &hKey)
|
L"Applications\\PPTVIEW.EXE\\shell\\Show\\command", 0, KEY_READ, &hKey)
|
||||||
!= ERROR_SUCCESS))
|
!= ERROR_SUCCESS))
|
||||||
{
|
{
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -436,14 +436,14 @@ BOOL GetPPTViewerPathFromReg(char *pptViewerPath, int stringSize)
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
// remove "%1" from end of key value
|
// remove "%1" from end of key value
|
||||||
pptViewerPath[strlen(pptViewerPath) - 4] = '\0';
|
pptViewerPath[wcslen(pptViewerPath) - 4] = '\0';
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unhook the Windows hook
|
// Unhook the Windows hook
|
||||||
void Unhook(int id)
|
void Unhook(int id)
|
||||||
{
|
{
|
||||||
DEBUG("Unhook: start %d\n", id);
|
DEBUG(L"Unhook: start %d\n", id);
|
||||||
if (pptView[id].hook != NULL)
|
if (pptView[id].hook != NULL)
|
||||||
{
|
{
|
||||||
UnhookWindowsHookEx(pptView[id].hook);
|
UnhookWindowsHookEx(pptView[id].hook);
|
||||||
@ -454,13 +454,13 @@ void Unhook(int id)
|
|||||||
}
|
}
|
||||||
pptView[id].hook = NULL;
|
pptView[id].hook = NULL;
|
||||||
pptView[id].msgHook = NULL;
|
pptView[id].msgHook = NULL;
|
||||||
DEBUG("Unhook: exit ok\n");
|
DEBUG(L"Unhook: exit ok\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Close the PowerPoint viewer, release resources
|
// Close the PowerPoint viewer, release resources
|
||||||
DllExport void ClosePPT(int id)
|
DllExport void ClosePPT(int id)
|
||||||
{
|
{
|
||||||
DEBUG("ClosePPT: start%d\n", id);
|
DEBUG(L"ClosePPT: start%d\n", id);
|
||||||
pptView[id].state = PPT_CLOSED;
|
pptView[id].state = PPT_CLOSED;
|
||||||
Unhook(id);
|
Unhook(id);
|
||||||
if (pptView[id].hWnd == 0)
|
if (pptView[id].hWnd == 0)
|
||||||
@ -474,13 +474,13 @@ DllExport void ClosePPT(int id)
|
|||||||
CloseHandle(pptView[id].hThread);
|
CloseHandle(pptView[id].hThread);
|
||||||
CloseHandle(pptView[id].hProcess);
|
CloseHandle(pptView[id].hProcess);
|
||||||
memset(&pptView[id], 0, sizeof(PPTVIEW));
|
memset(&pptView[id], 0, sizeof(PPTVIEW));
|
||||||
DEBUG("ClosePPT: exit ok\n");
|
DEBUG(L"ClosePPT: exit ok\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// Moves the show back onto the display
|
// Moves the show back onto the display
|
||||||
DllExport void Resume(int id)
|
DllExport void Resume(int id)
|
||||||
{
|
{
|
||||||
DEBUG("Resume: %d\n", id);
|
DEBUG(L"Resume: %d\n", id);
|
||||||
MoveWindow(pptView[id].hWnd, pptView[id].rect.left,
|
MoveWindow(pptView[id].hWnd, pptView[id].rect.left,
|
||||||
pptView[id].rect.top,
|
pptView[id].rect.top,
|
||||||
pptView[id].rect.right - pptView[id].rect.left,
|
pptView[id].rect.right - pptView[id].rect.left,
|
||||||
@ -490,7 +490,7 @@ DllExport void Resume(int id)
|
|||||||
// Moves the show off the screen so it can't be seen
|
// Moves the show off the screen so it can't be seen
|
||||||
DllExport void Stop(int id)
|
DllExport void Stop(int id)
|
||||||
{
|
{
|
||||||
DEBUG("Stop:%d\n", id);
|
DEBUG(L"Stop:%d\n", id);
|
||||||
MoveWindow(pptView[id].hWnd, -32000, -32000,
|
MoveWindow(pptView[id].hWnd, -32000, -32000,
|
||||||
pptView[id].rect.right - pptView[id].rect.left,
|
pptView[id].rect.right - pptView[id].rect.left,
|
||||||
pptView[id].rect.bottom - pptView[id].rect.top, TRUE);
|
pptView[id].rect.bottom - pptView[id].rect.top, TRUE);
|
||||||
@ -499,7 +499,7 @@ DllExport void Stop(int id)
|
|||||||
// Return the total number of slides
|
// Return the total number of slides
|
||||||
DllExport int GetSlideCount(int id)
|
DllExport int GetSlideCount(int id)
|
||||||
{
|
{
|
||||||
DEBUG("GetSlideCount:%d\n", id);
|
DEBUG(L"GetSlideCount:%d\n", id);
|
||||||
if (pptView[id].state == 0)
|
if (pptView[id].state == 0)
|
||||||
{
|
{
|
||||||
return -1;
|
return -1;
|
||||||
@ -513,7 +513,7 @@ DllExport int GetSlideCount(int id)
|
|||||||
// Return the number of the slide currently viewing
|
// Return the number of the slide currently viewing
|
||||||
DllExport int GetCurrentSlide(int id)
|
DllExport int GetCurrentSlide(int id)
|
||||||
{
|
{
|
||||||
DEBUG("GetCurrentSlide:%d\n", id);
|
DEBUG(L"GetCurrentSlide:%d\n", id);
|
||||||
if (pptView[id].state == 0)
|
if (pptView[id].state == 0)
|
||||||
{
|
{
|
||||||
return -1;
|
return -1;
|
||||||
@ -527,7 +527,7 @@ DllExport int GetCurrentSlide(int id)
|
|||||||
// Take a step forwards through the show
|
// Take a step forwards through the show
|
||||||
DllExport void NextStep(int id)
|
DllExport void NextStep(int id)
|
||||||
{
|
{
|
||||||
DEBUG("NextStep:%d (%d)\n", id, pptView[id].currentSlide);
|
DEBUG(L"NextStep:%d (%d)\n", id, pptView[id].currentSlide);
|
||||||
if (pptView[id].currentSlide > pptView[id].slideCount) return;
|
if (pptView[id].currentSlide > pptView[id].slideCount) return;
|
||||||
if (pptView[id].currentSlide < pptView[id].slideCount)
|
if (pptView[id].currentSlide < pptView[id].slideCount)
|
||||||
{
|
{
|
||||||
@ -540,7 +540,7 @@ DllExport void NextStep(int id)
|
|||||||
// Take a step backwards through the show
|
// Take a step backwards through the show
|
||||||
DllExport void PrevStep(int id)
|
DllExport void PrevStep(int id)
|
||||||
{
|
{
|
||||||
DEBUG("PrevStep:%d (%d)\n", id, pptView[id].currentSlide);
|
DEBUG(L"PrevStep:%d (%d)\n", id, pptView[id].currentSlide);
|
||||||
if (pptView[id].currentSlide > 1)
|
if (pptView[id].currentSlide > 1)
|
||||||
{
|
{
|
||||||
pptView[id].guess = pptView[id].currentSlide - 1;
|
pptView[id].guess = pptView[id].currentSlide - 1;
|
||||||
@ -556,7 +556,7 @@ DllExport void Blank(int id)
|
|||||||
// So send random unmapped letter first (say 'A'), then we can
|
// So send random unmapped letter first (say 'A'), then we can
|
||||||
// better guarantee B will blank instead of trying to guess
|
// better guarantee B will blank instead of trying to guess
|
||||||
// whether it was already blank or not.
|
// whether it was already blank or not.
|
||||||
DEBUG("Blank:%d\n", id);
|
DEBUG(L"Blank:%d\n", id);
|
||||||
HWND h1 = GetForegroundWindow();
|
HWND h1 = GetForegroundWindow();
|
||||||
HWND h2 = GetFocus();
|
HWND h2 = GetFocus();
|
||||||
SetForegroundWindow(pptView[id].hWnd);
|
SetForegroundWindow(pptView[id].hWnd);
|
||||||
@ -573,7 +573,7 @@ DllExport void Blank(int id)
|
|||||||
// Unblank the show
|
// Unblank the show
|
||||||
DllExport void Unblank(int id)
|
DllExport void Unblank(int id)
|
||||||
{
|
{
|
||||||
DEBUG("Unblank:%d\n", id);
|
DEBUG(L"Unblank:%d\n", id);
|
||||||
// Pressing any key resumes.
|
// Pressing any key resumes.
|
||||||
// For some reason SendMessage works for unblanking, but not blanking.
|
// For some reason SendMessage works for unblanking, but not blanking.
|
||||||
SendMessage(pptView[id].hWnd2, WM_CHAR, 'A', 0);
|
SendMessage(pptView[id].hWnd2, WM_CHAR, 'A', 0);
|
||||||
@ -582,7 +582,7 @@ DllExport void Unblank(int id)
|
|||||||
// Go directly to a slide
|
// Go directly to a slide
|
||||||
DllExport void GotoSlide(int id, int slideNo)
|
DllExport void GotoSlide(int id, int slideNo)
|
||||||
{
|
{
|
||||||
DEBUG("GotoSlide %i %i:\n", id, slideNo);
|
DEBUG(L"GotoSlide %i %i:\n", id, slideNo);
|
||||||
// Did try WM_KEYDOWN/WM_CHAR/WM_KEYUP with SendMessage but didn't work
|
// Did try WM_KEYDOWN/WM_CHAR/WM_KEYUP with SendMessage but didn't work
|
||||||
// perhaps I was sending to the wrong window? No idea.
|
// perhaps I was sending to the wrong window? No idea.
|
||||||
// Anyway fall back to keybd_event, which is OK as long we makesure
|
// Anyway fall back to keybd_event, which is OK as long we makesure
|
||||||
@ -619,7 +619,7 @@ DllExport void RestartShow(int id)
|
|||||||
// Only way I've found to get around this is to step backwards all the way
|
// Only way I've found to get around this is to step backwards all the way
|
||||||
// through. Lets move the window out of the way first so the audience
|
// through. Lets move the window out of the way first so the audience
|
||||||
// doesn't see this.
|
// doesn't see this.
|
||||||
DEBUG("RestartShow:%d\n", id);
|
DEBUG(L"RestartShow:%d\n", id);
|
||||||
Stop(id);
|
Stop(id);
|
||||||
GotoSlide(id, pptView[id].slideCount);
|
GotoSlide(id, pptView[id].slideCount);
|
||||||
for (int i=0; i <= pptView[id].steps - pptView[id].lastSlideSteps; i++)
|
for (int i=0; i <= pptView[id].steps - pptView[id].lastSlideSteps; i++)
|
||||||
@ -644,12 +644,12 @@ LRESULT CALLBACK CbtProc(int nCode, WPARAM wParam, LPARAM lParam)
|
|||||||
HHOOK hook = globalHook;
|
HHOOK hook = globalHook;
|
||||||
if (nCode == HCBT_CREATEWND)
|
if (nCode == HCBT_CREATEWND)
|
||||||
{
|
{
|
||||||
char csClassName[16];
|
wchar_t csClassName[32];
|
||||||
HWND hCurrWnd = (HWND)wParam;
|
HWND hCurrWnd = (HWND)wParam;
|
||||||
DWORD retProcId = NULL;
|
DWORD retProcId = NULL;
|
||||||
GetClassName(hCurrWnd, csClassName, sizeof(csClassName));
|
GetClassName(hCurrWnd, csClassName, sizeof(csClassName));
|
||||||
if ((strcmp(csClassName, "paneClassDC") == 0)
|
if ((wcscmp(csClassName, L"paneClassDC") == 0)
|
||||||
||(strcmp(csClassName, "screenClass") == 0))
|
||(wcscmp(csClassName, L"screenClass") == 0))
|
||||||
{
|
{
|
||||||
int id = -1;
|
int id = -1;
|
||||||
DWORD windowThread = GetWindowThreadProcessId(hCurrWnd, NULL);
|
DWORD windowThread = GetWindowThreadProcessId(hCurrWnd, NULL);
|
||||||
@ -663,7 +663,7 @@ LRESULT CALLBACK CbtProc(int nCode, WPARAM wParam, LPARAM lParam)
|
|||||||
}
|
}
|
||||||
if (id >= 0)
|
if (id >= 0)
|
||||||
{
|
{
|
||||||
if (strcmp(csClassName, "paneClassDC") == 0)
|
if (wcscmp(csClassName, L"paneClassDC") == 0)
|
||||||
{
|
{
|
||||||
pptView[id].hWnd2 = hCurrWnd;
|
pptView[id].hWnd2 = hCurrWnd;
|
||||||
}
|
}
|
||||||
@ -737,7 +737,7 @@ LRESULT CALLBACK CwpProc(int nCode, WPARAM wParam, LPARAM lParam){
|
|||||||
CWPSTRUCT *cwp;
|
CWPSTRUCT *cwp;
|
||||||
cwp = (CWPSTRUCT *)lParam;
|
cwp = (CWPSTRUCT *)lParam;
|
||||||
HHOOK hook = NULL;
|
HHOOK hook = NULL;
|
||||||
char filename[MAX_PATH];
|
wchar_t filename[MAX_PATH];
|
||||||
|
|
||||||
DWORD windowThread = GetWindowThreadProcessId(cwp->hwnd, NULL);
|
DWORD windowThread = GetWindowThreadProcessId(cwp->hwnd, NULL);
|
||||||
int id = -1;
|
int id = -1;
|
||||||
@ -758,9 +758,9 @@ LRESULT CALLBACK CwpProc(int nCode, WPARAM wParam, LPARAM lParam){
|
|||||||
{
|
{
|
||||||
if ((pptView[id].currentSlide > 0)
|
if ((pptView[id].currentSlide > 0)
|
||||||
&& (pptView[id].previewPath != NULL
|
&& (pptView[id].previewPath != NULL
|
||||||
&& strlen(pptView[id].previewPath) > 0))
|
&& wcslen(pptView[id].previewPath) > 0))
|
||||||
{
|
{
|
||||||
sprintf_s(filename, MAX_PATH, "%s%i.bmp",
|
swprintf_s(filename, MAX_PATH, L"%s%i.bmp",
|
||||||
pptView[id].previewPath,
|
pptView[id].previewPath,
|
||||||
pptView[id].currentSlide);
|
pptView[id].currentSlide);
|
||||||
CaptureAndSaveWindow(cwp->hwnd, filename);
|
CaptureAndSaveWindow(cwp->hwnd, filename);
|
||||||
@ -820,7 +820,7 @@ LRESULT CALLBACK CwpProc(int nCode, WPARAM wParam, LPARAM lParam){
|
|||||||
return CallNextHookEx(hook, nCode, wParam, lParam);
|
return CallNextHookEx(hook, nCode, wParam, lParam);
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID CaptureAndSaveWindow(HWND hWnd, CHAR* filename)
|
VOID CaptureAndSaveWindow(HWND hWnd, wchar_t* filename)
|
||||||
{
|
{
|
||||||
HBITMAP hBmp;
|
HBITMAP hBmp;
|
||||||
if ((hBmp = CaptureWindow(hWnd)) == NULL)
|
if ((hBmp = CaptureWindow(hWnd)) == NULL)
|
||||||
@ -863,7 +863,7 @@ VOID CaptureAndSaveWindow(HWND hWnd, CHAR* filename)
|
|||||||
|
|
||||||
// Writing:
|
// Writing:
|
||||||
FILE* pFile;
|
FILE* pFile;
|
||||||
int err = fopen_s(&pFile, filename, "wb");
|
int err = _wfopen_s(&pFile, filename, L"wb");
|
||||||
if (err == 0)
|
if (err == 0)
|
||||||
{
|
{
|
||||||
fwrite(&bmf, sizeof(bmf), 1, pFile);
|
fwrite(&bmf, sizeof(bmf), 1, pFile);
|
||||||
@ -893,7 +893,7 @@ HBITMAP CaptureWindow(HWND hWnd)
|
|||||||
if ((hMemDC = CreateCompatibleDC(hDC)) != NULL)
|
if ((hMemDC = CreateCompatibleDC(hDC)) != NULL)
|
||||||
{
|
{
|
||||||
hDCBmp = (HBITMAP)SelectObject(hMemDC, hImage);
|
hDCBmp = (HBITMAP)SelectObject(hMemDC, hImage);
|
||||||
HMODULE hLib = LoadLibrary("User32");
|
HMODULE hLib = LoadLibrary(L"User32");
|
||||||
// PrintWindow works for windows outside displayable area
|
// PrintWindow works for windows outside displayable area
|
||||||
// but was only introduced in WinXP. BitBlt requires the window to
|
// but was only introduced in WinXP. BitBlt requires the window to
|
||||||
// be topmost and within the viewable area of the display
|
// be topmost and within the viewable area of the display
|
||||||
|
@ -26,13 +26,13 @@
|
|||||||
|
|
||||||
#define DllExport extern "C" __declspec( dllexport )
|
#define DllExport extern "C" __declspec( dllexport )
|
||||||
|
|
||||||
#define DEBUG(...) if (debug) printf(__VA_ARGS__)
|
#define DEBUG(...) if (debug) wprintf(__VA_ARGS__)
|
||||||
|
|
||||||
enum PPTVIEWSTATE {PPT_CLOSED, PPT_STARTED, PPT_OPENED, PPT_LOADED,
|
enum PPTVIEWSTATE {PPT_CLOSED, PPT_STARTED, PPT_OPENED, PPT_LOADED,
|
||||||
PPT_CLOSING};
|
PPT_CLOSING};
|
||||||
|
|
||||||
DllExport int OpenPPT(char *filename, HWND hParentWnd, RECT rect,
|
DllExport int OpenPPT(wchar_t *filename, HWND hParentWnd, RECT rect,
|
||||||
char *previewPath);
|
wchar_t *previewPath);
|
||||||
DllExport BOOL CheckInstalled();
|
DllExport BOOL CheckInstalled();
|
||||||
DllExport void ClosePPT(int id);
|
DllExport void ClosePPT(int id);
|
||||||
DllExport int GetCurrentSlide(int id);
|
DllExport int GetCurrentSlide(int id);
|
||||||
@ -50,11 +50,11 @@ DllExport void SetDebug(BOOL onOff);
|
|||||||
LRESULT CALLBACK CbtProc(int nCode, WPARAM wParam, LPARAM lParam);
|
LRESULT CALLBACK CbtProc(int nCode, WPARAM wParam, LPARAM lParam);
|
||||||
LRESULT CALLBACK CwpProc(int nCode, WPARAM wParam, LPARAM lParam);
|
LRESULT CALLBACK CwpProc(int nCode, WPARAM wParam, LPARAM lParam);
|
||||||
LRESULT CALLBACK GetMsgProc(int nCode, WPARAM wParam, LPARAM lParam);
|
LRESULT CALLBACK GetMsgProc(int nCode, WPARAM wParam, LPARAM lParam);
|
||||||
BOOL GetPPTViewerPath(char *pptViewerPath, int stringSize);
|
BOOL GetPPTViewerPath(wchar_t *pptViewerPath, int stringSize);
|
||||||
BOOL GetPPTViewerPathFromReg(char *pptViewerPath, int stringSize);
|
BOOL GetPPTViewerPathFromReg(wchar_t *pptViewerPath, int stringSize);
|
||||||
HBITMAP CaptureWindow(HWND hWnd);
|
HBITMAP CaptureWindow(HWND hWnd);
|
||||||
VOID SaveBitmap(CHAR* filename, HBITMAP hBmp) ;
|
VOID SaveBitmap(wchar_t* filename, HBITMAP hBmp) ;
|
||||||
VOID CaptureAndSaveWindow(HWND hWnd, CHAR* filename);
|
VOID CaptureAndSaveWindow(HWND hWnd, wchar_t* filename);
|
||||||
BOOL GetPPTInfo(int id);
|
BOOL GetPPTInfo(int id);
|
||||||
BOOL SavePPTInfo(int id);
|
BOOL SavePPTInfo(int id);
|
||||||
void Unhook(int id);
|
void Unhook(int id);
|
||||||
@ -80,8 +80,8 @@ struct PPTVIEW
|
|||||||
int lastSlideSteps;
|
int lastSlideSteps;
|
||||||
int steps;
|
int steps;
|
||||||
int guess;
|
int guess;
|
||||||
char filename[MAX_PATH];
|
wchar_t filename[MAX_PATH];
|
||||||
char previewPath[MAX_PATH];
|
wchar_t previewPath[MAX_PATH];
|
||||||
int slideNos[MAX_SLIDES];
|
int slideNos[MAX_SLIDES];
|
||||||
PPTVIEWSTATE state;
|
PPTVIEWSTATE state;
|
||||||
};
|
};
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
||||||
IntermediateDirectory="$(ConfigurationName)"
|
IntermediateDirectory="$(ConfigurationName)"
|
||||||
ConfigurationType="2"
|
ConfigurationType="2"
|
||||||
CharacterSet="2"
|
CharacterSet="1"
|
||||||
>
|
>
|
||||||
<Tool
|
<Tool
|
||||||
Name="VCPreBuildEventTool"
|
Name="VCPreBuildEventTool"
|
||||||
@ -93,7 +93,7 @@
|
|||||||
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
OutputDirectory="$(SolutionDir)$(ConfigurationName)"
|
||||||
IntermediateDirectory="$(ConfigurationName)"
|
IntermediateDirectory="$(ConfigurationName)"
|
||||||
ConfigurationType="2"
|
ConfigurationType="2"
|
||||||
CharacterSet="2"
|
CharacterSet="1"
|
||||||
WholeProgramOptimization="1"
|
WholeProgramOptimization="1"
|
||||||
>
|
>
|
||||||
<Tool
|
<Tool
|
||||||
|
@ -132,6 +132,7 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog):
|
|||||||
self.audioListWidget.setAlternatingRowColors(True)
|
self.audioListWidget.setAlternatingRowColors(True)
|
||||||
self.findVerseSplit = re.compile(u'---\[\]---\n', re.UNICODE)
|
self.findVerseSplit = re.compile(u'---\[\]---\n', re.UNICODE)
|
||||||
self.whitespace = re.compile(r'\W+', re.UNICODE)
|
self.whitespace = re.compile(r'\W+', re.UNICODE)
|
||||||
|
self.find_tags = re.compile(u'\{/?\w+\}', re.UNICODE)
|
||||||
|
|
||||||
def keyPressEvent(self, event):
|
def keyPressEvent(self, event):
|
||||||
"""
|
"""
|
||||||
@ -720,8 +721,53 @@ class EditSongForm(QtGui.QDialog, Ui_EditSongDialog):
|
|||||||
self.manager.save_object(book)
|
self.manager.save_object(book)
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
cnt_errors = 0
|
||||||
|
error_list = ''
|
||||||
|
verse_tag = []
|
||||||
|
verse_num = []
|
||||||
|
for i in range(self.verseListWidget.rowCount()):
|
||||||
|
item = self.verseListWidget.item(i, 0)
|
||||||
|
tags = self.find_tags.findall(item.text())
|
||||||
|
if self._validate_tags(tags) == False:
|
||||||
|
field = unicode(item.data(QtCore.Qt.UserRole).toString())
|
||||||
|
verse_tag.append(VerseType.translated_name(field[0]))
|
||||||
|
verse_num.append(field[1:])
|
||||||
|
cnt_errors += 1;
|
||||||
|
if cnt_errors > 0:
|
||||||
|
for i in range(cnt_errors):
|
||||||
|
error_list += '%s %s' % (verse_tag[i], verse_num[i])
|
||||||
|
if i < cnt_errors-1:
|
||||||
|
error_list += ', '
|
||||||
|
critical_error_message_box(
|
||||||
|
message=translate('SongsPlugin.EditSongForm',
|
||||||
|
'There are misplaced formatting tags in the following verses:\n\n%s\n\n'
|
||||||
|
'Please correct these tags before continuing.' % error_list))
|
||||||
|
return False
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
def _validate_tags(self, _tags):
|
||||||
|
"""
|
||||||
|
Validates a list of tags
|
||||||
|
Deletes the first affiliated tag pair which is located side by side in the list
|
||||||
|
and call itself recursively with the shortened tag list.
|
||||||
|
If there is any misplaced tag in the list, either the lenght of the tag list is not even,
|
||||||
|
or the function won't find any tag pairs side by side.
|
||||||
|
If there is no misplaced tag, the length of the list will be zero on any recursive run.
|
||||||
|
|
||||||
|
Return:
|
||||||
|
True if the function can't find any mismatched tags
|
||||||
|
False if there are mismatched tags.
|
||||||
|
"""
|
||||||
|
if len(_tags) == 0:
|
||||||
|
return True
|
||||||
|
if len(_tags) % 2 != 0:
|
||||||
|
return False
|
||||||
|
for i in range(len(_tags)-1):
|
||||||
|
if _tags[i+1] == "{/" + _tags[i][1:]:
|
||||||
|
del _tags[i:i+2]
|
||||||
|
return self._validate_tags(_tags)
|
||||||
|
return False
|
||||||
|
|
||||||
def onCopyrightInsertButtonTriggered(self):
|
def onCopyrightInsertButtonTriggered(self):
|
||||||
text = self.copyrightEdit.text()
|
text = self.copyrightEdit.text()
|
||||||
pos = self.copyrightEdit.cursorPosition()
|
pos = self.copyrightEdit.cursorPosition()
|
||||||
|
Loading…
Reference in New Issue
Block a user