Merge pull request #12099 from stari4ek/v3-12097-video-android-search-path

Fixed: #12097 VideoPlayer on Android ignores search paths
This commit is contained in:
子龙山人 2015-06-08 17:22:14 +08:00
commit 57e92df8ee
2 changed files with 4 additions and 9 deletions

View File

@ -32,6 +32,7 @@
#include "jni/JniHelper.h" #include "jni/JniHelper.h"
#include "base/CCDirector.h" #include "base/CCDirector.h"
#include "base/CCEventListenerKeyboard.h" #include "base/CCEventListenerKeyboard.h"
#include "platform/CCFileUtils.h"
//----------------------------------------------------------------------------------------------------------- //-----------------------------------------------------------------------------------------------------------
#define CLASS_NAME "org/cocos2dx/lib/Cocos2dxVideoHelper" #define CLASS_NAME "org/cocos2dx/lib/Cocos2dxVideoHelper"
@ -193,7 +194,7 @@ VideoPlayer::~VideoPlayer()
void VideoPlayer::setFileName(const std::string& fileName) void VideoPlayer::setFileName(const std::string& fileName)
{ {
_videoURL = fileName; _videoURL = FileUtils::getInstance()->fullPathForFilename(fileName);
_videoSource = VideoPlayer::Source::FILENAME; _videoSource = VideoPlayer::Source::FILENAME;
setVideoURLJNI(_videoPlayerIndex, (int)Source::FILENAME,_videoURL); setVideoURLJNI(_videoPlayerIndex, (int)Source::FILENAME,_videoURL);
} }

View File

@ -55,7 +55,6 @@ using namespace cocos2d::experimental::ui;
-(void) videoFinished:(NSNotification*) notification; -(void) videoFinished:(NSNotification*) notification;
-(void) playStateChange; -(void) playStateChange;
+(NSString*) fullPathFromRelativePath:(NSString*) relPath;
@end @end
@ -138,8 +137,7 @@ using namespace cocos2d::experimental::ui;
self.moviePlayer.movieSourceType = MPMovieSourceTypeStreaming; self.moviePlayer.movieSourceType = MPMovieSourceTypeStreaming;
[self.moviePlayer setContentURL:[NSURL URLWithString:@(videoUrl.c_str())]]; [self.moviePlayer setContentURL:[NSURL URLWithString:@(videoUrl.c_str())]];
} else { } else {
NSString *path = [UIVideoViewWrapperIos fullPathFromRelativePath:@(videoUrl.c_str())]; self.moviePlayer = [[[MPMoviePlayerController alloc] initWithContentURL:[NSURL fileURLWithPath:@(videoUrl.c_str())]] autorelease];
self.moviePlayer = [[[MPMoviePlayerController alloc] initWithContentURL:[NSURL fileURLWithPath:path]] autorelease];
self.moviePlayer.movieSourceType = MPMovieSourceTypeFile; self.moviePlayer.movieSourceType = MPMovieSourceTypeFile;
} }
self.moviePlayer.allowsAirPlay = false; self.moviePlayer.allowsAirPlay = false;
@ -260,10 +258,6 @@ using namespace cocos2d::experimental::ui;
} }
} }
+(NSString*) fullPathFromRelativePath:(NSString*) relPath
{
return [NSString stringWithCString: cocos2d::FileUtils::getInstance()->fullPathForFilename(std::string([relPath UTF8String])).c_str() encoding: [NSString defaultCStringEncoding]];
}
@end @end
//------------------------------------------------------------------------------------------------------------ //------------------------------------------------------------------------------------------------------------
@ -293,7 +287,7 @@ VideoPlayer::~VideoPlayer()
void VideoPlayer::setFileName(const std::string& fileName) void VideoPlayer::setFileName(const std::string& fileName)
{ {
_videoURL = fileName; _videoURL = FileUtils::getInstance()->fullPathForFilename(fileName);
_videoSource = VideoPlayer::Source::FILENAME; _videoSource = VideoPlayer::Source::FILENAME;
[((UIVideoViewWrapperIos*)_videoView) setURL:(int)_videoSource :_videoURL]; [((UIVideoViewWrapperIos*)_videoView) setURL:(int)_videoSource :_videoURL];
} }