Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
C
check
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abook_web
check
Commits
999c601a
Commit
999c601a
authored
Dec 12, 2014
by
Masaru Abe
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
パフォーマンス改善 動画キャッシュ関連
parent
4a385f13
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
155 additions
and
35 deletions
+155
-35
abvw/common/js/avweb.js
+1
-1
abvw/js/contentview.js
+9
-5
abvw/js/contentview_CreateObjects.js
+0
-0
abvw/js/contentview_Events.js
+15
-2
abvw/js/contentview_FileSystem.js
+130
-27
No files found.
abvw/common/js/avweb.js
View file @
999c601a
...
...
@@ -631,7 +631,7 @@ function avwGrabContentPageImage(accountPath, params, success, error) {
//フィアルシステムが有効であればキャッシュ
if
(
CONTENTVIEW_FILESYSTEM
.
fs
!=
null
){
var
fileName
=
"page_"
+
params
.
pageNo
+
".dat"
;
CONTENTVIEW_FILESYSTEM
.
saveFile
(
params
.
contentId
,
fileName
,
src
);
CONTENTVIEW_FILESYSTEM
.
save
Page
File
(
params
.
contentId
,
fileName
,
src
);
}
if
(
success
)
{
...
...
abvw/js/contentview.js
View file @
999c601a
...
...
@@ -4955,7 +4955,7 @@ function showControlsVideo(target) {
};
/* show video*/
function
showVideoObject
(
x
,
y
,
width
,
height
,
src
,
isFullscreen
)
{
function
showVideoObject
(
x
,
y
,
width
,
height
,
src
,
isFullscreen
,
isAddKey
)
{
var
pt1
=
imageToScreen
(
x
,
y
);
var
pt2
=
imageToScreen
(
x
+
width
,
y
+
height
);
...
...
@@ -4968,6 +4968,10 @@ function showVideoObject(x, y, width, height, src, isFullscreen) {
//getPosVideo(x, y, (pt2.x - pt1.x), (pt2.y - pt1.y));
getPosVideo
(
x
,
y
,
width
,
height
);
if
(
!
isFullscreen
&&
isAddKey
){
src
=
src
+
'&key='
+
(
new
Date
()).
toIdString
();
}
if
(
isFullscreen
===
false
)
{
$
(
'#playvideo'
).
attr
(
'z-order'
,
'1000'
);
$
(
'#playvideo'
).
css
(
'left'
,
pt1
.
x
+
'px'
);
...
...
@@ -4979,8 +4983,8 @@ function showVideoObject(x, y, width, height, src, isFullscreen) {
'width="'
+
(
pt2
.
x
-
pt1
.
x
)
+
'" '
+
'height="'
+
(
pt2
.
y
-
pt1
.
y
)
+
'" '
+
'autoplay controls loop>'
+
' <source src="'
+
src
+
'
&key='
+
(
new
Date
()).
toIdString
()
+
'
" type="video/mp4"> '
+
' <source src="'
+
src
+
'
&key='
+
(
new
Date
()).
toIdString
()
+
'
" type="video/ogg"> '
+
' <source src="'
+
src
+
'" type="video/mp4"> '
+
' <source src="'
+
src
+
'" type="video/ogg"> '
+
'</video>'
);
}
else
{
...
...
@@ -4988,8 +4992,8 @@ function showVideoObject(x, y, width, height, src, isFullscreen) {
'width="'
+
(
pt2
.
x
-
pt1
.
x
)
+
'" '
+
'height="'
+
(
pt2
.
y
-
pt1
.
y
)
+
'" '
+
'autoplay controls>'
+
' <source src="'
+
src
+
'
&key='
+
(
new
Date
()).
toIdString
()
+
'
" type="video/mp4"> '
+
' <source src="'
+
src
+
'
&key='
+
(
new
Date
()).
toIdString
()
+
'
" type="video/ogg"> '
+
' <source src="'
+
src
+
'" type="video/mp4"> '
+
' <source src="'
+
src
+
'" type="video/ogg"> '
+
'</video>'
);
}
...
...
abvw/js/contentview_CreateObjects.js
View file @
999c601a
This diff is collapsed.
Click to expand it.
abvw/js/contentview_Events.js
View file @
999c601a
...
...
@@ -868,6 +868,8 @@ function onUnlock() {
function
onClick_CanvasMain
(
event
)
{
console
.
log
(
"onClick_CanvasMain"
);
event
.
preventDefault
();
if
(
isLoadingObject
){
...
...
@@ -1493,6 +1495,8 @@ function resetNaviAction(){
function
onTouchstart
(
evt
){
console
.
log
(
"onTouchstart _isClick:"
+
_isClick
);
//evt.preventDefault();
if
(
ClientData
.
IsAddingMarking
()
==
true
){
...
...
@@ -1540,7 +1544,6 @@ function onTouchstart(evt){
_touchFirstPos
=
null
;
if
(
_bWin8TouchEnabled
){
_bufferPoints
=
[];
if
(
_startPoints
.
length
==
0
){
// start navi page case
...
...
@@ -1728,6 +1731,8 @@ var isPreventClick = false;
function
onTouchmove
(
evt
){
console
.
log
(
"onTouchmove isClick:"
+
_isClick
);
//evt.preventDefault();
if
(
ClientData
.
IsAddingMarking
()
==
true
){
...
...
@@ -1931,11 +1936,15 @@ function onTouchmove(evt){
}
}
else
{
_isClick
=
false
;
//
_isClick = false;
// for android or ipad
touch1
=
evt
.
touches
[
0
];
touch2
=
evt
.
touches
[
1
];
if
(
touch2
!=
null
){
_isClick
=
false
;
}
if
(
_3dAnimate
){
var
imagePt
=
screenToImage
(
touch1
.
pageX
,
touch1
.
pageY
);
...
...
@@ -2006,6 +2015,8 @@ function onTouchmove(evt){
function
onTouchend
(
evt
){
console
.
log
(
"onTouchend isClick:"
+
_isClick
);
//evt.preventDefault();
if
(
ClientData
.
IsAddingMarking
()
==
true
){
...
...
@@ -2080,8 +2091,10 @@ function onTouchend(evt){
touchStartedTime
=
0
;
if
(
_moveNum
==
2
){
nextPage_click
();
return
;
}
else
if
(
_moveNum
==
-
2
){
prevPage_click
();
return
;
}
else
{
correctCanvasPosition
();
}
...
...
abvw/js/contentview_FileSystem.js
View file @
999c601a
...
...
@@ -2,16 +2,10 @@
//名前空間用のオブジェクトを用意する
var
CONTENTVIEW_FILESYSTEM
=
{};
$
(
function
()
{
CONTENTVIEW_FILESYSTEM
.
isXhrBusy
=
false
;
//CONTENTVIEW_FILESYSTEM.fs = null;
//window.requestFileSystem = window.requestFileSystem || window.webkitRequestFileSystem;
//// Initiate filesystem on page load.
//if (window.requestFileSystem) {
// CONTENTVIEW_FILESYSTEM.initFS();
//}
});
//$(function () {
//});
CONTENTVIEW_FILESYSTEM
.
initFS
=
function
(
func
)
{
...
...
@@ -32,21 +26,32 @@ CONTENTVIEW_FILESYSTEM.initFS = function( func ) {
function
(
filesystem
)
{
console
.
log
(
"initFS window.requestFileSystem"
);
CONTENTVIEW_FILESYSTEM
.
fs
=
filesystem
;
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getDirectory
(
'abook'
,
{
create
:
true
},
null
,
CONTENTVIEW_FILESYSTEM
.
errorHandler
);
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getDirectory
(
'abook'
,
{
create
:
true
},
function
(
dirEntry
)
{
// /abookディレクトリ作成成功
if
(
func
!=
null
){
func
();
}
},
CONTENTVIEW_FILESYSTEM
.
errorHandler
);
},
function
(
err
){
// 失敗時のコールバック関数
CONTENTVIEW_FILESYSTEM
.
errorHandler
(
err
);
if
(
func
!=
null
){
func
();
}
}
);
};
CONTENTVIEW_FILESYSTEM
.
saveFile
=
function
(
contentId
,
fileName
,
data
)
{
CONTENTVIEW_FILESYSTEM
.
save
Page
File
=
function
(
contentId
,
fileName
,
data
)
{
if
(
!
CONTENTVIEW_FILESYSTEM
.
fs
)
{
console
.
log
(
'CONTENTVIEW_FILESYSTEM.fs is null. id='
+
contentId
);
return
;
}
...
...
@@ -56,7 +61,7 @@ CONTENTVIEW_FILESYSTEM.saveFile = function(contentId, fileName, data) {
'/abook/'
+
contentId
,
{
create
:
true
},
function
(
dirEntry
)
{
// /abook/contentId ディレクトリ作成成功
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getFile
(
'/abook/'
+
contentId
+
"/"
+
fileName
,
{
create
:
true
},
...
...
@@ -71,10 +76,6 @@ CONTENTVIEW_FILESYSTEM.saveFile = function(contentId, fileName, data) {
};
var
blobData
=
new
Blob
([
data
],
{
type
:
"text/plain"
});
fileWriter
.
write
(
blobData
);
//var bb = new BlobBuilder(); // Note: window.WebKitBlobBuilder in Chrome 12.
//bb.append(data);
//fileWriter.write(bb.getBlob('text/plain'));
}
);
},
...
...
@@ -114,21 +115,26 @@ CONTENTVIEW_FILESYSTEM.checkUpdate = function(contentId, data, func) {
if
(
!
CONTENTVIEW_FILESYSTEM
.
fs
)
{
console
.
log
(
'CONTENTVIEW_FILESYSTEM.fs is null. id='
+
contentId
);
//おまじない ajaxカウントをインクリする必要有り
nAjaxLoad
++
;
//ファンクションがあれば実行
if
(
func
!=
null
){
func
(
data
);
}
return
;
}
//既にjson.txtが存在するか
var
fileName
=
contentID
+
"/json.txt"
;
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getFile
(
'/abook/'
+
fileName
,
{
create
:
false
},
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getFile
(
'/abook/'
+
fileName
,
{
create
:
false
},
function
(
fileEntry
){
fileEntry
.
file
(
function
(
file
){
var
reader
=
new
FileReader
();
reader
.
onloadend
=
function
(
e
)
{
console
.
log
(
"read Json.txt"
);
//console.log(e.target.result);
//JSONに戻す
var
jsonObjOld
=
JSON
.
parse
(
e
.
target
.
result
);
...
...
@@ -136,9 +142,9 @@ CONTENTVIEW_FILESYSTEM.checkUpdate = function(contentId, data, func) {
console
.
log
(
"OLD:"
+
jsonObjOld
.
contentData
.
lastDeliveryDate
);
console
.
log
(
"NEW:"
+
data
.
contentData
.
lastDeliveryDate
);
if
(
jsonObjOld
.
contentData
.
lastDeliveryDate
!=
data
.
contentData
.
lastDeliveryDate
){
console
.
log
(
"違う"
);
//ディレクトリ消し
console
.
log
(
"Update Content."
);
//ディレクトリ消し
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getDirectory
(
'/abook/'
+
contentId
,
{},
...
...
@@ -162,9 +168,12 @@ CONTENTVIEW_FILESYSTEM.checkUpdate = function(contentId, data, func) {
fileWriter
.
onwriteend
=
function
(
e
)
{
console
.
log
(
'JSON書き込み完了'
);
//
ファンクション実行
//
おまじない ajaxカウントをインクリする必要有り
nAjaxLoad
++
;
//ファンクション実行
if
(
func
!=
null
){
func
(
data
);
}
};
fileWriter
.
onerror
=
function
(
e
)
{
...
...
@@ -190,10 +199,16 @@ CONTENTVIEW_FILESYSTEM.checkUpdate = function(contentId, data, func) {
);
}
else
{
//おまじない ajaxカウントをインクリする必要有り
nAjaxLoad
++
;
//ファンクション実行
if
(
func
!=
null
){
func
(
data
);
}
}
};
reader
.
readAsText
(
file
);
}
...
...
@@ -202,8 +217,7 @@ CONTENTVIEW_FILESYSTEM.checkUpdate = function(contentId, data, func) {
function
(
err
){
// 失敗時のコールバック関数
console
.
log
(
"NotRead json.txt"
);
//書き込む
//パス作成
//書き込む パス作成
//var path = "/abook/" + contentId + "/" + fileName;
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getDirectory
(
'/abook/'
+
contentId
,
...
...
@@ -219,9 +233,12 @@ CONTENTVIEW_FILESYSTEM.checkUpdate = function(contentId, data, func) {
fileWriter
.
onwriteend
=
function
(
e
)
{
console
.
log
(
'JSON書き込み完了'
);
//ファンクション実行
//おまじない ajaxカウントをインクリする必要有り
nAjaxLoad
++
;
//ファンクション実行
if
(
func
!=
null
){
func
(
data
);
}
};
fileWriter
.
onerror
=
function
(
e
)
{
...
...
@@ -245,6 +262,92 @@ CONTENTVIEW_FILESYSTEM.checkUpdate = function(contentId, data, func) {
};
CONTENTVIEW_FILESYSTEM
.
showVideoObjectCache
=
function
(
x
,
y
,
width
,
height
,
src
,
isFullscreen
,
contentId
,
resourceId
){
console
.
log
(
'CONTENTVIEW_FILESYSTEM.showVideoObjectCache'
);
if
(
!
CONTENTVIEW_FILESYSTEM
.
fs
)
{
console
.
log
(
'CONTENTVIEW_FILESYSTEM.fs is null. id='
+
contentId
);
showVideoObject
(
x
,
y
,
width
,
height
,
src
,
isFullscreen
,
true
);
return
;
}
//キャッシュが存在するか確認
var
fileName
=
contentID
+
"/res_"
+
resourceId
+
".dat"
;
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getFile
(
'/abook/'
+
fileName
,
{
create
:
false
},
function
(
fileEntry
){
fileEntry
.
file
(
function
(
file
){
console
.
log
(
"read cache"
)
var
url
=
window
.
URL
||
window
.
webkitURL
;
var
resSrc
=
url
.
createObjectURL
(
file
);
showVideoObject
(
x
,
y
,
width
,
height
,
resSrc
,
isFullscreen
,
false
);
}
);
},
function
(
err
){
// 失敗時のコールバック関数
console
.
log
(
"NotRead FileSystem"
);
//キャッシュ化
var
xhr
=
new
XMLHttpRequest
();
xhr
.
onreadystatechange
=
function
(){
if
(
this
.
readyState
==
4
&&
this
.
status
==
200
){
CONTENTVIEW_FILESYSTEM
.
isXhrBusy
=
false
;
$
(
'#divImageLoading'
).
css
(
'display'
,
'none'
);
//this.response is what you're looking for
console
.
log
(
this
.
response
,
typeof
this
.
response
);
CONTENTVIEW_FILESYSTEM
.
fs
.
root
.
getFile
(
'/abook/'
+
fileName
,
{
create
:
true
},
function
(
fileEntry
){
fileEntry
.
createWriter
(
function
(
fileWriter
)
{
fileWriter
.
onwriteend
=
function
(
e
)
{
console
.
log
(
'RES書き込み完了'
);
};
fileWriter
.
onerror
=
function
(
e
)
{
console
.
log
(
'RES書き込みエラー: '
+
e
.
toString
());
};
var
blobData
=
new
Blob
([
xhr
.
response
],
{
type
:
"application/octet-stream"
});
//var blobData = new Blob([this.response], {type:"video/mp4"});
fileWriter
.
write
(
blobData
);
}
);
},
CONTENTVIEW_FILESYSTEM
.
errorHandler
);
}
else
{
if
(
this
.
readyState
==
2
){
$
(
'#divImageLoading'
).
css
(
'display'
,
'block'
);
}
console
.
log
(
"onreadystatechange:"
+
this
.
readyState
+
" "
+
this
.
status
);
}
}
if
(
!
CONTENTVIEW_FILESYSTEM
.
isXhrBusy
){
xhr
.
open
(
'GET'
,
src
);
xhr
.
responseType
=
'blob'
;
xhr
.
send
();
CONTENTVIEW_FILESYSTEM
.
isXhrBusy
=
true
;
}
else
{
console
.
log
(
"xhr is busy."
);
}
//タグは書き出し
showVideoObject
(
x
,
y
,
width
,
height
,
src
,
isFullscreen
,
true
);
}
);
}
CONTENTVIEW_FILESYSTEM
.
errorHandler
=
function
(
e
)
{
var
msg
=
''
;
switch
(
e
.
code
)
{
...
...
@@ -268,6 +371,6 @@ CONTENTVIEW_FILESYSTEM.errorHandler = function(e) {
break
;
};
//CONTENTVIEW_FILESYSTEM.fs = null;
alert
(
'Error: '
+
msg
);
alert
(
'
FileSystemAPI
Error: '
+
msg
);
};
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment