Commit 90cbc971 by Motohisa Nakano

20121205-2

parent 3c754480
...@@ -11,6 +11,9 @@ ...@@ -11,6 +11,9 @@
/** /**
* システムエラーメッセージスタイル * システムエラーメッセージスタイル
*/ */
.toast-container {
z-index: 90001;
}
.toast-item { .toast-item {
border-radius: 10px; border-radius: 10px;
} }
......
...@@ -79,36 +79,51 @@ var UserEnvironment = function() { ...@@ -79,36 +79,51 @@ var UserEnvironment = function() {
* User Settings Class Definition * User Settings Class Definition
*/ */
var UserSetting = function() { var UserSetting = function() {
this.US_KEY="AVWUS"; this.US_KEY="AVWUS";
this.userSetting = this.load();
}; };
/* get user setting from localStorage */
UserSetting.prototype.load = function() {
var storage = window.localStorage;
var value = null;
var js = null;
if(storage) {
var value = storage.getItem(this.US_KEY);
if(!value) {
value = "{}"; // 空JSON文字列
}
js = JSON.parse(value);
}
return js;
}
/* store user setting */ /* store user setting */
UserSetting.prototype.set = function(key, value) { UserSetting.prototype.set = function(key, value) {
if(!this.userSetting) {
this.userSetting = this.load();
}
var values = this.userSetting;
if(!values) {
values = { key: value };
} else {
values[key] = value;
}
var storage = window.localStorage; var storage = window.localStorage;
if(storage) { if(storage) {
var val = storage.getItem(this.US_KEY); var jsonStr = JSON.stringify(values);
var js = null; storage.setItem(this.US_KEY, jsonStr);
if(!val) {
js = {};
} else {
js = JSON.parse(val);
}
js[key] = value;
storage.setItem(this.US_KEY, JSON.stringify(js));
} }
this.userSetting = values;
}; };
/* grab user setting */ /* grab user setting */
UserSetting.prototype.get = function(key) { UserSetting.prototype.get = function(key) {
var storage = window.localStorage; if(!this.userSetting) {
var value = null; this.userSetting = this.load();
if(storage) { }
var value = storage.getItem(this.US_KEY); var values = this.userSetting;
if(!value) { if(values) {
return value; return values[key];
}
var js = JSON.parse(value);
return js[key];
} }
return value; return null;
}; };
/* show user setting object list */ /* show user setting object list */
UserSetting.prototype.show = function(elmid) { UserSetting.prototype.show = function(elmid) {
...@@ -282,6 +297,9 @@ $(function () { ...@@ -282,6 +297,9 @@ $(function () {
alert(error); alert(error);
} }
}); });
// ロード時に一旦エラー状態をクリアしておく
avwClearError();
}); });
/* get system setting object */ /* get system setting object */
...@@ -723,18 +741,22 @@ function getByte(text) { ...@@ -723,18 +741,22 @@ function getByte(text) {
return count; return count;
}; };
/* show system error message */ /* show system error message */
var isShowErrorMessage = false; var hasErrorKey = 'AVW_HASERR';
function showSystemError() { function showSystemError() {
// すでに表示されていたら次は表示しない if(avwHasError()) {
if(isShowErrorMessage) { // すでにエラー状態であればエラーを表示しない
return; return;
} else {
// エラー状態にセット
avwSetErrorState();
} }
// エラーメッセージの表示 // create DOM element for showing error message
var errMes = i18nText('sysErrorCallApi01'); var errMes = i18nText('sysErrorCallApi01');
var tags = '<div id="avw-sys-error"></div>'; var tags = '<div id="avw-sys-error"></div>';
$('body').prepend(tags); //$('body').prepend(tags);
$('body').append(tags);
$('#avw-sys-error').css( { $('#avw-sys-error').css( {
'opacity': 0.7, 'opacity': 0.7,
'position': 'fixed', 'position': 'fixed',
...@@ -742,7 +764,8 @@ function showSystemError() { ...@@ -742,7 +764,8 @@ function showSystemError() {
'left': '0', 'left': '0',
'width': $(window).width(), 'width': $(window).width(),
'height': $(window).height(), 'height': $(window).height(),
'background': '#999' 'background': '#999',
'z-index': 90000
}) })
// resize error page // resize error page
$(window).resize(function() { $(window).resize(function() {
...@@ -751,15 +774,45 @@ function showSystemError() { ...@@ -751,15 +774,45 @@ function showSystemError() {
'height': $(window).height() 'height': $(window).height()
}); });
}); });
/* show error messages */ // show error messages
$().toastmessage({ position: 'middle-center' }); $().toastmessage({ position: 'middle-center' });
$().toastmessage('showToast', { $().toastmessage('showToast', {
type: 'error', type: 'error',
sticky: true, sticky: true,
text: errMes
});
/*
$().toastmessage('showToast', {
type: 'error',
sticky: true,
text: errMes, text: errMes,
close: function() { isShowErrorMessage = false; } close: function() { isShowErrorMessage = false; }
}); });
}; */
};
/* エラー状態を取得 */
function avwHasError() {
var session = window.sessionStorage;
var isError = false;
if(session) {
isError = session.getItem(hasErrorKey);
}
return (isError == 'true');
}
/* エラー状態にセット */
function avwSetErrorState() {
var session = window.sessionStorage;
if(session) {
session.setItem(hasErrorKey, true);
}
}
/* エラー状態をクリア */
function avwClearError() {
var session = window.sessionStorage;
if(session) {
session.setItem(hasErrorKey, false);
}
}
/* ブラウザunload時に警告メッセージの出力設定を行う関数 */ /* ブラウザunload時に警告メッセージの出力設定を行う関数 */
function avwSetLogoutNortice() { function avwSetLogoutNortice() {
window.onbeforeunload = function(event) { window.onbeforeunload = function(event) {
......
{ {
"sysErrorCallApi01":"EN:ご迷惑をおかけし申し訳ございません。<br />システムエラーが発生しました。<br />アプリケーションを終了し、管理者に連絡してください。", "sysErrorCallApi01":"System error.<br/>Please close this window and contact administrator.",
"sysInfoScrLock01":"EN:長時間操作されなかったため、画面をロックしています。<br />画面をクリックしてロックを解除してください。", "sysInfoScrLock01":"Click to unlock.",
"sysInfoWithoutLogout":"EN:ログアウトしておりませんが、このまま終了してもよろしいですか?\n※【注意】ログアウトしないと次回ログインできない場合がございます。", "sysInfoWithoutLogout":"Are you sure to close this window without logout?\nIncorrect logout will cause login problem next time.",
"txtUsrCap":"User Infomation", "txtUsrCap":"User Infomation",
"txtLastLoginTime":"Last login time:", "txtLastLoginTime":"Last login date:",
"txtOpt":"Option", "txtOpt":"Option",
"txtOpt001":"Home default mode", "txtOpt001":"Initial Screen",
"txtHondana":"Bookself", "txtHondana":"Bookshelf",
"txtList":"List", "txtList":"List",
"txtOpt002":"Loop Video and Music", "txtOpt002":"Repeat movie and audio",
"txtOpt003":"EN:マーキング", "txtOpt003":"Show marking when opening contents.",
"dspOptReset":"Restore To Default", "dspOptReset":"Reset",
"txtBkResCap":"EN:サーバにバックアップ/リストア", "txtBkResCap":"Backup / Restore",
"txtOptBkCfm":"EN:毎回ログアウトの時、バックアップするかどうかは必ず確認する", "txtOptBkCfm":"Confirm backup at every logout.",
"dspOptBk":"Backup", "dspOptBk":"Backup",
"dspOptRes":"Restore", "dspOptRes":"Restore",
"dspSave":"Save", "dspSave":"Apply",
"txtBkMsg":"EN:サーバにバックアップしますか?", "txtBkMsg":"Backup to server?",
"txtResMsg":"EN:サーバからリストアしますか?", "txtResMsg":"Restore from Server?",
"msgPwdEmpty":"EN:パスワードが必要。", "msgPwdEmpty":"Password is required.",
"msgPwdOldWrong":"EN:古いパスワードが間違っています。", "msgPwdOldWrong":"Current Password mismatch.",
"msgPwdNotMatch":"EN:パスワードが一致しません。", "msgPwdNotMatch":"New Password doesn't match.",
"msgLoginErrWrong":"EN:ログインできません。入力情報を確認してください。(Error Code:{0})", "msgLoginErrWrong":"LoginId or Password wrong: {0}",
"dspPubDt2":"Delivery Date:", "dspPubDt2":"Distributed Date:",
"txtPage":"Page:", "txtPage":"Page:",
"dspDelete":"Delete", "dspDelete":"Delete",
"dspShioriDelConf":"EN:選択されているしおりを削除しますか?", "dspShioriDelConf":"Are you sure to delete bookmark?",
"dspRegDt":"Register Date", "dspRegDt":"Registered Date",
"dspLogin":"Login", "dspLogin":"Login",
"dspSkip":"Skip", "dspSkip":"Skip",
"dspPwdUpd":"Change Password", "dspPwdUpd":"Apply",
"txtLoginAccPath":"Account Path:", "txtLoginAccPath":"Account Path:",
"txtLoginId":"Login Id:", "txtLoginId":"Login Id:",
"txtLoginPwd":"Password:", "txtLoginPwd":"Password:",
"txtLoginPwdRbr":"EN:アカウントパスとログインIDを記憶する", "txtLoginPwdRbr":"Remember Account Path and Login Id.",
"txtPwdCurr":"Current Password", "txtPwdCurr":"Current Password",
"txtPwdNew":"New Password", "txtPwdNew":"New Password",
"txtPwdNewRe":"EN:(再)変更パスワード", "txtPwdNewRe":"Again",
"txtPwdRemind":"EN:スキップを選択すると、30日以内にこのメッセージが表示されせん", "txtPwdRemind":"This message won't be shown during 30days if skip selected.",
"txtSearch":"Search", "txtSearch":"Search",
"dspShiori":"Bookmark", "dspShiori":"Bookmark",
"dspSetting":"Setting", "dspSetting":"Setting",
"dspLogout":"Logout", "dspLogout":"Logout",
"txtRead":"Read", "txtRead":"Read",
"txtSort":"Order By", "txtSort":"Sort",
"dspTitleNm":"Title Name", "dspTitleNm":"Title",
"dspTitleNmKn":"Title Name(Kana)", "dspTitleNmKn":"Title(Kana)",
"txtPubDt":"EN:公開日", "txtPubDt":"Released Date",
"txtRecordNum":"EN:件", "txtRecordNum":"",
"txtRecordTotal":"EN:件 表示", "txtRecordTotal":"",
"dspViewMore":"EN:>>次の{0}件を表示", "dspViewMore":">> Next {0} contents",
"txtGen":"Category", "txtGen":"Genre",
"txtGr":"Group", "txtGr":"Group",
"txtViewDt":"View Date", "txtViewDt":"Accessed Date",
"txtDetailPage":"Detail", "txtDetailPage":"Detail",
"txtCtnNm":"Content Name", "txtCtnNm":"Content Name",
"txtTag":"Tag", "txtTag":"Tag",
"txtContTxt":"EN:本文", "txtContTxt":"Body Text",
"txtLogoutBkMsg":"EN:ログアウトする前にバックアップしますか?", "txtLogoutBkMsg":"Backup before logout?",
"txtLogoutOptBkCfm":"EN:今回の行動を記憶し、次回から確認せずに、同じことをする。", "txtLogoutOptBkCfm":"Remember this operation",
"dspBkOK":"EN:バックアップしてログアウト", "dspBkOK":"Backup and Logout",
"dspBkCancel":"EN:バックアップしないでログアウト", "dspBkCancel":"Logout",
"txtSearchResult":"Search Result", "txtSearchResult":"Result",
"dspHome":"Home", "dspHome":"Home",
"txtLoginUser":"(Ver.20121205-1)EN:ログイン中:", "txtLoginUser":"(Ver.20121206-1)User:",
"txtAll":"All", "txtAll":"All",
"txtMkgSize":"EN:太さ", "txtMkgSize":"Size",
"txtMkgS":"EN:小", "txtMkgS":"S",
"txtMkgM":"EN:中", "txtMkgM":"M",
"txtMkgB":"EN:大", "txtMkgB":"L",
"txtMkgSB":"EN:特大", "txtMkgSB":"LL",
"dspOK":"OK", "dspOK":"OK",
"dspCancel":"Cancel", "dspCancel":"Cancel",
"txtMkToolBar":"EN:マーキング", "txtMkToolBar":"Marking Toolbar",
"dspPgClear":"EN:Clear this page", "dspPgClear":"Clear this page",
"txtColor":"Color", "txtColor":"Color",
"txtIndex":"Index", "txtIndex":"Index",
"txtShioriCtnLs":"Bookmark List", "txtShioriCtnLs":"Bookmark list",
"txtTextCopy":"EN:テキストコピー", "txtTextCopy":"Copy Body Text",
"txtNoTextCopy":"EN:テキストがありません。", "txtNoTextCopy":"No Text",
"txtNoSearchResult":"EN:検索結果がありません。", "txtNoSearchResult":"No Result",
"msgShioriNotExists":"EN:しおりがありません。", "msgShioriNotExists":"no Bookmark",
"msgPwdChangeOK":"EN:パスワード変更は成功しました。", "msgPwdChangeOK":"Success.",
"msgPwdChangeNG":"EN:パスワード変更は失敗しましたので、すみませんが、もう一度してください。※注意:新規パスワードには英字および数字両方を含める必要があります。", "msgPwdChangeNG":"Failed.<br/>Password requires at least both of character and numeric.",
"msgSearchNotExist":"EN:条件と該当するコンテンツがありません", "msgSearchNotExist":"No content",
"txtTooltipBack":"EN:戻る", "txtTooltipBack":"Back",
"txtTooltipBookmark":"EN:しおり追加・削除", "txtTooltipBookmark":"Add/Delete Bookmark",
"txtTooltipShowMemo":"EN:メモ表示・非表示", "txtTooltipShowMemo":"Show/Hide memo",
"txtTooltipAddMemo":"EN:メモ追加", "txtTooltipAddMemo":"Add memo",
"txtTooltipShowMarking":"EN:マーキング表示・非表示", "txtTooltipShowMarking":"Show/Hide Marking",
"txtTooltipShowMarkingTool":"EN:マーキングツールバーを表示・非表示", "txtTooltipShowMarkingTool":"Show/Hide Marking Panel",
"msgShioriDeleted":"EN:しおりのページが削除しました。", "msgShioriDeleted":"Page was deleted.",
"dspViewHistory":"View History", "dspViewHistory":"History",
"msgLoginEmpty":"EN:入力してください", "msgLoginEmpty":"Please fill empty field.",
"msgSaveOk":"EN:保存しました", "msgSaveOk":"Saved",
"msgPlaceHolder":"EN:キーワードを入力してください", "msgPlaceHolder":"Keyword",
"txtOpt004":"EN:※コンテンツを開いた時に表示する", "txtOpt004":"Show when content will be opened.",
"txtRestoreTitle":"EN:リストア確認", "txtRestoreTitle":"Restore confirmation",
"txtBackupTitle":"EN:バックアップ確認", "txtBackupTitle":"Backup confirmation",
"txtResMsgNotice":"EN:※リストアしたら、現時点のローカルのデータでサーバのバックアップデータを上書きします。リストア後、元の状態に復元できませんので、ご注意ください", "txtResMsgNotice":"This operation will override current data and all of your data will be lost.",
"dspChange":"Change", "dspChange":"Change",
"msgNoIndex":"EN:インデックスがありません", "msgNoIndex":"No index.",
"msgBackupSuccess":"EN:バックアップが正常に終了しました", "msgBackupSuccess":"Backup success.",
"msgBackupFailed":"EN:バックアップが失敗しました", "msgBackupFailed":"Backup failed.",
"msgRestoreSuccess":"EN:リストアが正常に終了しました", "msgRestoreSuccess":"Restore success.",
"msgRestoreFailed":"EN:リストアが失敗しました", "msgRestoreFailed":"Restore failed.",
"txtDeleteConfirmTitle":"EN:しおり削除確認", "txtDeleteConfirmTitle":"Delete confirmation",
"msgHistoryNotExist":"EN:閲覧履歴はありません。", "msgHistoryNotExist":"No history",
"msgChangePassword":"EN:パスワード変更", "msgChangePassword":"Change Password",
"txtMemoEdit":"Edit", "txtMemoEdit":"Edit memo",
"txtMemoCopy":"Copy", "txtMemoCopy":"Copy",
"msgPageImgErr":"EN:コンテンツを表示することができません。コンテンツが削除された可能性があります。ホーム画面に戻り異なるコンテンツを選択してください。", "msgPageImgErr":"Unable to show contents. Maybe it was deleted at server. Back home and choose another content.",
"sysAppTitle":"EN:ABook閲覧ウェブ版" "sysAppTitle":"ABook Viewer for Web"
} }
{ {
"sysErrorCallApi01":"ご迷惑をおかけし申し訳ございません。<br />システムエラーが発生しました。<br />アプリケーションを終了し、管理者に連絡してください。", "sysErrorCallApi01":"ご迷惑をおかけし申し訳ございません。<br />システムエラーが発生しました。<br />アプリケーションを終了し、管理者に連絡してください。",
"sysInfoScrLock01":"長時間操作されなかったため、画面をロックしています。<br />画面をクリックしてロックを解除してください。", "sysInfoScrLock01":"長時間操作されなかったため、画面をロックしています。<br />画面をクリックしてロックを解除してください。",
"sysInfoWithoutLogout":"ログアウトしておりませんが、このまま終了してもよろしいですか?\n※【注意】ログアウトしないと次回ログインできない場合がございます。", "sysInfoWithoutLogout":"ログアウトしてませんが、このまま終了してもよろしいですか?\n※【注意】ログアウトしないと次回ログインできない場合がございます。",
"txtUsrCap":"ユーザ情報", "txtUsrCap":"ユーザ情報",
"txtLastLoginTime":"最終ログイン時間:", "txtLastLoginTime":"最終ログイン時間:",
"txtOpt":"オプション", "txtOpt":"オプション",
"txtOpt001":"最初の画面を選択", "txtOpt001":"初期表示",
"txtHondana":"本棚", "txtHondana":"本棚",
"txtList":"リスト", "txtList":"リスト",
"txtOpt002":"動画、音楽繰り返し", "txtOpt002":"動画・音楽を繰り返し再生する",
"txtOpt003":"マーキング", "txtOpt003":"マーキング",
"dspOptReset":"初期設定に戻る", "dspOptReset":"初期設定に戻る",
"txtBkResCap":"サーバにバックアップ/リストア", "txtBkResCap":"サーバにバックアップ/リストア",
"txtOptBkCfm":"毎回ログアウトの時、バックアップするかどうか必ず確認する", "txtOptBkCfm":"ログアウトの時、バックアップするかどうか確認する",
"dspOptBk":"バックアップ", "dspOptBk":"バックアップ",
"dspOptRes":"リストア", "dspOptRes":"リストア",
"dspSave":"保存", "dspSave":"保存",
"txtBkMsg":"サーバにバックアップしますか?", "txtBkMsg":"サーバにデータをバックアップしますか?",
"txtResMsg":"サーバからデータを復旧しますか?※復旧すると現在のデータが上書きされます。復旧後は直前の状態に戻すことはできませんのでご注意ください。", "txtResMsg":"サーバからデータをリストアしますか?",
"msgPwdEmpty":"パスワードが必要。", "msgPwdEmpty":"パスワードを入力してください",
"msgPwdOldWrong":"現在のパスワードは誤りにあります。", "msgPwdOldWrong":"現在のパスワードに誤りがあります",
"msgPwdNotMatch":"変更パスワードが一致していません。", "msgPwdNotMatch":"変更パスワードが一致していません。",
"msgLoginErrWrong":"ログインできません。入力情報を確認してください。(エラーコード:{0})", "msgLoginErrWrong":"ログインできません。入力情報を確認してください。(エラーコード:{0})",
"dspPubDt2":"発行日:", "dspPubDt2":"発行日:",
...@@ -45,12 +45,12 @@ ...@@ -45,12 +45,12 @@
"dspLogout":"ログアウト", "dspLogout":"ログアウト",
"txtRead":"読む", "txtRead":"読む",
"txtSort":"並べ替え", "txtSort":"並べ替え",
"dspTitleNm":"タイトル", "dspTitleNm":"タイトル",
"dspTitleNmKn":"タイトル名(かな)", "dspTitleNmKn":"タイトル(カナ)",
"txtPubDt":"公開日", "txtPubDt":"公開日",
"txtRecordNum":"件", "txtRecordNum":"件",
"txtRecordTotal":"件 表示", "txtRecordTotal":"件 表示",
"dspViewMore":">>次の{0}件を表示", "dspViewMore":">> 次の{0}件を表示",
"txtGen":"ジャンル", "txtGen":"ジャンル",
"txtGr":"グループ", "txtGr":"グループ",
"txtViewDt":"閲覧日", "txtViewDt":"閲覧日",
...@@ -61,10 +61,10 @@ ...@@ -61,10 +61,10 @@
"txtLogoutBkMsg":"ログアウトする前にバックアップしますか?", "txtLogoutBkMsg":"ログアウトする前にバックアップしますか?",
"txtLogoutOptBkCfm":"今回の行動を記憶する。", "txtLogoutOptBkCfm":"今回の行動を記憶する。",
"dspBkOK":"バックアップしてログアウト", "dspBkOK":"バックアップしてログアウト",
"dspBkCancel":"バックアップしないでログアウト", "dspBkCancel":"バックアップせずにログアウト",
"txtSearchResult":"検索結果", "txtSearchResult":"検索結果",
"dspHome":"ホーム", "dspHome":"ホーム",
"txtLoginUser":"(Ver.20121205-1)ログイン中:", "txtLoginUser":"(Ver.20121206-1)ログイン中:",
"txtAll":"すべて", "txtAll":"すべて",
"txtMkgSize":"太さ", "txtMkgSize":"太さ",
"txtMkgS":"小", "txtMkgS":"小",
...@@ -81,8 +81,8 @@ ...@@ -81,8 +81,8 @@
"txtTextCopy":"テキストコピー", "txtTextCopy":"テキストコピー",
"txtNoTextCopy":"テキストがありません。", "txtNoTextCopy":"テキストがありません。",
"txtNoSearchResult":"検索結果がありません。", "txtNoSearchResult":"検索結果がありません。",
"msgShioriNotExists":"しおりがありません", "msgShioriNotExists":"しおりがありません",
"msgPwdChangeOK":"パスワード変更は成功しました。", "msgPwdChangeOK":"パスワードを変更しました。",
"msgPwdChangeNG":"パスワード変更に失敗しました。再入力してください。※注意:新規パスワードには英字および数字両方を含める必要があります。", "msgPwdChangeNG":"パスワード変更に失敗しました。再入力してください。※注意:新規パスワードには英字および数字両方を含める必要があります。",
"msgSearchNotExist":"条件に該当するコンテンツがありません。", "msgSearchNotExist":"条件に該当するコンテンツがありません。",
"txtTooltipBack":"戻る", "txtTooltipBack":"戻る",
...@@ -93,24 +93,24 @@ ...@@ -93,24 +93,24 @@
"txtTooltipShowMarkingTool":"マーキングツールバーを表示・非表示", "txtTooltipShowMarkingTool":"マーキングツールバーを表示・非表示",
"msgShioriDeleted":"ページが削除しました。", "msgShioriDeleted":"ページが削除しました。",
"dspViewHistory":"閲覧履歴", "dspViewHistory":"閲覧履歴",
"msgLoginEmpty":"入力してください", "msgLoginEmpty":"ログイン情報を入力してください",
"msgSaveOk":"保存しました", "msgSaveOk":"保存しました",
"msgPlaceHolder":"キーワードを入力してください", "msgPlaceHolder":"キーワードを入力してください",
"txtOpt004":"※コンテンツを開いた時に表示する", "txtOpt004":"※コンテンツを開いた時に表示する",
"txtRestoreTitle":"リストア確認", "txtRestoreTitle":"リストア確認",
"txtBackupTitle":"バックアップ確認", "txtBackupTitle":"バックアップ確認",
"txtResMsgNotice":"※リストアしたら、現時点のローカルのデータでサーバのバックアップデータを上書きします。リストア後、元の状態に復元できませんので、ご注意ください", "txtResMsgNotice":"※リストアすると、現時点のローカルのデータでサーバのバックアップデータを上書きします。リストア後、元の状態に復元できませんので、ご注意ください",
"dspChange":"変更", "dspChange":"変更",
"msgNoIndex":"インデックスがありません", "msgNoIndex":"インデックスがありません",
"msgBackupSuccess":"バックアップが正常に終了しました", "msgBackupSuccess":"バックアップが正常に終了しました",
"msgBackupFailed":"バックアップ失敗しました", "msgBackupFailed":"バックアップ失敗しました",
"msgRestoreSuccess":"リストアが正常に終了しました", "msgRestoreSuccess":"リストアが正常に終了しました",
"msgRestoreFailed":"リストア失敗しました", "msgRestoreFailed":"リストア失敗しました",
"txtDeleteConfirmTitle":"しおり削除確認", "txtDeleteConfirmTitle":"しおり削除確認",
"msgHistoryNotExist":"閲覧履歴はありません。", "msgHistoryNotExist":"閲覧履歴はありません。",
"msgChangePassword":"パスワード変更", "msgChangePassword":"パスワード変更",
"txtMemoEdit":"編集", "txtMemoEdit":"編集",
"txtMemoCopy":"コピー", "txtMemoCopy":"コピー",
"msgPageImgErr":"コンテンツを表示することができません。コンテンツが削除された可能性があります。ホーム画面に戻り異なるコンテンツを選択してください。", "msgPageImgErr":"コンテンツを表示することができません。コンテンツが削除された可能性があります。ホーム画面に戻り異なるコンテンツを選択してください。",
"sysAppTitle":"ABook閲覧ウェブ版" "sysAppTitle":"ABook閲覧ウェブ版"
} }
{ {
"sysErrorCallApi01":"시스템 에러가 발생했습니다. 이용에 불편을 드려 죄송합니다.", "sysErrorCallApi01":"시스템 에러가 발생했습니다. 이용에 불편을 드려 죄송합니다.",
"sysInfoScrLock01":"장시간 조작이 없었으므로, 화면이 잠겼습니다.<br/>잠김을 해제하려면 화면을 클릭하십시오.", "sysInfoScrLock01":"장시간 조작이 없었으므로, 화면이 잠겼습니다.<br/>잠김을 해제하려면 화면을 클릭하십시오.",
"sysInfoWithoutLogout":"로그아웃하지 않은 상태로 창을 닫으면, 다음에 로그인되지 않는 경우도 있습니다. 이대로 창을 닫으시겠습니까?", "sysInfoWithoutLogout":"로그아웃하지 않은 상태로 창을 닫으면, 다음에 로그인되지 않는 경우도 있습니다. 이대로 창을 닫으시겠습니까?\n(이 메세지는 브라우저를 '새로 고침' 할 때에도 표시됩니다.)",
"txtUsrCap":"사용자 정보", "txtUsrCap":"사용자 정보",
"txtLastLoginTime":"최종 로그인 시간:", "txtLastLoginTime":"최종 로그인 시간:",
"txtOpt":"옵션", "txtOpt":"옵션",
"txtOpt001":"기본 화면 선택", "txtOpt001":"기본 화면 선택",
"txtHondana":"갤러리", "txtHondana":"그리드",
"txtList":"리스트", "txtList":"리스트",
"txtOpt002":"동영상, 음악 반복 재생", "txtOpt002":"동영상, 음악 반복 재생",
"txtOpt003":"마킹", "txtOpt003":"마킹",
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
"dspOptRes":"복원", "dspOptRes":"복원",
"dspSave":"저장", "dspSave":"저장",
"txtBkMsg":"서버에 백업하시겠습니까?", "txtBkMsg":"서버에 백업하시겠습니까?",
"txtResMsg":"서버에서 복원하시겠습니까? ※복원하면, 사용자 디바이스(PC, 태블릿 등)에 저장된 데이터를 서버의 데이터로 덮어씁니다. 복원 후 취소할 수 없습니다.", "txtResMsg":"기존에 서버에 백업한 데이터를 복원하시겠습니까?",
"msgPwdEmpty":"패스워드를 입력해 주십시오.", "msgPwdEmpty":"패스워드를 입력해 주십시오.",
"msgPwdOldWrong":"기존 패스워드를 바르게 입력해 주십시오.", "msgPwdOldWrong":"기존 패스워드를 바르게 입력해 주십시오.",
"msgPwdNotMatch":"신규 패스워드와 신규 패스워드 확인이 일치하지 않습니다.", "msgPwdNotMatch":"신규 패스워드와 신규 패스워드 확인이 일치하지 않습니다.",
...@@ -64,7 +64,7 @@ ...@@ -64,7 +64,7 @@
"dspBkCancel":"로그아웃", "dspBkCancel":"로그아웃",
"txtSearchResult":"검색 결과", "txtSearchResult":"검색 결과",
"dspHome":"홈", "dspHome":"홈",
"txtLoginUser":"(Ver.20121205-1)로그인 중:", "txtLoginUser":"(Ver.20121206-1)로그인 중:",
"txtAll":"전체", "txtAll":"전체",
"txtMkgSize":"두께", "txtMkgSize":"두께",
"txtMkgS":"소", "txtMkgS":"소",
...@@ -83,7 +83,7 @@ ...@@ -83,7 +83,7 @@
"txtNoSearchResult":"검색 결과가 없습니다.", "txtNoSearchResult":"검색 결과가 없습니다.",
"msgShioriNotExists":"북마크가 없습니다.", "msgShioriNotExists":"북마크가 없습니다.",
"msgPwdChangeOK":"패스워드가 변경되었습니다.", "msgPwdChangeOK":"패스워드가 변경되었습니다.",
"msgPwdChangeNG":"패스워드를 변경하지 못했습니다. 다시 시도하시기 바랍니다.※주의 : 패스워드에는 영/숫자를 1개 이상씩 사용해야 합니다.", "msgPwdChangeNG":"패스워드를 변경하지 못했습니다. 다시 시도하시기 바랍니다.<br/>※주의 : 패스워드에는 영/숫자를 1개 이상씩 사용해야 합니다.",
"msgSearchNotExist":"조건에 맞는 컨텐츠가 없습니다.", "msgSearchNotExist":"조건에 맞는 컨텐츠가 없습니다.",
"txtTooltipBack":"뒤로 가기", "txtTooltipBack":"뒤로 가기",
"txtTooltipBookmark":"북마크 추가/삭제", "txtTooltipBookmark":"북마크 추가/삭제",
...@@ -93,13 +93,13 @@ ...@@ -93,13 +93,13 @@
"txtTooltipShowMarkingTool":"마킹 툴바 표시/비표시", "txtTooltipShowMarkingTool":"마킹 툴바 표시/비표시",
"msgShioriDeleted":"북마크한 페이지가 삭제되었습니다.", "msgShioriDeleted":"북마크한 페이지가 삭제되었습니다.",
"dspViewHistory":"열람 이력", "dspViewHistory":"열람 이력",
"msgLoginEmpty":"입력해 주십시오.", "msgLoginEmpty":"로그인 정보를 입력해 주십시오.",
"msgSaveOk":"저장했습니다.", "msgSaveOk":"저장했습니다.",
"msgPlaceHolder":"키워드를 입력해 주십시오.", "msgPlaceHolder":"키워드를 입력해 주십시오.",
"txtOpt004":"컨텐츠를 열 때 표시", "txtOpt004":"컨텐츠를 열 때 표시",
"txtRestoreTitle":"복원 확인", "txtRestoreTitle":"복원 확인",
"txtBackupTitle":"백업 확인", "txtBackupTitle":"백업 확인",
"txtResMsgNotice":"서버에서 복원하시겠습니까? ※복원하면, 사용자 디바이스(PC, 태블릿 등)에 저장된 데이터를 서버의 데이터로 덮어씁니다. 복원 후 취소할 수 없습니다.", "txtResMsgNotice":"※복원하면, 사용자 디바이스(PC, 태블릿 등)에 저장된 데이터를 마지막으로 백업한 데이터로 덮어씁니다. 복원 후 취소할 수 없습니다.",
"dspChange":"변경", "dspChange":"변경",
"msgNoIndex":"목차가 없습니다.", "msgNoIndex":"목차가 없습니다.",
"msgBackupSuccess":"백업했습니다.", "msgBackupSuccess":"백업했습니다.",
...@@ -108,9 +108,9 @@ ...@@ -108,9 +108,9 @@
"msgRestoreFailed":"복원을 실패했습니다.", "msgRestoreFailed":"복원을 실패했습니다.",
"txtDeleteConfirmTitle":"북마크 삭제 확인", "txtDeleteConfirmTitle":"북마크 삭제 확인",
"msgHistoryNotExist":"열람 이력이 없습니다.", "msgHistoryNotExist":"열람 이력이 없습니다.",
"msgChangePassword":"패스워드 변경", "msgChangePassword":"패스워드 변경를 변경해 주십시오.",
"txtMemoEdit":"편집", "txtMemoEdit":"편집",
"txtMemoCopy":"복사", "txtMemoCopy":"복사",
"msgPageImgErr":"KO:コンテンツを表示することができません。コンテンツが削除された可能性があります。ホーム画面に戻り異なるコンテンツを選択してください。", "msgPageImgErr":"컨텐츠를 표시할 수 없습니다. 이 컨텐츠는 삭제되었을 가능성이 있습니다.",
"sysAppTitle":"KO:ABook閲覧ウェブ版" "sysAppTitle":"ABook : 멀티미디어 컨텐츠 플랫폼"
} }
...@@ -1081,6 +1081,8 @@ ...@@ -1081,6 +1081,8 @@
} }
}else{ }else{
/* fit page */
screenFit();
ClientData.IsAddingMarking(true); ClientData.IsAddingMarking(true);
ClientData.IsDisplayMarking(true); ClientData.IsDisplayMarking(true);
...@@ -1100,8 +1102,7 @@ ...@@ -1100,8 +1102,7 @@
/* draw again */ /* draw again */
drawCanvas(); drawCanvas();
/* fit page */
screenFit();
displayCanvasDraw(); displayCanvasDraw();
disableAllControl(); disableAllControl();
...@@ -1216,7 +1217,11 @@ ...@@ -1216,7 +1217,11 @@
$('#lastpage').unbind('click'); $('#lastpage').unbind('click');
$('#zoomfit').unbind('click'); $('#zoomfit').unbind('click');
$('#zoomin').unbind('click'); $('#zoomin').unbind('click');
$('#zoomout').unbind('click'); $('#zoomin').removeClass();
$('#zoomin').addClass('expansion_off');
$('#zoomout').unbind('click');
$('#zoomout').removeClass();
$('#zoomout').addClass('reduction_off');
$("#slider_page").slider( "option", "disabled", true ); $("#slider_page").slider( "option", "disabled", true );
disable('#txtSearch','#txtSlider'); disable('#txtSearch','#txtSlider');
...@@ -1245,8 +1250,8 @@ ...@@ -1245,8 +1250,8 @@
$("#nextpage").css('cursor', 'pointer'); $("#nextpage").css('cursor', 'pointer');
$("#lastpage").css('cursor', 'pointer'); $("#lastpage").css('cursor', 'pointer');
$("#zoomfit").css('cursor', 'pointer'); $("#zoomfit").css('cursor', 'pointer');
$("#zoomin").css('cursor', 'pointer'); // $("#zoomin").css('cursor', 'pointer');
$("#zoomout").css('cursor', 'pointer'); // $("#zoomout").css('cursor', 'pointer');
$("#control_screen").css('cursor', 'pointer'); $("#control_screen").css('cursor', 'pointer');
$("#control_screen_2").css('cursor', 'pointer'); $("#control_screen_2").css('cursor', 'pointer');
$("#slider_page").css('cursor', 'pointer'); $("#slider_page").css('cursor', 'pointer');
...@@ -1335,8 +1340,12 @@ ...@@ -1335,8 +1340,12 @@
$('#nextpage').bind('click',nextPage_click); $('#nextpage').bind('click',nextPage_click);
$('#lastpage').bind('click',lastPage_click); $('#lastpage').bind('click',lastPage_click);
$('#zoomfit').bind('click',screenFit); $('#zoomfit').bind('click',screenFit);
$('#zoomin').bind('click',zoomIn); // $('#zoomin').bind('click',zoomIn);
$('#zoomout').bind('click',zoomOut); // $('#zoomin').addClass('expansion');
// $("#zoomin").css('cursor', 'pointer');
// $('#zoomout').bind('click',zoomOut);
// $('#zoomout').addClass('reduction');
// $("#zoomout").css('cursor', 'pointer'); checkDisableButtonZoom();
$( "#slider_page" ).slider( "option", "disabled", false ); $( "#slider_page" ).slider( "option", "disabled", false );
enable('#txtSearch','#txtSlider'); enable('#txtSearch','#txtSlider');
...@@ -1921,8 +1930,15 @@ ...@@ -1921,8 +1930,15 @@
}else{ }else{
/* create data on dialog */ /* create data on dialog */
$('#divCopyText').children().remove(); $('#divCopyText').children().remove();
//$('#divCopyText').append('<li class="last">' + sPageText + '</li>'); //$('#divCopyText').append('<li class="last">' + sPageText + '</li>');
$('#divCopyText').append('<label class="last" style="word-wrap:break-word">' +sPageText+ '</label>');
var strPattern = "\n";
var strTemp = sPageText;
strTemp = strTemp.replace(strPattern, "<br/>");
strTemp += "<br/>";
$('#divCopyText').append('<div class="last" id="txtTextCopy" style="word-wrap:break-word">' + strTemp + '</div>');
/* display dialog */ /* display dialog */
// $("#divCopyText").dialog({ // $("#divCopyText").dialog({
// show: "blind", // show: "blind",
...@@ -3341,7 +3357,9 @@ function oldContent_Back(){ ...@@ -3341,7 +3357,9 @@ function oldContent_Back(){
/* handle from bookmark page */ /* handle from bookmark page */
handleFromBookMarkPage(); handleFromBookMarkPage();
trackTransforms(context_main);
nAjaxLoad = 0; nAjaxLoad = 0;
......
...@@ -911,6 +911,14 @@ aside.bookmarkBox label{ ...@@ -911,6 +911,14 @@ aside.bookmarkBox label{
line-height:15px; line-height:15px;
vertical-align:middle; vertical-align:middle;
} }
aside.bookmarkBox div{
padding:4px;
border-bottom:solid 1px #444;
overflow:hidden;
font-size:11px;
line-height:15px;
vertical-align:middle;
}
aside.bookmarkBox li .imgbox{ aside.bookmarkBox li .imgbox{
/* /*
...@@ -1079,6 +1087,9 @@ aside.bookmarkBox .last{ ...@@ -1079,6 +1087,9 @@ aside.bookmarkBox .last{
.sizing .reduction {width:56px;background-position:-117px 0;} .sizing .reduction {width:56px;background-position:-117px 0;}
.sizing a:hover.reduction {background-position:-117px -33px;} .sizing a:hover.reduction {background-position:-117px -33px;}
.sizing .expansion_off {width:59px;background-position:0 0;}
.sizing .reduction_off {width:56px;background-position:-117px 0;}
/*----------------------------*/ /*----------------------------*/
/* 14. toolbar setting */ /* 14. toolbar setting */
/*----------------------------*/ /*----------------------------*/
......
...@@ -1205,16 +1205,23 @@ function mouseMove_canvasMain(event){ ...@@ -1205,16 +1205,23 @@ function mouseMove_canvasMain(event){
mx = event.targetTouches[0].pageX - px; mx = event.targetTouches[0].pageX - px;
my = event.targetTouches[0].pageY - py; my = event.targetTouches[0].pageY - py;
} }
// scaling // scaling
var sx = (destRect.right - destRect.left) / (srcRect.right - srcRect.left); // var sx = (destRect.right - destRect.left) / (srcRect.right - srcRect.left);
var sy = (destRect.bottom - destRect.top) / (srcRect.bottom - srcRect.top); // var sy = (destRect.bottom - destRect.top) / (srcRect.bottom - srcRect.top);
var sx = 1 / userScale;
var sy = 1 / userScale;
// calc scaling moving distance // calc scaling moving distance
moveX = Math.round(-mx * sx); moveX = Math.round(-mx * sx);
moveY = Math.round(-my * sy); moveY = Math.round(-my * sy);
// store current mouse point // store current mouse point
if (avwUserEnvObj.os != "ipad" && avwUserEnvObj.os != "android") { if (avwUserEnvObj.os != "ipad" && avwUserEnvObj.os != "android") {
px = event.pageX; px = event.pageX;
...@@ -1228,6 +1235,37 @@ function mouseMove_canvasMain(event){ ...@@ -1228,6 +1235,37 @@ function mouseMove_canvasMain(event){
flip(); flip();
zoomVideo(); zoomVideo();
// lastX = event.offsetX || (event.pageX - canvas_main.offsetLeft);
// lastY = event.offsetY || (event.pageY - canvas_main.offsetTop);
//
// if (dragStart){
// var pt = context_main.transformedPoint(lastX,lastY);
//
//
//
// if(yPos < maxposY){
// xPos += pt.x-dragStart.x;
// yPos += pt.y-dragStart.y;
//
// context_main.translate(pt.x-dragStart.x,pt.y-dragStart.y);
//
// // Clear the entire canvas
// var p1 = context_main.transformedPoint(0,0);
// var p2 = context_main.transformedPoint(canvas_main.width,canvas_main.height);
// context_main.clearRect(p1.x,p1.y,p2.x-p1.x,p2.y-p1.y);
//
// flip();
// }else{
//
// }
//
//
//
//
// }
} }
var cwMain = $('#main').width(); var cwMain = $('#main').width();
...@@ -1295,12 +1333,18 @@ function mouseDown_CanvasMain(event){ ...@@ -1295,12 +1333,18 @@ function mouseDown_CanvasMain(event){
py = event.targetTouches[0].pageY; py = event.targetTouches[0].pageY;
} }
// document.body.style.mozUserSelect = document.body.style.webkitUserSelect = document.body.style.userSelect = 'none';
// lastX = event.offsetX || (event.pageX - canvas_main.offsetLeft);
// lastY = event.offsetY || (event.pageY - canvas_main.offsetTop);
// dragStart = context_main.transformedPoint(lastX,lastY);
} }
function mouseUp_CanvasMain(event){ function mouseUp_CanvasMain(event){
moveFlag = false; moveFlag = false;
} }
/* View Component setDefaultEvent */ /* View Component setDefaultEvent */
function setDefaultEvent() { function setDefaultEvent() {
document.getElementById('main').addEventListener('click',onClick_CanvasMain,false); document.getElementById('main').addEventListener('click',onClick_CanvasMain,false);
...@@ -1779,6 +1823,25 @@ function flip() { ...@@ -1779,6 +1823,25 @@ function flip() {
var size = canvas.height / height; var size = canvas.height / height;
height = canvas.height; height = canvas.height;
width = width * size; width = width * size;
}
if(userScale != 1 && width < canvas.width){
width = width * userScale;
if(width > canvas.width){
//var size = canvas.width / width;
width = canvas.width;
//height = height * size;
}
}else if(userScale != 1 && height < canvas.height){
height = width * userScale;
if(height > canvas.height){
//var size = canvas.height / height;
height = canvas.height;
//width = width * size;
}
} }
var destX = 0, destY = 0; var destX = 0, destY = 0;
...@@ -1801,6 +1864,8 @@ function flip() { ...@@ -1801,6 +1864,8 @@ function flip() {
destRect = new Rect(destX, destY, width, height); destRect = new Rect(destX, destY, width, height);
/* get position for drawing canvas*/ /* get position for drawing canvas*/
if(isFirstLoad == true){ if(isFirstLoad == true){
nPositionCanvas.left = destRect.left; nPositionCanvas.left = destRect.left;
...@@ -1822,14 +1887,17 @@ function flip() { ...@@ -1822,14 +1887,17 @@ function flip() {
scaleX = offscreen.width / width; scaleX = offscreen.width / width;
scaleY = offscreen.height / height; scaleY = offscreen.height / height;
// draw canvas // draw canvas
context.clearRect(0, 0, canvas.width, canvas.height); context.clearRect(0, 0, canvas.width, canvas.height);
context.save(); context.save();
context.drawImage(offscreen, context.drawImage(offscreen,
srcRect.left, srcRect.top, srcRect.right - srcRect.left, srcRect.bottom - srcRect.top, srcRect.left, srcRect.top, srcRect.right - srcRect.left, srcRect.bottom - srcRect.top,
destRect.left, destRect.top, width, height); destRect.left, destRect.top, width, height);
context.restore(); context.restore();
}; };
/* mediaType = 1 and actionType = 0 linkURL object*/ /* mediaType = 1 and actionType = 0 linkURL object*/
...@@ -2443,7 +2511,12 @@ function sizingNotFull(width, height) { ...@@ -2443,7 +2511,12 @@ function sizingNotFull(width, height) {
.css('top', marginY); .css('top', marginY);
} }
$("#draw_canvas").css('cursor', 'default'); $("#draw_canvas").css('cursor', 'default');
if(userScale !=1){
changeScale(userScale);
flip();
}
}; };
/* Adjust Component size */ /* Adjust Component size */
...@@ -2463,6 +2536,10 @@ function sizingFullSize(width, height) { ...@@ -2463,6 +2536,10 @@ function sizingFullSize(width, height) {
$("#draw_canvas").css('cursor', 'default'); $("#draw_canvas").css('cursor', 'default');
if(userScale !=1){
changeScale(userScale);
flip();
}
}; };
/* zoom video */ /* zoom video */
...@@ -2505,9 +2582,78 @@ function zoomVideo(){ ...@@ -2505,9 +2582,78 @@ function zoomVideo(){
} }
} }
var scaleFactor = 1.1;
var zoom = function(clicks){
var pt = context_main.transformedPoint(lastX,lastY);
context_main.translate(lastX,lastY);
var factor = Math.pow(scaleFactor,clicks);
context_main.scale(factor,factor);
maxposY += canvas_main.width * (factor - 1);
context_main.translate(-lastX,-lastY);
}
// Adds ctx.getTransform() - returns an SVGMatrix
// Adds ctx.transformedPoint(x,y) - returns an SVGPoint
function trackTransforms(ctx){
var svg = document.createElementNS("http://www.w3.org/2000/svg",'svg');
var xform = svg.createSVGMatrix();
ctx.getTransform = function(){ return xform; };
var savedTransforms = [];
var save = ctx.save;
ctx.save = function(){
savedTransforms.push(xform.translate(0,0));
return save.call(ctx);
};
var restore = ctx.restore;
ctx.restore = function(){
xform = savedTransforms.pop();
return restore.call(ctx);
};
var scale = ctx.scale;
ctx.scale = function(sx,sy){
xform = xform.scaleNonUniform(sx,sy);
return scale.call(ctx,sx,sy);
};
var rotate = ctx.rotate;
ctx.rotate = function(radians){
xform = xform.rotate(radians*180/Math.PI);
return rotate.call(ctx,radians);
};
var translate = ctx.translate;
ctx.translate = function(dx,dy){
xform = xform.translate(dx,dy);
return translate.call(ctx,dx,dy);
};
var transform = ctx.transform;
ctx.transform = function(a,b,c,d,e,f){
var m2 = svg.createSVGMatrix();
m2.a=a; m2.b=b; m2.c=c; m2.d=d; m2.e=e; m2.f=f;
xform = xform.multiply(m2);
return transform.call(ctx,a,b,c,d,e,f);
};
var setTransform = ctx.setTransform;
ctx.setTransform = function(a,b,c,d,e,f){
xform.a = a;
xform.b = b;
xform.c = c;
xform.d = d;
xform.e = e;
xform.f = f;
return setTransform.call(ctx,a,b,c,d,e,f);
};
var pt = svg.createSVGPoint();
ctx.transformedPoint = function(x,y){
pt.x=x; pt.y=y;
return pt.matrixTransform(xform.inverse());
}
}
/* zoomIn event */ /* zoomIn event */
function zoomIn() { function zoomIn() {
userScale += scaleDelta; userScale += scaleDelta;
if(userScale > 4){ if(userScale > 4){
userScale = 4; userScale = 4;
...@@ -2516,11 +2662,47 @@ function zoomIn() { ...@@ -2516,11 +2662,47 @@ function zoomIn() {
changeScale(userScale); changeScale(userScale);
flip(); flip();
/* zoom video */ /* zoom video */
zoomVideo(); zoomVideo();
checkDisableButtonZoom();
}; };
function checkDisableButtonZoom(){
if(userScale >= 4){
$('#zoomin').unbind('click');
$('#zoomin').removeClass();
$('#zoomin').addClass('expansion_off');
$("#zoomin").css('cursor', 'default');
}else{
$('#zoomin').unbind('click');
$('#zoomin').bind('click',zoomIn);
$('#zoomin').removeClass();
$('#zoomin').addClass('expansion');
$("#zoomin").css('cursor', 'pointer');
}
if(userScale <= 1){
$('#zoomout').unbind('click');
$('#zoomout').removeClass();
$('#zoomout').addClass('reduction_off');
$("#zoomout").css('cursor', 'default');
}else{
$('#zoomout').unbind('click');
$('#zoomout').bind('click',zoomOut);
$('#zoomout').removeClass();
$('#zoomout').addClass('reduction');
$("#zoomout").css('cursor', 'pointer');
}
}
/* zoomOut event */ /* zoomOut event */
function zoomOut() { function zoomOut() {
userScale -= scaleDelta; userScale -= scaleDelta;
...@@ -2533,6 +2715,8 @@ function zoomOut() { ...@@ -2533,6 +2715,8 @@ function zoomOut() {
/* zoom video */ /* zoom video */
zoomVideo() zoomVideo()
checkDisableButtonZoom();
}; };
/* restore screen size */ /* restore screen size */
...@@ -2540,16 +2724,18 @@ function screenFit() { ...@@ -2540,16 +2724,18 @@ function screenFit() {
var canvas = document.getElementById('main'); var canvas = document.getElementById('main');
var offScreen = document.getElementById('offscreen'); var offScreen = document.getElementById('offscreen');
context_main.clearRect(0,0,canvas_main.width,canvas_main.height);
srcRect = new Rect(0, 0, offScreen.width, offScreen.height); srcRect = new Rect(0, 0, offScreen.width, offScreen.height);
userScale = 1; userScale = 1;
moveX = 0; moveX = 0;
moveY = 0; moveY = 0;
flip(); flip();
/* zoom video */ /* zoom video */
zoomVideo(); zoomVideo();
checkDisableButtonZoom();
}; };
...@@ -2561,21 +2747,64 @@ function changeScale(scale) { ...@@ -2561,21 +2747,64 @@ function changeScale(scale) {
var sc = srcRect.center(); var sc = srcRect.center();
var sw = offScreen.width, sh = offScreen.height; var sw = offScreen.width, sh = offScreen.height;
sw /= scale;
sh /= scale; var width = offscreen.width;
var height = offscreen.height;
// srcRect.left = sc.x - Math.floor(sw / 2); var aspect = offscreen.width / offscreen.height;
// srcRect.top = sc.y - Math.floor(sh / 2); if(canvas.width > canvas.height) {
// srcRect.right = srcRect.left + sw; height = canvas.height;
// srcRect.bottom = srcRect.top + sh; width = height * aspect;
// srcRect.width = sw; if(width > canvas.width) {
// srcRect.height = sh; width = canvas.width;
height = width / aspect;
}
if(height > canvas.height){
height = canvas.height;
width = height / aspect;
}
} else {
width = canvas.width;
height = width / aspect;
}
if(width < canvas.width){
//if(width >= height){
width = width * scale;
if(width > canvas.width){
sw /= scale;
sh = sw / (canvas.width / canvas.height);
}else{
sh /= scale;
}
//}else if(height <= canvas.height){
} else if(height < canvas.height){
height = height * scale;
if(height > canvas.height){
sh /= scale;
sw = sh / (canvas.height / canvas.width);
}else{
sw /= scale;
}
}else{
sh /= scale;
sw /= scale;
}
srcRect.left = sc.x - Math.round(sw / 2); srcRect.left = sc.x - Math.round(sw / 2);
srcRect.top = sc.y - Math.round(sh / 2); srcRect.top = sc.y - Math.round(sh / 2);
srcRect.right = Math.round(srcRect.left + sw); srcRect.right = Math.round(srcRect.left + sw);
srcRect.bottom = Math.round(srcRect.top + sh); srcRect.bottom = Math.round(srcRect.top + sh);
srcRect.width = srcRect.right - srcRect.left; srcRect.width = srcRect.right - srcRect.left;
srcRect.height = srcRect.bottom - srcRect.top; srcRect.height = srcRect.bottom - srcRect.top;
}; };
/* change Scale screen*/ /* change Scale screen*/
......
...@@ -91,15 +91,28 @@ function bodyClickFunction(event) { ...@@ -91,15 +91,28 @@ function bodyClickFunction(event) {
// Check mouse is in rectangle of searching panel // Check mouse is in rectangle of searching panel
if ($('#header-searchbox').css('display') != "none") { if ($('#header-searchbox').css('display') != "none") {
if (event.targetTouches[0].clientX >= $('#header-searchbox').position().left
&& event.targetTouches[0].clientX <= ($('#header-searchbox').position().left + $('#header-searchbox').width())
&& event.targetTouches[0].clientY >= $('#header-searchbox').position().top
&& event.targetTouches[0].clientY <= ($('#header-searchbox').position().top + $('#header-searchbox').height())) {
isHoverOn = true; var currPosX, currPosY;
var avwUserEnvObj = new UserEnvironment();
if (avwUserEnvObj.os == 'android') {
//$("#searchbox-key").val(event.targetTouches[0].pageX + "_" + $('#header-searchbox').position().left + ":" + ($('#header-searchbox').position().left + $('#header-searchbox').width()));
currPosX = event.targetTouches[0].pageX;
currPosY = event.targetTouches[0].pageY;
} }
else { else {
currPosX = event.targetTouches[0].clientX;
currPosY = event.targetTouches[0].clientY;
}
if (currPosX >= $('#header-searchbox').position().left
&& currPosX <= ($('#header-searchbox').position().left + $('#header-searchbox').width())
&& currPosY >= $('#header-searchbox').position().top
&& currPosY <= ($('#header-searchbox').position().top + $('#header-searchbox').height())) {
isHoverOn = true;
}
else {
isHoverOn = false; isHoverOn = false;
$('#header-searchbox').hide(); $('#header-searchbox').hide();
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment