Commit baa5391839b0c0bc5722d2e6a4fb3d5c003ae79e
1 parent
5553a3ffd4
Exists in
master
upgrade to 4.9.0
Showing 15 changed files with 277 additions and 10 deletions Inline Diff
- .gitignore
- GameSDKDemo/build.gradle
- GameSDKDemo/gradle/wrapper/gradle-wrapper.jar
- GameSDKDemo/gradle/wrapper/gradle-wrapper.properties
- GameSDKDemo/gradlew
- GameSDKDemo/gradlew.bat
- GameSDKDemo/src/main/AndroidManifest.xml
- GameSDKDemo/src/main/java/com/gump/game/sdk/demo/MainActivity.java
- GameSDKDemo/src/main/res/drawable-hdpi/ic_launcher.jpeg
- GameSDKDemo/src/main/res/drawable-hdpi/ic_launcher.png
- GameSDKDemo/src/main/res/drawable-mdpi/ic_launcher.png
- GameSDKDemo/src/main/res/drawable-xhdpi/ic_launcher.jpeg
- GameSDKDemo/src/main/res/drawable-xhdpi/ic_launcher.png
- GameSDKDemo/src/main/res/values-zh/strings.xml
- GameSDKDemo/src/main/res/values/strings.xml
.gitignore
File was created | 1 | *.iml | |
2 | build/ | ||
3 | .DS_Store | ||
4 | .idea | ||
5 | .gradle | ||
6 |
GameSDKDemo/build.gradle
1 | apply plugin: 'com.android.application' | 1 | apply plugin: 'com.android.application' |
2 | 2 | ||
3 | /*The config for internal testing,you could ignore it | 3 | /*The config for internal testing,you could ignore it |
4 | * gump内部测试使用,你可以自行配置,或者直接删除这部分内容 | 4 | * gump内部测试使用,你可以自行配置,或者直接删除这部分内容 |
5 | * --start-- | 5 | * --start-- |
6 | */ | 6 | */ |
7 | def keystorePSW = '' | 7 | def keystorePSW = '' |
8 | def keystoreAlias = '' | 8 | def keystoreAlias = '' |
9 | def keystoreAliasPSW = '' | 9 | def keystoreAliasPSW = '' |
10 | // default keystore file, PLZ config file path in local.properties | 10 | // default keystore file, PLZ config file path in local.properties |
11 | def keyfile = file('s.keystore.temp') | 11 | def keyfile = file('s.keystore.temp') |
12 | 12 | ||
13 | Properties properties = new Properties() | 13 | Properties properties = new Properties() |
14 | // local.properties file in the root director | 14 | // local.properties file in the root director |
15 | properties.load(project.file('local.properties').newDataInputStream()) | 15 | properties.load(project.file('local.properties').newDataInputStream()) |
16 | def keystoreFilepath = properties.getProperty("keystore.path") | 16 | def keystoreFilepath = properties.getProperty("keystore.path") |
17 | 17 | ||
18 | if (keystoreFilepath) { | 18 | if (keystoreFilepath) { |
19 | keystorePSW = properties.getProperty("keystore.password") | 19 | keystorePSW = properties.getProperty("keystore.password") |
20 | keystoreAlias = properties.getProperty("keystore.alias") | 20 | keystoreAlias = properties.getProperty("keystore.alias") |
21 | keystoreAliasPSW = properties.getProperty("keystore.key_passwd") | 21 | keystoreAliasPSW = properties.getProperty("keystore.key_passwd") |
22 | keyfile = file(keystoreFilepath) | 22 | keyfile = file(keystoreFilepath) |
23 | } | 23 | } |
24 | /* | 24 | /* |
25 | * The config for internal testing,you could ignore it | 25 | * The config for internal testing,you could ignore it |
26 | * gump内部测试使用,你可以自行配置,或者直接删除这部分内容 | 26 | * gump内部测试使用,你可以自行配置,或者直接删除这部分内容 |
27 | * --end-- | 27 | * --end-- |
28 | */ | 28 | */ |
29 | 29 | ||
30 | repositories { | 30 | repositories { |
31 | maven { | 31 | maven { |
32 | url "http://117.50.8.198:8081/nexus/content/repositories/sdk" | 32 | url "http://117.50.8.198:8081/nexus/content/repositories/sdk" |
33 | } | 33 | } |
34 | jcenter() | 34 | jcenter() |
35 | google() | 35 | google() |
36 | } | 36 | } |
37 | 37 | ||
38 | android { | 38 | android { |
39 | compileSdkVersion 28 | 39 | compileSdkVersion 28 |
40 | buildToolsVersion '28.0.3' | 40 | buildToolsVersion '28.0.3' |
41 | 41 | ||
42 | signingConfigs { | 42 | signingConfigs { |
43 | release { | 43 | release { |
44 | storeFile keyfile | 44 | storeFile keyfile |
45 | storePassword keystorePSW | 45 | storePassword keystorePSW |
46 | keyPassword keystoreAliasPSW | 46 | keyPassword keystoreAliasPSW |
47 | keyAlias keystoreAlias | 47 | keyAlias keystoreAlias |
48 | } | 48 | } |
49 | } | 49 | } |
50 | 50 | ||
51 | defaultConfig { | 51 | defaultConfig { |
52 | minSdkVersion 14 | 52 | minSdkVersion 14 |
53 | targetSdkVersion 27 | 53 | targetSdkVersion 30 |
54 | applicationId "mx.she.rd4" | 54 | applicationId "com.gp.bakedst.sg" |
55 | versionCode 6 | 55 | versionCode 6 |
56 | versionName "1.4" | 56 | versionName "1.5" |
57 | testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" | 57 | testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" |
58 | signingConfig signingConfigs.release | 58 | signingConfig signingConfigs.release |
59 | } | 59 | } |
60 | buildTypes { | 60 | buildTypes { |
61 | release { | 61 | release { |
62 | minifyEnabled false | 62 | minifyEnabled false |
63 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' | 63 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' |
64 | zipAlignEnabled true | 64 | zipAlignEnabled true |
65 | } | 65 | } |
66 | debug { | 66 | debug { |
67 | signingConfig signingConfigs.release | 67 | signingConfig signingConfigs.release |
68 | } | 68 | } |
69 | } | 69 | } |
70 | lintOptions { | 70 | lintOptions { |
71 | abortOnError false | 71 | abortOnError false |
72 | } | 72 | } |
73 | compileOptions { | 73 | compileOptions { |
74 | sourceCompatibility JavaVersion.VERSION_1_8 | 74 | sourceCompatibility JavaVersion.VERSION_1_8 |
75 | targetCompatibility JavaVersion.VERSION_1_8 | 75 | targetCompatibility JavaVersion.VERSION_1_8 |
76 | } | 76 | } |
77 | applicationVariants.all { | 77 | applicationVariants.all { |
78 | variant -> | 78 | variant -> |
79 | variant.outputs.all { | 79 | variant.outputs.all { |
80 | outputFileName = "GameSDKDemo-" + variant.name + defaultConfig.versionName + ".apk" | 80 | outputFileName = "GameSDKDemo-" + variant.name + defaultConfig.versionName + ".apk" |
81 | } | 81 | } |
82 | } | 82 | } |
83 | 83 | ||
84 | } | 84 | } |
85 | 85 | ||
86 | dependencies { | 86 | dependencies { |
87 | implementation fileTree(include: ['*.jar'], dir: 'libs') | 87 | implementation fileTree(include: ['*.jar'], dir: 'libs') |
88 | // implementation 'com.android.support:support-v4:27.1.1' | 88 | // implementation 'com.android.support:support-v4:27.1.1' |
89 | implementation 'androidx.appcompat:appcompat:1.1.0' | 89 | implementation 'androidx.appcompat:appcompat:1.1.0' |
90 | implementation 'androidx.fragment:fragment:1.1.0' | 90 | implementation 'androidx.fragment:fragment:1.1.0' |
91 | implementation 'com.google.android.material:material:1.0.0' | 91 | implementation 'com.google.android.material:material:1.0.0' |
92 | testImplementation 'junit:junit:4.12' | 92 | testImplementation 'junit:junit:4.12' |
93 | // implementation 'com.android.support:appcompat-v7:27.1.1' | 93 | // implementation 'com.android.support:appcompat-v7:27.1.1' |
94 | // implementation 'com.android.support:design:27.1.1' | 94 | // implementation 'com.android.support:design:27.1.1' |
95 | // implementation project(':GameSDK') | 95 | // implementation project(':GameSDK') |
96 | // implementation project(':IAP5Helper') | 96 | // implementation project(':IAP5Helper') |
97 | implementation 'com.gumptech.sdk:GameSDK:4.8.0' | 97 | implementation 'com.gumptech.sdk:GameSDK:4.9.0' |
98 | // implementation 'com.gump.game.sdk:SamsungIAP:5.1.1' | 98 | // implementation 'com.gump.game.sdk:SamsungIAP:5.1.1' |
99 | } | 99 | } |
100 | 100 |
GameSDKDemo/gradle/wrapper/gradle-wrapper.jar
No preview for this file type
GameSDKDemo/gradle/wrapper/gradle-wrapper.properties
File was created | 1 | #Thu Jun 04 13:41:54 CST 2020 | |
2 | distributionBase=GRADLE_USER_HOME | ||
3 | distributionPath=wrapper/dists | ||
4 | zipStoreBase=GRADLE_USER_HOME | ||
5 | zipStorePath=wrapper/dists | ||
6 | distributionUrl=https\://services.gradle.org/distributions/gradle-5.6.4-all.zip | ||
7 |
GameSDKDemo/gradlew
File was created | 1 | #!/usr/bin/env sh | |
2 | |||
3 | ############################################################################## | ||
4 | ## | ||
5 | ## Gradle start up script for UN*X | ||
6 | ## | ||
7 | ############################################################################## | ||
8 | |||
9 | # Attempt to set APP_HOME | ||
10 | # Resolve links: $0 may be a link | ||
11 | PRG="$0" | ||
12 | # Need this for relative symlinks. | ||
13 | while [ -h "$PRG" ] ; do | ||
14 | ls=`ls -ld "$PRG"` | ||
15 | link=`expr "$ls" : '.*-> \(.*\)$'` | ||
16 | if expr "$link" : '/.*' > /dev/null; then | ||
17 | PRG="$link" | ||
18 | else | ||
19 | PRG=`dirname "$PRG"`"/$link" | ||
20 | fi | ||
21 | done | ||
22 | SAVED="`pwd`" | ||
23 | cd "`dirname \"$PRG\"`/" >/dev/null | ||
24 | APP_HOME="`pwd -P`" | ||
25 | cd "$SAVED" >/dev/null | ||
26 | |||
27 | APP_NAME="Gradle" | ||
28 | APP_BASE_NAME=`basename "$0"` | ||
29 | |||
30 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
31 | DEFAULT_JVM_OPTS="" | ||
32 | |||
33 | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||
34 | MAX_FD="maximum" | ||
35 | |||
36 | warn () { | ||
37 | echo "$*" | ||
38 | } | ||
39 | |||
40 | die () { | ||
41 | echo | ||
42 | echo "$*" | ||
43 | echo | ||
44 | exit 1 | ||
45 | } | ||
46 | |||
47 | # OS specific support (must be 'true' or 'false'). | ||
48 | cygwin=false | ||
49 | msys=false | ||
50 | darwin=false | ||
51 | nonstop=false | ||
52 | case "`uname`" in | ||
53 | CYGWIN* ) | ||
54 | cygwin=true | ||
55 | ;; | ||
56 | Darwin* ) | ||
57 | darwin=true | ||
58 | ;; | ||
59 | MINGW* ) | ||
60 | msys=true | ||
61 | ;; | ||
62 | NONSTOP* ) | ||
63 | nonstop=true | ||
64 | ;; | ||
65 | esac | ||
66 | |||
67 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||
68 | |||
69 | # Determine the Java command to use to start the JVM. | ||
70 | if [ -n "$JAVA_HOME" ] ; then | ||
71 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||
72 | # IBM's JDK on AIX uses strange locations for the executables | ||
73 | JAVACMD="$JAVA_HOME/jre/sh/java" | ||
74 | else | ||
75 | JAVACMD="$JAVA_HOME/bin/java" | ||
76 | fi | ||
77 | if [ ! -x "$JAVACMD" ] ; then | ||
78 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | ||
79 | |||
80 | Please set the JAVA_HOME variable in your environment to match the | ||
81 | location of your Java installation." | ||
82 | fi | ||
83 | else | ||
84 | JAVACMD="java" | ||
85 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
86 | |||
87 | Please set the JAVA_HOME variable in your environment to match the | ||
88 | location of your Java installation." | ||
89 | fi | ||
90 | |||
91 | # Increase the maximum file descriptors if we can. | ||
92 | if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then | ||
93 | MAX_FD_LIMIT=`ulimit -H -n` | ||
94 | if [ $? -eq 0 ] ; then | ||
95 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then | ||
96 | MAX_FD="$MAX_FD_LIMIT" | ||
97 | fi | ||
98 | ulimit -n $MAX_FD | ||
99 | if [ $? -ne 0 ] ; then | ||
100 | warn "Could not set maximum file descriptor limit: $MAX_FD" | ||
101 | fi | ||
102 | else | ||
103 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" | ||
104 | fi | ||
105 | fi | ||
106 | |||
107 | # For Darwin, add options to specify how the application appears in the dock | ||
108 | if $darwin; then | ||
109 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" | ||
110 | fi | ||
111 | |||
112 | # For Cygwin, switch paths to Windows format before running java | ||
113 | if $cygwin ; then | ||
114 | APP_HOME=`cygpath --path --mixed "$APP_HOME"` | ||
115 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` | ||
116 | JAVACMD=`cygpath --unix "$JAVACMD"` | ||
117 | |||
118 | # We build the pattern for arguments to be converted via cygpath | ||
119 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` | ||
120 | SEP="" | ||
121 | for dir in $ROOTDIRSRAW ; do | ||
122 | ROOTDIRS="$ROOTDIRS$SEP$dir" | ||
123 | SEP="|" | ||
124 | done | ||
125 | OURCYGPATTERN="(^($ROOTDIRS))" | ||
126 | # Add a user-defined pattern to the cygpath arguments | ||
127 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then | ||
128 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" | ||
129 | fi | ||
130 | # Now convert the arguments - kludge to limit ourselves to /bin/sh | ||
131 | i=0 | ||
132 | for arg in "$@" ; do | ||
133 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` | ||
134 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option | ||
135 | |||
136 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition | ||
137 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` | ||
138 | else | ||
139 | eval `echo args$i`="\"$arg\"" | ||
140 | fi | ||
141 | i=$((i+1)) | ||
142 | done | ||
143 | case $i in | ||
144 | (0) set -- ;; | ||
145 | (1) set -- "$args0" ;; | ||
146 | (2) set -- "$args0" "$args1" ;; | ||
147 | (3) set -- "$args0" "$args1" "$args2" ;; | ||
148 | (4) set -- "$args0" "$args1" "$args2" "$args3" ;; | ||
149 | (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; | ||
150 | (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; | ||
151 | (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; | ||
152 | (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; | ||
153 | (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; | ||
154 | esac | ||
155 | fi | ||
156 | |||
157 | # Escape application args | ||
158 | save () { | ||
159 | for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done | ||
160 | echo " " | ||
161 | } | ||
162 | APP_ARGS=$(save "$@") | ||
163 | |||
164 | # Collect all arguments for the java command, following the shell quoting and substitution rules | ||
165 | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" | ||
166 | |||
167 | # by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong | ||
168 | if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then | ||
169 | cd "$(dirname "$0")" | ||
170 | fi | ||
171 | |||
172 | exec "$JAVACMD" "$@" | ||
173 |
GameSDKDemo/gradlew.bat
File was created | 1 | @if "%DEBUG%" == "" @echo off | |
2 | @rem ########################################################################## | ||
3 | @rem | ||
4 | @rem Gradle startup script for Windows | ||
5 | @rem | ||
6 | @rem ########################################################################## | ||
7 | |||
8 | @rem Set local scope for the variables with windows NT shell | ||
9 | if "%OS%"=="Windows_NT" setlocal | ||
10 | |||
11 | set DIRNAME=%~dp0 | ||
12 | if "%DIRNAME%" == "" set DIRNAME=. | ||
13 | set APP_BASE_NAME=%~n0 | ||
14 | set APP_HOME=%DIRNAME% | ||
15 | |||
16 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||
17 | set DEFAULT_JVM_OPTS= | ||
18 | |||
19 | @rem Find java.exe | ||
20 | if defined JAVA_HOME goto findJavaFromJavaHome | ||
21 | |||
22 | set JAVA_EXE=java.exe | ||
23 | %JAVA_EXE% -version >NUL 2>&1 | ||
24 | if "%ERRORLEVEL%" == "0" goto init | ||
25 | |||
26 | echo. | ||
27 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||
28 | echo. | ||
29 | echo Please set the JAVA_HOME variable in your environment to match the | ||
30 | echo location of your Java installation. | ||
31 | |||
32 | goto fail | ||
33 | |||
34 | :findJavaFromJavaHome | ||
35 | set JAVA_HOME=%JAVA_HOME:"=% | ||
36 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||
37 | |||
38 | if exist "%JAVA_EXE%" goto init | ||
39 | |||
40 | echo. | ||
41 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||
42 | echo. | ||
43 | echo Please set the JAVA_HOME variable in your environment to match the | ||
44 | echo location of your Java installation. | ||
45 | |||
46 | goto fail | ||
47 | |||
48 | :init | ||
49 | @rem Get command-line arguments, handling Windows variants | ||
50 | |||
51 | if not "%OS%" == "Windows_NT" goto win9xME_args | ||
52 | |||
53 | :win9xME_args | ||
54 | @rem Slurp the command line arguments. | ||
55 | set CMD_LINE_ARGS= | ||
56 | set _SKIP=2 | ||
57 | |||
58 | :win9xME_args_slurp | ||
59 | if "x%~1" == "x" goto execute | ||
60 | |||
61 | set CMD_LINE_ARGS=%* | ||
62 | |||
63 | :execute | ||
64 | @rem Setup the command line | ||
65 | |||
66 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||
67 | |||
68 | @rem Execute Gradle | ||
69 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | ||
70 | |||
71 | :end | ||
72 | @rem End local scope for the variables with windows NT shell | ||
73 | if "%ERRORLEVEL%"=="0" goto mainEnd | ||
74 | |||
75 | :fail | ||
76 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | ||
77 | rem the _cmd.exe /c_ return code! | ||
78 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | ||
79 | exit /b 1 | ||
80 | |||
81 | :mainEnd | ||
82 | if "%OS%"=="Windows_NT" endlocal | ||
83 | |||
84 | :omega | ||
85 |
GameSDKDemo/src/main/AndroidManifest.xml
1 | <manifest xmlns:android="http://schemas.android.com/apk/res/android" | 1 | <manifest xmlns:android="http://schemas.android.com/apk/res/android" |
2 | package="com.gump.game.sdk.demo"> | 2 | package="com.gump.game.sdk.demo"> |
3 | 3 | ||
4 | 4 | ||
5 | <uses-permission android:name="android.permission.INTERNET"/> | 5 | <uses-permission android:name="android.permission.INTERNET"/> |
6 | <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/> | 6 | <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/> |
7 | <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> | 7 | <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> |
8 | <!-- Danger Level permission--> | 8 | <!-- Danger Level permission--> |
9 | 9 | ||
10 | <!-- VERY IMPORTANT! Don't forget this permission, or in-app billing won't work. --> | 10 | <!-- VERY IMPORTANT! Don't forget this permission, or in-app billing won't work. --> |
11 | <uses-permission android:name="com.android.vending.BILLING"/> | 11 | <uses-permission android:name="com.android.vending.BILLING"/> |
12 | <!--samgung iap need this permission--> | 12 | <!--samgung iap need this permission--> |
13 | <uses-permission android:name="com.samsung.android.iap.permission.BILLING"/> | 13 | <uses-permission android:name="com.samsung.android.iap.permission.BILLING"/> |
14 | 14 | ||
15 | <application | 15 | <application |
16 | android:allowBackup="true" | 16 | android:allowBackup="true" |
17 | android:icon="@drawable/ic_launcher" | 17 | android:icon="@drawable/ic_launcher" |
18 | android:label="@string/app_name"> | 18 | android:label="@string/app_name"> |
19 | <activity | 19 | <activity |
20 | android:name="com.gump.game.sdk.demo.MainActivity" | 20 | android:name="com.gump.game.sdk.demo.MainActivity" |
21 | android:configChanges="orientation|screenSize|keyboardHidden|keyboard|screenLayout" | 21 | android:configChanges="orientation|screenSize|keyboardHidden|keyboard|screenLayout" |
22 | android:label="@string/app_name" | 22 | android:label="@string/app_name" |
23 | android:theme="@style/Theme.AppCompat.Light.NoActionBar" | 23 | android:theme="@style/Theme.AppCompat.Light.NoActionBar" |
24 | android:screenOrientation="portrait"> | 24 | > |
25 | <intent-filter> | 25 | <intent-filter> |
26 | <action android:name="android.intent.action.MAIN"/> | 26 | <action android:name="android.intent.action.MAIN"/> |
27 | 27 | ||
28 | <category android:name="android.intent.category.LAUNCHER"/> | 28 | <category android:name="android.intent.category.LAUNCHER"/> |
29 | </intent-filter> | 29 | </intent-filter> |
30 | </activity> | 30 | </activity> |
31 | |||
31 | <activity | 32 | <activity |
32 | android:name="com.gump.game.sdk.PassportActivity" | 33 | android:name="com.gump.game.sdk.PassportActivity" |
33 | android:configChanges="orientation|screenSize|keyboardHidden|keyboard|screenLayout" | 34 | android:configChanges="orientation|screenSize|keyboardHidden|keyboard|screenLayout" |
34 | android:launchMode="singleTask" | 35 | android:launchMode="singleTask" |
35 | android:theme="@style/Theme.Pink" | 36 | android:theme="@style/Theme.Origin" |
36 | android:screenOrientation="behind" | 37 | android:screenOrientation="behind" |
37 | android:windowSoftInputMode="stateAlwaysHidden|adjustPan"> | 38 | android:windowSoftInputMode="stateAlwaysHidden|adjustPan"> |
38 | </activity> | 39 | </activity> |
39 | <activity | 40 | <activity |
40 | android:name="com.gump.game.sdk.RechargeActivity" | 41 | android:name="com.gump.game.sdk.RechargeActivity" |
41 | android:configChanges="orientation|screenSize|keyboardHidden|keyboard|screenLayout" | 42 | android:configChanges="orientation|screenSize|keyboardHidden|keyboard|screenLayout" |
42 | android:launchMode="singleTask" | 43 | android:launchMode="singleTask" |
43 | android:screenOrientation="behind" | 44 | android:screenOrientation="behind" |
44 | android:theme="@style/Theme.Translucent"> | 45 | android:theme="@style/Theme.Translucent"> |
45 | <intent-filter> | 46 | <intent-filter> |
46 | <category android:name="android.intent.category.DEFAULT"/> | 47 | <category android:name="android.intent.category.DEFAULT"/> |
47 | 48 | ||
48 | <action android:name="android.intent.action.VIEW"/> | 49 | <action android:name="android.intent.action.VIEW"/> |
49 | 50 | ||
50 | <category android:name="android.intent.category.BROWSABLE"/> | 51 | <category android:name="android.intent.category.BROWSABLE"/> |
51 | 52 | ||
52 | <data | 53 | <data |
53 | android:host="com.gump.sdk" | 54 | android:host="com.gump.sdk" |
54 | android:scheme="gump100"/> | 55 | android:scheme="gump100"/> |
55 | </intent-filter> | 56 | </intent-filter> |
56 | </activity> | 57 | </activity> |
57 | 58 | ||
58 | </application> | 59 | </application> |
59 | 60 | ||
60 | 61 | ||
61 | </manifest> | 62 | </manifest> |
62 | 63 |
GameSDKDemo/src/main/java/com/gump/game/sdk/demo/MainActivity.java
1 | package com.gump.game.sdk.demo; | 1 | package com.gump.game.sdk.demo; |
2 | 2 | ||
3 | import android.os.Bundle; | 3 | import android.os.Bundle; |
4 | import android.util.Log; | 4 | import android.util.Log; |
5 | import android.widget.Button; | 5 | import android.widget.Button; |
6 | import android.widget.TextView; | 6 | import android.widget.TextView; |
7 | import android.widget.Toast; | 7 | import android.widget.Toast; |
8 | 8 | ||
9 | import com.gump.game.sdk.GameSDK; | ||
10 | import com.gump.game.sdk.GumpPreference; | 9 | import com.gump.game.sdk.GumpPreference; |
10 | import com.gump.game.sdk.GameSDK; | ||
11 | import com.gump.game.sdk.SDKSettings; | 11 | import com.gump.game.sdk.SDKSettings; |
12 | import com.gump.game.sdk.bean.GumpUser; | 12 | import com.gump.game.sdk.bean.GumpUser; |
13 | import com.gump.game.sdk.callback.LoginStateListener; | 13 | import com.gump.game.sdk.callback.LoginStateListener; |
14 | import com.gump.game.sdk.callback.RechargeCallback; | 14 | import com.gump.game.sdk.callback.RechargeCallback; |
15 | import com.gump.game.sdk.passport.fb.FBAccessToken; | 15 | import com.gump.game.sdk.passport.fb.FBAccessToken; |
16 | 16 | ||
17 | import java.util.Locale; | 17 | import java.util.Locale; |
18 | 18 | ||
19 | import androidx.appcompat.app.AppCompatActivity; | 19 | import androidx.appcompat.app.AppCompatActivity; |
20 | 20 | ||
21 | public class MainActivity extends AppCompatActivity implements RechargeCallback { | 21 | public class MainActivity extends AppCompatActivity implements RechargeCallback { |
22 | 22 | ||
23 | private static final String TAG = "MainActivity"; | 23 | private static final String TAG = "MainActivity"; |
24 | 24 | ||
25 | private TextView tvVersion; | 25 | private TextView tvVersion; |
26 | private TextView userInfo; | 26 | private TextView userInfo; |
27 | 27 | ||
28 | private Button btnLoginOrLogout; | 28 | private Button btnLoginOrLogout; |
29 | private Button btnCheckState; | 29 | private Button btnCheckState; |
30 | private Button btnPay; | 30 | private Button btnPay; |
31 | private Button btnIap; | 31 | private Button btnIap; |
32 | 32 | ||
33 | private String appId = "100"; | 33 | private String appId = "100"; |
34 | private String appKey = "f899139df5e1059396431415e770c6dd"; | ||
35 | private GumpUser gumpUser; | 34 | private GumpUser gumpUser; |
36 | 35 | ||
37 | /** | 36 | /** |
38 | * 测试数据 | 37 | * 测试数据 |
39 | */ | 38 | */ |
40 | String serverId = "100"; | 39 | String serverId = "100"; |
41 | String roleId = "41080"; | 40 | String roleId = "41080"; |
42 | 41 | ||
43 | 42 | ||
44 | @Override | 43 | @Override |
45 | protected void onCreate(Bundle savedInstanceState) { | 44 | protected void onCreate(Bundle savedInstanceState) { |
46 | super.onCreate(savedInstanceState); | 45 | super.onCreate(savedInstanceState); |
47 | setContentView(R.layout.activity_main); | 46 | setContentView(R.layout.activity_main); |
48 | 47 | ||
49 | tvVersion = findViewById(R.id.version); | 48 | tvVersion = findViewById(R.id.version); |
50 | userInfo = findViewById(R.id.user_info); | 49 | userInfo = findViewById(R.id.user_info); |
51 | btnLoginOrLogout = findViewById(R.id.login_or_logout); | 50 | btnLoginOrLogout = findViewById(R.id.login_or_logout); |
52 | btnCheckState = findViewById(R.id.check_state); | 51 | btnCheckState = findViewById(R.id.check_state); |
53 | btnLoginOrLogout.setOnClickListener(v -> { | 52 | btnLoginOrLogout.setOnClickListener(v -> { |
54 | if (btnLoginOrLogout.getTag() == null || (Integer) btnLoginOrLogout.getTag() == 0) | 53 | if (btnLoginOrLogout.getTag() == null || (Integer) btnLoginOrLogout.getTag() == 0) |
55 | GameSDK.login(MainActivity.this); | 54 | GameSDK.login(MainActivity.this); |
56 | else | 55 | else |
57 | GameSDK.logout(MainActivity.this); | 56 | GameSDK.logout(MainActivity.this); |
58 | }); | 57 | }); |
59 | btnCheckState.setOnClickListener(v -> { | 58 | btnCheckState.setOnClickListener(v -> { |
60 | GameSDK.iapUsable(MainActivity.this, serverId, roleId, usable -> { | 59 | GameSDK.iapUsable(MainActivity.this, serverId, roleId, usable -> { |
61 | btnIap.setEnabled(usable); | 60 | btnIap.setEnabled(usable); |
62 | btnPay.setEnabled(!usable); | 61 | btnPay.setEnabled(!usable); |
63 | }); | 62 | }); |
64 | }); | 63 | }); |
65 | btnPay = findViewById(R.id.pay); | 64 | btnPay = findViewById(R.id.pay); |
66 | btnPay.setOnClickListener(v -> { | 65 | btnPay.setOnClickListener(v -> { |
67 | PaymentInfoSubmitFragment submitFragment = PaymentInfoSubmitFragment.newInstance(payInfo -> GameSDK.pay(MainActivity.this, payInfo, MainActivity.this)); | 66 | PaymentInfoSubmitFragment submitFragment = PaymentInfoSubmitFragment.newInstance(payInfo -> GameSDK.pay(MainActivity.this, payInfo, MainActivity.this)); |
68 | submitFragment.show(getSupportFragmentManager(), "pay"); | 67 | submitFragment.show(getSupportFragmentManager(), "pay"); |
69 | }); | 68 | }); |
70 | btnIap = findViewById(R.id.iap); | 69 | btnIap = findViewById(R.id.iap); |
71 | btnIap.setOnClickListener(v -> { | 70 | btnIap.setOnClickListener(v -> { |
72 | PaymentInfoSubmitFragment submitFragment = PaymentInfoSubmitFragment.newInstance(payInfo -> GameSDK.iap(MainActivity.this, payInfo, MainActivity.this)); | 71 | PaymentInfoSubmitFragment submitFragment = PaymentInfoSubmitFragment.newInstance(payInfo -> GameSDK.iap(MainActivity.this, payInfo, MainActivity.this)); |
73 | submitFragment.show(getSupportFragmentManager(), "iap"); | 72 | submitFragment.show(getSupportFragmentManager(), "iap"); |
74 | }); | 73 | }); |
75 | 74 | ||
76 | 75 | ||
77 | Log.i("DEMO", "country:" + Locale.getDefault().getCountry() + ",language:" + Locale.getDefault().getLanguage()); | 76 | Log.i("DEMO", "country:" + Locale.getDefault().getCountry() + ",language:" + Locale.getDefault().getLanguage()); |
78 | 77 | ||
79 | GameSDK.getSettings().setDebug(false); | 78 | GameSDK.getSettings().setDebug(false); |
80 | /** | 79 | /** |
81 | * 设置是否打印debug日志 | 80 | * 设置是否打印debug日志 |
82 | */ | 81 | */ |
83 | GameSDK.getSettings().enableDebugLogging(true); | 82 | GameSDK.getSettings().enableDebugLogging(true); |
84 | /** | 83 | /** |
85 | * 设置启用facebook登录 | 84 | * 设置启用facebook登录 |
86 | */ | 85 | */ |
87 | GameSDK.getSettings().requestThirdSupport(SDKSettings.THIRD_SUPPORT_FB); | 86 | GameSDK.getSettings().requestThirdSupport(SDKSettings.THIRD_SUPPORT_FB); |
88 | 87 | ||
89 | /** | 88 | /** |
90 | * 设置启用google登录 | 89 | * 设置启用google登录 |
91 | */ | 90 | */ |
92 | GameSDK.getSettings().requestThirdSupport(SDKSettings.THIRD_SUPPORT_GOOGLE); | 91 | GameSDK.getSettings().requestThirdSupport(SDKSettings.THIRD_SUPPORT_GOOGLE); |
93 | 92 | ||
94 | /** | 93 | /** |
95 | * 设置启用Line登录 | 94 | * 设置启用Line登录 |
96 | */ | 95 | */ |
97 | GameSDK.getSettings().requestThirdSupport(SDKSettings.THIRD_SUPPORT_LINE); | 96 | GameSDK.getSettings().requestThirdSupport(SDKSettings.THIRD_SUPPORT_LINE); |
98 | 97 | ||
99 | 98 | ||
100 | /** | 99 | /** |
101 | * 设置用户登录状态监听器 | 100 | * 设置用户登录状态监听器 |
102 | */ | 101 | */ |
103 | 102 | ||
104 | GameSDK.setUserStateListener(new LoginStateListener() { | 103 | GameSDK.setUserStateListener(new LoginStateListener() { |
105 | @Override | 104 | @Override |
106 | public void onLoginSuccess(GumpUser user) { | 105 | public void onLoginSuccess(GumpUser user) { |
107 | btnCheckState.setEnabled(true); | 106 | btnCheckState.setEnabled(true); |
108 | gumpUser = user; | 107 | gumpUser = user; |
109 | String userType = null; | 108 | String userType = null; |
110 | switch (user.getAccountType()) { | 109 | switch (user.getAccountType()) { |
111 | case GumpPreference.ACCOUNT_TYPE_FB: | 110 | case GumpPreference.ACCOUNT_TYPE_FB: |
112 | userType = "Facebook登录"; | 111 | userType = "Facebook登录"; |
113 | String fbToken = FBAccessToken.getCurrentAccessToken().getToken(); | 112 | String fbToken = FBAccessToken.getCurrentAccessToken().getToken(); |
114 | Log.d(TAG, "FBAccessToken:" + fbToken); | 113 | Log.d(TAG, "FBAccessToken:" + fbToken); |
115 | break; | 114 | break; |
116 | case GumpPreference.ACCOUNT_TYPE_QUICK_REG: | 115 | case GumpPreference.ACCOUNT_TYPE_QUICK_REG: |
117 | userType = "快速登录"; | 116 | userType = "快速登录"; |
118 | break; | 117 | break; |
119 | case GumpPreference.ACCOUNT_TYPE_REG: | 118 | case GumpPreference.ACCOUNT_TYPE_REG: |
120 | userType = "gump注册用户"; | 119 | userType = "gump注册用户"; |
121 | break; | 120 | break; |
122 | case GumpPreference.ACCOUNT_TYPE_GOOGLE: | 121 | case GumpPreference.ACCOUNT_TYPE_GOOGLE: |
123 | userType = "google 登录"; | 122 | userType = "google 登录"; |
124 | break; | 123 | break; |
125 | case GumpPreference.ACCOUNT_TYPE_LINE: | 124 | case GumpPreference.ACCOUNT_TYPE_LINE: |
126 | userType = "Line登录"; | 125 | userType = "Line登录"; |
127 | break; | 126 | break; |
128 | } | 127 | } |
129 | userInfo.setText(" Userid:" + user.getUid() + "\n accountType:(" + user.getAccountType() + ") " + userType + "\n sessionKey:" + user.getSessionKey() | 128 | userInfo.setText(" Userid:" + user.getUid() + "\n accountType:(" + user.getAccountType() + ") " + userType + "\n sessionKey:" + user.getSessionKey() |
130 | .getToken()); | 129 | .getToken()); |
131 | btnLoginOrLogout.setText("Logout"); | 130 | btnLoginOrLogout.setText("Logout"); |
132 | btnLoginOrLogout.setTag(1); | 131 | btnLoginOrLogout.setTag(1); |
133 | } | 132 | } |
134 | 133 | ||
135 | @Override | 134 | @Override |
136 | public void onLoginFailed(int code, String msg) { | 135 | public void onLoginFailed(int code, String msg) { |
137 | userInfo.setText(msg); | 136 | userInfo.setText(msg); |
138 | Toast.makeText(MainActivity.this, "Login failed:code=" + code + ",message=" + msg, Toast.LENGTH_SHORT).show(); | 137 | Toast.makeText(MainActivity.this, "Login failed:code=" + code + ",message=" + msg, Toast.LENGTH_SHORT).show(); |
139 | } | 138 | } |
140 | 139 | ||
141 | @Override | 140 | @Override |
142 | public void onLoginCanceled() { | 141 | public void onLoginCanceled() { |
143 | Toast.makeText(MainActivity.this, "operate be canceled", Toast.LENGTH_SHORT).show(); | 142 | Toast.makeText(MainActivity.this, "operate be canceled", Toast.LENGTH_SHORT).show(); |
144 | } | 143 | } |
145 | 144 | ||
146 | @Override | 145 | @Override |
147 | public void onLogout() { | 146 | public void onLogout() { |
148 | btnLoginOrLogout.setText("Login"); | 147 | btnLoginOrLogout.setText("Login"); |
149 | btnLoginOrLogout.setTag(0); | 148 | btnLoginOrLogout.setTag(0); |
150 | userInfo.setText("User is logout"); | 149 | userInfo.setText("User is logout"); |
151 | } | 150 | } |
152 | 151 | ||
153 | @Override | 152 | @Override |
154 | public void onPermissionDenied(String[] deniedPermissions) { | 153 | public void onPermissionDenied(String[] deniedPermissions) { |
155 | StringBuilder sb = new StringBuilder(); | 154 | StringBuilder sb = new StringBuilder(); |
156 | for (String s : deniedPermissions) { | 155 | for (String s : deniedPermissions) { |
157 | sb.append(s); | 156 | sb.append(s); |
158 | sb.append(","); | 157 | sb.append(","); |
159 | } | 158 | } |
160 | Toast.makeText(MainActivity.this, "Permission denied:" + sb.toString(), Toast.LENGTH_SHORT).show(); | 159 | Toast.makeText(MainActivity.this, "Permission denied:" + sb.toString(), Toast.LENGTH_SHORT).show(); |
161 | } | 160 | } |
162 | }); | 161 | }); |
163 | /** | 162 | /** |
164 | * 初始化sdk | 163 | * 初始化sdk |
165 | */ | 164 | */ |
166 | GameSDK.init(getApplicationContext(), appId); | 165 | GameSDK.init(getApplicationContext(), appId); |
167 | 166 | ||
168 | tvVersion.setText("SDK Version:" + GameSDK.getVersion()); | 167 | tvVersion.setText("SDK Version:" + GameSDK.getVersion()); |
169 | 168 | ||
170 | } | 169 | } |
171 | 170 | ||
172 | private void checkRisk() { | 171 | private void checkRisk() { |
173 | GameSDK.inspectRiskLevel(this, isRisk -> Log.i(TAG, isRisk ? "There is some risks" : "Nothing is risk")); | 172 | GameSDK.inspectRiskLevel(this, isRisk -> Log.i(TAG, isRisk ? "There is some risks" : "Nothing is risk")); |
174 | } | 173 | } |
175 | 174 | ||
176 | @Override | 175 | @Override |
177 | public void onPurchaseCompleted() { | 176 | public void onPurchaseCompleted() { |
178 | Log.i(TAG, "purchase completed"); | 177 | Log.i(TAG, "purchase completed"); |
179 | } | 178 | } |
180 | 179 | ||
181 | @Override | 180 | @Override |
182 | public void onPurchaseError(int code, String msg) { | 181 | public void onPurchaseError(int code, String msg) { |
183 | Log.i(TAG, "purchase error:"+code+","+msg); | 182 | Log.i(TAG, "purchase error:"+code+","+msg); |
184 | } | 183 | } |
185 | 184 | ||
186 | @Override | 185 | @Override |
187 | public void onPurchaseCanceled() { | 186 | public void onPurchaseCanceled() { |
188 | Log.i(TAG, "purchase canceled"); | 187 | Log.i(TAG, "purchase canceled"); |
189 | } | 188 | } |
190 | 189 | ||
191 | 190 | ||
192 | } | 191 | } |
GameSDKDemo/src/main/res/drawable-hdpi/ic_launcher.jpeg
1.82 KB
GameSDKDemo/src/main/res/drawable-hdpi/ic_launcher.png
7.23 KB
GameSDKDemo/src/main/res/drawable-mdpi/ic_launcher.png
4.73 KB
GameSDKDemo/src/main/res/drawable-xhdpi/ic_launcher.jpeg
2.33 KB
GameSDKDemo/src/main/res/drawable-xhdpi/ic_launcher.png
9.91 KB
GameSDKDemo/src/main/res/values-zh/strings.xml
1 | <?xml version="1.0" encoding="utf-8"?> | 1 | <?xml version="1.0" encoding="utf-8"?> |
2 | <resources> | 2 | <resources> |
3 | 3 | ||
4 | <string name="app_name">GameSDKSample</string> | 4 | <string name="app_name">Baked Stone</string> |
5 | 5 | ||
6 | <string name="init">初始化</string> | 6 | <string name="init">初始化</string> |
7 | <string name="login">登录</string> | 7 | <string name="login">登录</string> |
8 | <string name="check">检查支付状态</string> | 8 | <string name="check">检查支付状态</string> |
9 | <string name="iap">官方支付(插件支付)</string> | 9 | <string name="iap">官方支付(插件支付)</string> |
10 | <string name="pay">三方支付</string> | 10 | <string name="pay">三方支付</string> |
11 | 11 | ||
12 | 12 | ||
13 | <string name="hint_product">商品id/商品名</string> | 13 | <string name="hint_product">商品id/商品名</string> |
14 | <string name="hint_amount">金额</string> | 14 | <string name="hint_amount">金额</string> |
15 | <string name="hint_currency">货币代码</string> | 15 | <string name="hint_currency">货币代码</string> |
16 | <string name="hint_server_id">serverId</string> | 16 | <string name="hint_server_id">serverId</string> |
17 | <string name="hint_role_id">roleId</string> | 17 | <string name="hint_role_id">roleId</string> |
18 | <string name="hint_extra">游戏透传信息(extraInfo)</string> | 18 | <string name="hint_extra">游戏透传信息(extraInfo)</string> |
19 | <string name="go_pay">去支付</string> | 19 | <string name="go_pay">去支付</string> |
20 | </resources> | 20 | </resources> |
21 | 21 |
GameSDKDemo/src/main/res/values/strings.xml
1 | <?xml version="1.0" encoding="utf-8"?> | 1 | <?xml version="1.0" encoding="utf-8"?> |
2 | <resources> | 2 | <resources> |
3 | 3 | ||
4 | <string name="app_name">GameSDKSample</string> | 4 | <string name="app_name">Baked Stone</string> |
5 | 5 | ||
6 | <string name="init">Initialize</string> | 6 | <string name="init">Initialize</string> |
7 | <string name="login">Login</string> | 7 | <string name="login">Login</string> |
8 | <string name="check">Check payemnt state</string> | 8 | <string name="check">Check payemnt state</string> |
9 | <string name="iap">IAP</string> | 9 | <string name="iap">IAP</string> |
10 | <string name="pay">Pay</string> | 10 | <string name="pay">Pay</string> |
11 | 11 | ||
12 | <string name="hint_product">product</string> | 12 | <string name="hint_product">product</string> |
13 | <string name="hint_amount">amount</string> | 13 | <string name="hint_amount">amount</string> |
14 | <string name="hint_currency">currency</string> | 14 | <string name="hint_currency">currency</string> |
15 | <string name="hint_server_id">serverId</string> | 15 | <string name="hint_server_id">serverId</string> |
16 | <string name="hint_role_id">roleId</string> | 16 | <string name="hint_role_id">roleId</string> |
17 | <string name="hint_extra">extraInfo</string> | 17 | <string name="hint_extra">extraInfo</string> |
18 | <string name="go_pay">Submit</string> | 18 | <string name="go_pay">Submit</string> |
19 | 19 | ||
20 | </resources> | 20 | </resources> |
21 | 21 |