fixed bugs, added progress saving, setted MIN API to 19
This commit is contained in:
		
							parent
							
								
									3e3daf6c0c
								
							
						
					
					
						commit
						ba9cba22eb
					
				| @ -2,9 +2,55 @@ | |||||||
| 
 | 
 | ||||||
| #include "main_code.h" | #include "main_code.h" | ||||||
| 
 | 
 | ||||||
|  | JavaVM* localJavaVirtualMachine = 0; | ||||||
|  | 
 | ||||||
|  | JNIEXPORT void JNICALL Java_fishrungames_doublehitballs_JniWrapper_SetJavaVM(JNIEnv * env, jobject obj) | ||||||
|  | { | ||||||
|  |     env->GetJavaVM(&localJavaVirtualMachine); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| JNIEXPORT void JNICALL Java_fishrungames_doublehitballs_JniWrapper_Init(JNIEnv * env, jobject obj,  jint width, jint height) | JNIEXPORT void JNICALL Java_fishrungames_doublehitballs_JniWrapper_Init(JNIEnv * env, jobject obj,  jint width, jint height) | ||||||
| { | { | ||||||
| 	JniInitApp<TMyApplication>(width, height, width, height); | 	JniInitApp<TMyApplication>(width, height, width, height); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | std::stringstream LoadFileFromAndroid(const std::string& fileName) | ||||||
|  | { | ||||||
|  |     *Console << "LoadFileFromAndroid called \n"; | ||||||
| 
 | 
 | ||||||
|  |     JNIEnv* jEnv; | ||||||
|  |     localJavaVirtualMachine->GetEnv((void**)&jEnv, JNI_VERSION_1_4); | ||||||
|  | 
 | ||||||
|  |     jclass jniWrapper = jEnv->FindClass("fishrungames/doublehitballs/JniWrapper"); | ||||||
|  | 
 | ||||||
|  |     jstring jFileName = jEnv->NewStringUTF(fileName.c_str()); | ||||||
|  | 
 | ||||||
|  |     jmethodID jLoadFile = jEnv->GetStaticMethodID(jniWrapper, "LoadFile", "(Ljava/lang/String;)Ljava/lang/String;"); | ||||||
|  | 
 | ||||||
|  |     jstring jFileContent = (jstring)jEnv->CallStaticObjectMethod(jniWrapper, jLoadFile, jFileName); | ||||||
|  | 
 | ||||||
|  |     jboolean jCopy = false; | ||||||
|  |     std::stringstream ss; | ||||||
|  |     ss << jEnv->GetStringUTFChars(jFileContent, &jCopy); | ||||||
|  | 
 | ||||||
|  |     *Console << ss.str(); | ||||||
|  | 
 | ||||||
|  |     return ss; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void SaveFileToAndroid(const std::string& fileName, const std::string& fileContent) | ||||||
|  | { | ||||||
|  | 	*Console << "SaveFileToAndroid called \n"; | ||||||
|  | 
 | ||||||
|  | 	JNIEnv* jEnv; | ||||||
|  | 	localJavaVirtualMachine->GetEnv((void**)&jEnv, JNI_VERSION_1_4); | ||||||
|  | 
 | ||||||
|  |     jclass jniWrapper = jEnv->FindClass("fishrungames/doublehitballs/JniWrapper"); | ||||||
|  | 
 | ||||||
|  |     jstring jFileName = jEnv->NewStringUTF(fileName.c_str()); | ||||||
|  |     jstring jFileContent = jEnv->NewStringUTF(fileContent.c_str()); | ||||||
|  | 
 | ||||||
|  |     jmethodID jSaveFile = jEnv->GetStaticMethodID(jniWrapper, "SaveFile", "(Ljava/lang/String;Ljava/lang/String;)V"); | ||||||
|  | 
 | ||||||
|  | 	jEnv->CallStaticVoidMethod(jniWrapper, jSaveFile, jFileName, jFileContent); | ||||||
|  | } | ||||||
							
								
								
									
										8
									
								
								game/android_api.h
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										8
									
								
								game/android_api.h
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @ -8,6 +8,9 @@ | |||||||
| #include <GLES2/gl2.h> | #include <GLES2/gl2.h> | ||||||
| #include <GLES2/gl2ext.h> | #include <GLES2/gl2ext.h> | ||||||
| 
 | 
 | ||||||
|  | #include <string> | ||||||
|  | #include <sstream> | ||||||
|  | 
 | ||||||
| #include "boost/shared_ptr.hpp" | #include "boost/shared_ptr.hpp" | ||||||
| 
 | 
 | ||||||
| #include "main_code.h" | #include "main_code.h" | ||||||
| @ -18,8 +21,13 @@ using namespace SE; | |||||||
| 
 | 
 | ||||||
| extern "C" | extern "C" | ||||||
| { | { | ||||||
|  |     JNIEXPORT void JNICALL Java_fishrungames_doublehitballs_JniWrapper_SetJavaVM(JNIEnv * env, jobject obj); | ||||||
|  | 
 | ||||||
|     JNIEXPORT void JNICALL Java_fishrungames_doublehitballs_JniWrapper_Init(JNIEnv * env, jobject obj,  jint width, jint height); |     JNIEXPORT void JNICALL Java_fishrungames_doublehitballs_JniWrapper_Init(JNIEnv * env, jobject obj,  jint width, jint height); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | std::stringstream LoadFileFromAndroid(const std::string& fileName); | ||||||
|  | 
 | ||||||
|  | void SaveFileToAndroid(const std::string& fileName, const std::string& fileContent); | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -1328,7 +1328,6 @@ void TGameLevel::Update(size_t dt) | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|      |      | ||||||
|      |  | ||||||
|     if (noMoreBlocks && LevelState != CONST_LEVELSTATE_FINISH_FREEZE) |     if (noMoreBlocks && LevelState != CONST_LEVELSTATE_FINISH_FREEZE) | ||||||
|     { |     { | ||||||
| 		Application->SaveUserProgress(levelStar, levelIndex); | 		Application->SaveUserProgress(levelStar, levelIndex); | ||||||
|  | |||||||
| @ -5,6 +5,7 @@ | |||||||
| #include <string> | #include <string> | ||||||
| 
 | 
 | ||||||
| #include "include/Engine.h" | #include "include/Engine.h" | ||||||
|  | #include "android_api.h" | ||||||
| 
 | 
 | ||||||
| #include "menucode.h" | #include "menucode.h" | ||||||
| 
 | 
 | ||||||
| @ -55,7 +56,7 @@ TMyApplication* Application; | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| int currentStar; | int currentStar; | ||||||
| std::vector<int> finishedLevels; | int currentLevel; | ||||||
| 
 | 
 | ||||||
| void TMyApplication::LoadUserProgress() | void TMyApplication::LoadUserProgress() | ||||||
| { | { | ||||||
| @ -63,17 +64,22 @@ void TMyApplication::LoadUserProgress() | |||||||
| 
 | 
 | ||||||
| 	try | 	try | ||||||
| 	{ | 	{ | ||||||
|  | #ifdef TARGET_WIN32 | ||||||
| 		boost::property_tree::json_parser::read_json(ST::PathToResources + "levels/user_progress.json", userProgressJson); | 		boost::property_tree::json_parser::read_json(ST::PathToResources + "levels/user_progress.json", userProgressJson); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #ifdef TARGET_ANDROID | ||||||
|  |         auto ss = LoadFileFromAndroid("user_progress.json"); | ||||||
|  |         boost::property_tree::json_parser::read_json(ss, userProgressJson); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|         currentStar = userProgressJson.get<int>("currentStar"); |         currentStar = userProgressJson.get<int>("currentStar"); | ||||||
| 		for (auto& index : userProgressJson.get_child("finishedLevels")) |         currentLevel = userProgressJson.get<int>("currentLevel"); | ||||||
| 		{ |  | ||||||
| 			finishedLevels.push_back(index.second.get_value<int>()); |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| 	catch (...) | 	catch (...) | ||||||
| 	{ | 	{ | ||||||
| 		currentStar = 0; | 		currentStar = 0; | ||||||
| 		finishedLevels.clear(); |         currentLevel = 0; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -84,38 +90,45 @@ void TMyApplication::SaveUserProgress(int levelStar, int levelIndex) | |||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	auto iter = std::find(finishedLevels.begin(), finishedLevels.end(), levelIndex); |     if (levelIndex < currentLevel) | ||||||
| 	if (iter != finishedLevels.end()) |  | ||||||
|     { |     { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 	finishedLevels.push_back(levelIndex); | 	if (currentStar == Menu.GalaxMenu.galaxies[0].Stars.size()) | ||||||
| 
 |  | ||||||
| 	if (finishedLevels.size() == Menu.GalaxMenu.galaxies[0].Stars[currentStar].selectionMenu.gameLevels.size()) |  | ||||||
| 	{ | 	{ | ||||||
| 		finishedLevels.clear(); | 		return; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 		if (currentStar < Menu.GalaxMenu.galaxies[0].Stars.size() - 1) | 	currentLevel += 1; | ||||||
|  | 
 | ||||||
|  | 	if (currentLevel == Menu.GalaxMenu.galaxies[0].Stars[currentStar].selectionMenu.gameLevels.size()) | ||||||
| 	{ | 	{ | ||||||
|  | 		currentLevel = 0; | ||||||
|  | 
 | ||||||
| 		currentStar += 1; | 		currentStar += 1; | ||||||
|  | 
 | ||||||
|  | 		if (currentStar == Menu.GalaxMenu.galaxies[0].Stars.size()) | ||||||
|  | 		{ | ||||||
|  | 
 | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	boost::property_tree::ptree userProgressJson; | 	boost::property_tree::ptree userProgressJson; | ||||||
| 
 | 
 | ||||||
| 	userProgressJson.put("currentStar", currentStar); | 	userProgressJson.put("currentStar", currentStar); | ||||||
|  |     userProgressJson.put("currentLevel", currentLevel); | ||||||
| 
 | 
 | ||||||
| 	boost::property_tree::ptree finishedLevelsTree; | #ifdef TARGET_WIN32 | ||||||
| 	for (int index : finishedLevels) |  | ||||||
| 	{ |  | ||||||
| 		boost::property_tree::ptree finishedLevel; |  | ||||||
| 		finishedLevel.put_value(index); |  | ||||||
| 		finishedLevelsTree.push_back(std::make_pair("", finishedLevel)); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	userProgressJson.put_child("finishedLevels", finishedLevelsTree); |  | ||||||
|     boost::property_tree::json_parser::write_json(ST::PathToResources + "levels/user_progress.json", userProgressJson); |     boost::property_tree::json_parser::write_json(ST::PathToResources + "levels/user_progress.json", userProgressJson); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | #ifdef TARGET_ANDROID | ||||||
|  |     std::stringstream ss; | ||||||
|  |     boost::property_tree::json_parser::write_json(ss, userProgressJson); | ||||||
|  | 
 | ||||||
|  |     SaveFileToAndroid("user_progress.json", ss.str()); | ||||||
|  | #endif | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -203,7 +216,6 @@ void TMyApplication::InnerInit() | |||||||
| 	else { | 	else { | ||||||
| 		std::cout << "menu error" << std::endl; | 		std::cout << "menu error" << std::endl; | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void TMyApplication::InnerDeinit() | void TMyApplication::InnerDeinit() | ||||||
| @ -607,9 +619,11 @@ void TMyApplication::LoadGalaxyUi() | |||||||
| 
 | 
 | ||||||
| 	modal_background->onMouseUpSignal.connect( | 	modal_background->onMouseUpSignal.connect( | ||||||
| 		[modal_background, this](Vector2f v, int i) { | 		[modal_background, this](Vector2f v, int i) { | ||||||
|  |             PerformInMainThreadAsync([modal_background, this]() { | ||||||
|                 modal_background->setVisibility(false); |                 modal_background->setVisibility(false); | ||||||
|                 Menu.GalaxMenu.setTimerActivity(false); |                 Menu.GalaxMenu.setTimerActivity(false); | ||||||
|             }); |             }); | ||||||
|  | 	}); | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -686,12 +700,14 @@ void TMyApplication::SetupGalaxyUi(size_t levelStar) | |||||||
| 				 | 				 | ||||||
| 				currentLevelButton->onMouseUpSignal.connect( | 				currentLevelButton->onMouseUpSignal.connect( | ||||||
| 					[this, modal_background, levelStar, levelIndex](Vector2f v, int i) { | 					[this, modal_background, levelStar, levelIndex](Vector2f v, int i) { | ||||||
|  |                         PerformInMainThreadAsync([this, modal_background, levelStar, levelIndex]() { | ||||||
| 							modal_background->setVisibility(false); | 							modal_background->setVisibility(false); | ||||||
| 
 | 
 | ||||||
| 							std::shared_ptr<TGameLevel> lvl = this->Menu.GalaxMenu.galaxies[0].Stars[levelStar].selectionMenu.gameLevels[levelIndex]; | 							std::shared_ptr<TGameLevel> lvl = this->Menu.GalaxMenu.galaxies[0].Stars[levelStar].selectionMenu.gameLevels[levelIndex]; | ||||||
| 							lvl->ReloadLevel(); | 							lvl->ReloadLevel(); | ||||||
| 							this->GoFromMenuToGame(lvl); | 							this->GoFromMenuToGame(lvl); | ||||||
| 						}); | 						}); | ||||||
|  | 				}); | ||||||
| 
 | 
 | ||||||
| 			} | 			} | ||||||
| 			else | 			else | ||||||
| @ -825,7 +841,7 @@ void TMyApplication::InnerOnMouseMove(TMouseState& mouseState) { | |||||||
| 
 | 
 | ||||||
| bool TMyApplication::IsLevelOpened(int levelStar, int levelIndex) | bool TMyApplication::IsLevelOpened(int levelStar, int levelIndex) | ||||||
| { | { | ||||||
| 	return levelStar <= currentStar; | 	return levelStar <= currentStar && levelIndex <= currentLevel; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -6,18 +6,14 @@ android { | |||||||
|     buildToolsVersion "28.0.0" |     buildToolsVersion "28.0.0" | ||||||
|     defaultConfig { |     defaultConfig { | ||||||
|         applicationId "fishrungames.DoubleHitBalls" |         applicationId "fishrungames.DoubleHitBalls" | ||||||
|         minSdkVersion 24 |         minSdkVersion 19 | ||||||
|         targetSdkVersion 28 |         targetSdkVersion 28 | ||||||
|         versionCode 1 |         versionCode 1 | ||||||
|         versionName "1.0" |         versionName "1.0" | ||||||
|         testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" |         testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" | ||||||
|         externalNativeBuild { |         externalNativeBuild { | ||||||
|             cmake { |             cmake { | ||||||
| 
 |                 abiFilters 'arm64-v8a', 'armeabi-v7a', 'x86' | ||||||
|                 abiFilters  "armeabi-v7a", "x86" |  | ||||||
| 
 |  | ||||||
|                 arguments "-DANDROID_STL=c++_shared" |  | ||||||
| 
 |  | ||||||
|                 cppFlags "-std=c++17 -frtti -fexceptions -fsigned-char -Wno-c++11-narrowing" |                 cppFlags "-std=c++17 -frtti -fexceptions -fsigned-char -Wno-c++11-narrowing" | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @ -38,6 +34,13 @@ android { | |||||||
|             assets.srcDirs = ['../../assets/'] |             assets.srcDirs = ['../../assets/'] | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |     splits { | ||||||
|  |         abi { | ||||||
|  |             enable true | ||||||
|  |             reset() | ||||||
|  |             include 'arm64-v8a', 'armeabi-v7a', 'x86' | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| dependencies { | dependencies { | ||||||
|  | |||||||
| @ -36,6 +36,8 @@ public class GL2JNIActivity extends Activity | |||||||
| 		EngineWrapper.LoadSalmonEngineLibrary(); | 		EngineWrapper.LoadSalmonEngineLibrary(); | ||||||
| 		EngineWrapper.SetActivityInstance(this); | 		EngineWrapper.SetActivityInstance(this); | ||||||
| 		EngineWrapper.SetupEnviroment(); | 		EngineWrapper.SetupEnviroment(); | ||||||
|  | 		JniWrapper.SetJavaVM(); | ||||||
|  | 		JniWrapper.SetContext(this); | ||||||
| 		 | 		 | ||||||
| 		String apkFilePath = null; | 		String apkFilePath = null; | ||||||
| 		ApplicationInfo appInfo = null; | 		ApplicationInfo appInfo = null; | ||||||
|  | |||||||
| @ -1,11 +1,52 @@ | |||||||
| package fishrungames.doublehitballs; | package fishrungames.doublehitballs; | ||||||
| 
 | 
 | ||||||
|  | import android.content.Context; | ||||||
|  | import android.util.Log; | ||||||
|  | 
 | ||||||
|  | import java.io.File; | ||||||
|  | import java.io.FileInputStream; | ||||||
|  | import java.io.FileOutputStream; | ||||||
|  | 
 | ||||||
| public class JniWrapper | public class JniWrapper | ||||||
| { | { | ||||||
|  |     static Context context = null; | ||||||
|  | 
 | ||||||
|  |     public static void SetContext(Context context) | ||||||
|  |     { | ||||||
|  |         JniWrapper.context = context; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     static { |     static { | ||||||
|         System.loadLibrary("DoubleHitBalls"); |         System.loadLibrary("DoubleHitBalls"); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static native void Init(int width, int height); |     public static native void Init(int width, int height); | ||||||
|  |     public static native void SetJavaVM(); | ||||||
| 
 | 
 | ||||||
|  |     public static String LoadFile(String fileName) | ||||||
|  |     { | ||||||
|  |         try { | ||||||
|  |             File file = new File(context.getFilesDir(), fileName); | ||||||
|  |             FileInputStream inputStream = new FileInputStream(file); | ||||||
|  |             byte[] data = new byte[(int) file.length()]; | ||||||
|  |             inputStream.read(data); | ||||||
|  |             inputStream.close(); | ||||||
|  |             return new String(data, "UTF-8"); | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             Log.d("SaveFile", "Failed to save a file."); | ||||||
|  |         } | ||||||
|  |         return ""; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static void SaveFile(String fileName, String fileContent) | ||||||
|  |     { | ||||||
|  |         try { | ||||||
|  |             File file = new File(context.getFilesDir(), fileName); | ||||||
|  |             FileOutputStream outputStream = new FileOutputStream(file); | ||||||
|  |             outputStream.write(fileContent.getBytes()); | ||||||
|  |             outputStream.close(); | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             Log.d("SaveFile", "Failed to save a file."); | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user