Showing
54 changed files
with
4835 additions
and
0 deletions
Too many changes to show.
To preserve performance only 54 of 54+ files are displayed.
gimiCinema/.gitignore
0 → 100644
gimiCinema/build.gradle
0 → 100644
| 1 | +apply plugin: 'com.android.application' | |
| 2 | +apply plugin: 'com.antfortune.freeline' | |
| 3 | +//apply plugin: 'me.tatarka.retrolambda' | |
| 4 | + | |
| 5 | +def releaseTime = { | |
| 6 | + return new Date().format("MM-dd~HH.mm.ss", TimeZone.getTimeZone("GMT+8:00")) | |
| 7 | +} | |
| 8 | + | |
| 9 | +def isWindows = { | |
| 10 | + return !(new File('build.gradle').getAbsolutePath().startsWith("/User")) | |
| 11 | +} | |
| 12 | + | |
| 13 | +ext { | |
| 14 | + APP_VERSION_CODE = 45; | |
| 15 | + APP_VERSION_NAME = "v4.5"; | |
| 16 | +} | |
| 17 | + | |
| 18 | +android { | |
| 19 | + compileSdkVersion ANDROID_BUILD_COMPILE_SDK_VERSION as int | |
| 20 | + buildToolsVersion ANDROID_BUILD_TOOLS_VERSION | |
| 21 | + | |
| 22 | + lintOptions { | |
| 23 | + abortOnError false | |
| 24 | + } | |
| 25 | + | |
| 26 | + freeline { | |
| 27 | + hack true | |
| 28 | + productFlavor 'QinNing' | |
| 29 | + } | |
| 30 | + | |
| 31 | + compileOptions { | |
| 32 | + sourceCompatibility JavaVersion.VERSION_1_7 | |
| 33 | + targetCompatibility JavaVersion.VERSION_1_7 | |
| 34 | + } | |
| 35 | + | |
| 36 | + sourceSets { | |
| 37 | + main { | |
| 38 | + jniLibs.srcDirs = ['libs'] | |
| 39 | + } | |
| 40 | + } | |
| 41 | + | |
| 42 | + packagingOptions { | |
| 43 | + exclude 'META-INF/DEPENDENCIES' | |
| 44 | + exclude 'META-INF/NOTICE' | |
| 45 | + exclude 'META-INF/LICENSE' | |
| 46 | + exclude 'META-INF/LICENSE.txt' | |
| 47 | + exclude 'META-INF/NOTICE.txt' | |
| 48 | + exclude 'META-INF/maven/com.belerweb/pinyin4j/pom.xml' | |
| 49 | + exclude 'META-INF/maven/com.belerweb/pinyin4j/pom.properties' | |
| 50 | + return false | |
| 51 | + } | |
| 52 | + | |
| 53 | + defaultConfig { | |
| 54 | + applicationId "com.xgimi.gimicinema" | |
| 55 | + minSdkVersion ANDROID_MIN_SDK_VERSION as int | |
| 56 | + targetSdkVersion ANDROID_TARGET_SDK_VERSION as int | |
| 57 | + versionCode APP_VERSION_CODE | |
| 58 | + versionName APP_VERSION_NAME | |
| 59 | + | |
| 60 | + testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" | |
| 61 | + | |
| 62 | +// jackOptions { | |
| 63 | +// enabled true | |
| 64 | +// } | |
| 65 | + } | |
| 66 | + | |
| 67 | + signingConfigs { | |
| 68 | + myConfig { | |
| 69 | + storeFile file('./debug.keystore') | |
| 70 | + storePassword "android" | |
| 71 | + keyAlias 'androiddebugkey' | |
| 72 | + keyPassword 'android' | |
| 73 | + } | |
| 74 | + } | |
| 75 | + buildTypes { | |
| 76 | + release { | |
| 77 | + minifyEnabled false | |
| 78 | + signingConfig signingConfigs.myConfig | |
| 79 | + buildConfigField 'String', 'DEFAULT_IP', "\"192.168.31.202\"" | |
| 80 | + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt' | |
| 81 | + } | |
| 82 | + debug { | |
| 83 | + buildConfigField 'String', 'DEFAULT_IP', "\"192.168.4.215\"" | |
| 84 | +// buildConfigField 'String', 'MACHINE_TYPE', "\"himedia\""; | |
| 85 | +// buildConfigField 'boolean', 'USE_GLIDE', "true"; | |
| 86 | + manifestPlaceholders = [label: "青柠影咖", icon: "@drawable/ic_luancher", channel: "QNJM"] | |
| 87 | + minifyEnabled false | |
| 88 | + signingConfig signingConfigs.myConfig | |
| 89 | + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt' | |
| 90 | + jniDebuggable false | |
| 91 | + } | |
| 92 | + } | |
| 93 | + productFlavors { | |
| 94 | + ZaiXian { | |
| 95 | + buildConfigField 'String', 'MACHINE_TYPE', "\"gimi\"" | |
| 96 | + buildConfigField 'boolean', 'USE_GLIDE', "false" | |
| 97 | + manifestPlaceholders = [label: "在线影院", icon: "@drawable/ic_luancher_zx", channel: "JSZC"] | |
| 98 | + } | |
| 99 | + | |
| 100 | + QinNing { | |
| 101 | +// applicationId "com.qnbar.fangtang.cinema" | |
| 102 | + buildConfigField 'String', 'MACHINE_TYPE', "\"gimi\"" | |
| 103 | + buildConfigField 'boolean', 'USE_GLIDE', "false" | |
| 104 | + manifestPlaceholders = [label: "青柠影咖", icon: "@drawable/ic_luancher", channel: "QN"] | |
| 105 | + } | |
| 106 | + | |
| 107 | + Himedia { | |
| 108 | + buildConfigField 'String', 'MACHINE_TYPE', "\"himedia\""; | |
| 109 | + buildConfigField 'boolean', 'USE_GLIDE', "true"; | |
| 110 | + manifestPlaceholders = [label: "在线影院", icon: "@drawable/ic_luancher_zx", channel: "QN"] | |
| 111 | + } | |
| 112 | + } | |
| 113 | + | |
| 114 | + applicationVariants.all { variant -> | |
| 115 | + variant.outputs.each { output -> | |
| 116 | + def oldFile = output.outputFile | |
| 117 | + println "*****" + oldFile + "*****" | |
| 118 | + | |
| 119 | + if (variant.buildType.name.equals('release')) { | |
| 120 | + def fileName = output.outputFile.name.replace(output.outputFile.name, | |
| 121 | + variant.productFlavors[0].name + "-${variant.versionCode}-${releaseTime()}.apk") | |
| 122 | + output.outputFile = new File(output.outputFile.parent, fileName) | |
| 123 | + // release to test folder | |
| 124 | + println fileName | |
| 125 | +// copyTask() | |
| 126 | + } | |
| 127 | +// if (variant.buildType.name.equals('debug')) { | |
| 128 | +// def fileName = output.outputFile.name.replace(output.outputFile.name, | |
| 129 | +// "debug" + variant.productFlavors[0].name + "-${variant.versionCode}-${releaseTime()}.apk") | |
| 130 | +// output.outputFile = new File(output.outputFile.parent, fileName) | |
| 131 | +// println fileName | |
| 132 | +// } | |
| 133 | + } | |
| 134 | + } | |
| 135 | + return false | |
| 136 | +} | |
| 137 | + | |
| 138 | +dependencies { | |
| 139 | + compile files('libs/decoder.jar') | |
| 140 | + compile files('libs/cinemaLib-1220.jar') | |
| 141 | + compile files('libs/glide-3.7.0.jar') | |
| 142 | + compile files('libs/greenbluetoothlelib.jar') | |
| 143 | + | |
| 144 | + compile project(':transitionhelper') | |
| 145 | + compile project(':uil') | |
| 146 | + compile project(':volley') | |
| 147 | + compile project(':pinying') | |
| 148 | + compile project(':debug-db') | |
| 149 | + | |
| 150 | + compile group: 'com.android.support', name: 'support-v4', version: '25.0.1' | |
| 151 | + compile group: 'com.android.support', name: 'recyclerview-v7', version: '25.0.1' | |
| 152 | + compile group: 'com.squareup.okhttp', name: 'okhttp', version: '2.7.5' | |
| 153 | + compile group: 'com.google.code.gson', name: 'gson', version: '2.4' | |
| 154 | + compile group: 'com.google.zxing', name: 'core', version: '3.3.0' | |
| 155 | + compile group: 'com.umeng.analytics', name: 'umeng-analytics', version: '5.4.1' | |
| 156 | + compile group: 'com.nineoldandroids', name: 'library', version: '2.4.0' | |
| 157 | + compile group: 'com.squareup.retrofit2', name: 'retrofit', version: '2.0.2' | |
| 158 | + compile group: 'com.squareup.retrofit2', name: 'converter-gson', version: '2.0.2' | |
| 159 | + compile 'org.greenrobot:eventbus:3.0.0' | |
| 160 | +} | |
| 161 | + | |
| 162 | +def getPwd(modifyPwd) { | |
| 163 | + return modifyPwd.replaceAll(".*:", "").trim() | |
| 164 | +} | |
| 165 | + | |
| 166 | +def getName(modifyPwd) { | |
| 167 | + return new File(modifyPwd).getName().replace(".java", ""); | |
| 168 | +} | |
| 169 | + | |
| 170 | +task('buildRelease') << { | |
| 171 | + | |
| 172 | +} | |
| 173 | +task releaseToTesting(type: Copy) { | |
| 174 | + from 'build/outputs/apk' | |
| 175 | +// into 'E:/py' | |
| 176 | + if (isWindows()) | |
| 177 | + into '//192.168.4.214/root/apks' | |
| 178 | + else | |
| 179 | + into '/Volumes/root/apks' | |
| 180 | + include '*.apk' | |
| 181 | + exclude { details -> | |
| 182 | + details.file.name.contains('debug') || | |
| 183 | + details.file.name.contains('release') | |
| 184 | + } | |
| 185 | +} | |
| 186 | +build.dependsOn clean | |
| 187 | +releaseToTesting {}.dependsOn build | |
| 188 | +build.shouldRunAfter clean | |
| 189 | +releaseToTesting {}.shouldRunAfter build | |
| 190 | + | |
| 191 | +task tests(type: Copy) { | |
| 192 | + from 'build/outputs/apk' | |
| 193 | +// into 'E:/py' | |
| 194 | + into '/Volumes/root/apks' | |
| 195 | +// into '\\\\192.168.4.214\\root' | |
| 196 | + include '*.apk' | |
| 197 | + exclude { details -> | |
| 198 | + details.file.name.contains('debug') || | |
| 199 | + details.file.name.contains('release') | |
| 200 | + } | |
| 201 | +} | |
| 202 | + | |
| 203 | +task getType() { | |
| 204 | + def pwd = new File('build.gradle').getAbsolutePath() | |
| 205 | + def windows = isWindows(); | |
| 206 | + println pwd + " fuck " + windows | |
| 207 | +} | |
| 208 | + | |
| 209 | +task('gitCommit') << { | |
| 210 | + def debug = false; | |
| 211 | + def pull = "git pull" | |
| 212 | + pull.execute() | |
| 213 | + | |
| 214 | + def cmdStatus = "git status ." | |
| 215 | + println "*****************execute $cmdStatus start*******************" | |
| 216 | + def var = cmdStatus.execute()/*.text.trim()*/ | |
| 217 | + println "*****************execute $cmdStatus start*******************" | |
| 218 | +// println var.text | |
| 219 | + def outputStream = new StringBuffer(); | |
| 220 | + var.waitForProcessOutput(outputStream, System.err) | |
| 221 | + def a = 0; | |
| 222 | + def commitMsg = ""; | |
| 223 | + def commitDelMsg = "删除了"; | |
| 224 | + def commitModMsg = "修改了"; | |
| 225 | + def commitAddMsg = "添加了"; | |
| 226 | + outputStream.toString().eachLine { | |
| 227 | + a++ | |
| 228 | + if (it.contains("build.gradle")) { | |
| 229 | + println "pass build.gradle $it" | |
| 230 | + return | |
| 231 | + } | |
| 232 | + if (it.contains("deleted:")) { | |
| 233 | + def pwd = getPwd(it); | |
| 234 | + println "deleted pwd is :" + pwd | |
| 235 | + commitDelMsg += getName(pwd) + " " | |
| 236 | + if (!debug) { | |
| 237 | + def rm = "git rm " + pwd | |
| 238 | + def rmResult = rm.execute() | |
| 239 | + def rmOutputStream = new StringBuffer() | |
| 240 | + rmResult.waitForProcessOutput(rmOutputStream, System.err) | |
| 241 | + } | |
| 242 | + return | |
| 243 | + } | |
| 244 | + if (it.contains("modified:")) { | |
| 245 | + def pwd = getPwd(it); | |
| 246 | + println "modified pwd is :" + pwd | |
| 247 | + commitModMsg += getName(pwd) + " " | |
| 248 | + if (!debug) { | |
| 249 | + def add = "git add " + pwd | |
| 250 | + def addResult = add.execute() | |
| 251 | + def addOutputStream = new StringBuffer() | |
| 252 | + addResult.waitForProcessOutput(addOutputStream, System.err) | |
| 253 | + } | |
| 254 | + return | |
| 255 | + } | |
| 256 | + | |
| 257 | + if (it.contains("src")) { | |
| 258 | + def pwd = getPwd(it); | |
| 259 | + println "untracked pwd is :" + pwd | |
| 260 | + commitAddMsg += getName(pwd) + " " | |
| 261 | + if (!debug) { | |
| 262 | + def add = "git add " + pwd | |
| 263 | + def addResult = add.execute() | |
| 264 | + def addOutputStream = new StringBuffer() | |
| 265 | + addResult.waitForProcessOutput(addOutputStream, System.err) | |
| 266 | + } | |
| 267 | + } | |
| 268 | + } | |
| 269 | + if (commitDelMsg != "删除了") { | |
| 270 | + commitMsg += commitDelMsg + " " | |
| 271 | + } | |
| 272 | + if (commitModMsg != "修改了") { | |
| 273 | + commitMsg += commitModMsg + " " | |
| 274 | + } | |
| 275 | + if (commitAddMsg != "添加了") { | |
| 276 | + commitMsg += commitAddMsg + " " | |
| 277 | + } | |
| 278 | + | |
| 279 | + println "######################commitMsg##########################" | |
| 280 | + println "$commitMsg" | |
| 281 | + println "######################commitMsg##########################" | |
| 282 | + println "*****************execute $cmdStatus end*******************" | |
| 283 | + | |
| 284 | + if (!debug) { | |
| 285 | + def commit = "git commit -m " + commitMsg | |
| 286 | + def commitResult = commit.execute() | |
| 287 | + def commitOutputStream = new StringBuffer(); | |
| 288 | + commitResult.waitForProcessOutput(commitOutputStream, System.err) | |
| 289 | + def push = "git push" | |
| 290 | + def putResult = push.execute() | |
| 291 | + def pushOutputStream = new StringBuffer() | |
| 292 | + putResult.waitForProcessOutput(pushOutputStream, System.err) | |
| 293 | + } | |
| 294 | +} | ... | ... |
gimiCinema/cinemaLibs.rar
0 → 100644
No preview for this file type
gimiCinema/debug.keystore
0 → 100644
No preview for this file type
gimiCinema/libs/armeabi/libdecode.so
0 → 100644
No preview for this file type
gimiCinema/libs/cinemaLib-1012.jar
0 → 100644
No preview for this file type
gimiCinema/libs/cinemaLib-1109.jar
0 → 100644
No preview for this file type
gimiCinema/libs/cinemaLib-1117.jar
0 → 100644
No preview for this file type
gimiCinema/libs/cinemaLib-1216.jar
0 → 100644
No preview for this file type
gimiCinema/libs/cinemaLib-1220.jar
0 → 100755
No preview for this file type
gimiCinema/libs/decoder.jar
0 → 100644
No preview for this file type
gimiCinema/libs/glide-3.7.0.jar
0 → 100644
No preview for this file type
gimiCinema/libs/greenbluetoothlelib.jar
0 → 100644
No preview for this file type
gimiCinema/src/main/AndroidManifest.xml
0 → 100644
| 1 | +<?xml version="1.0" encoding="utf-8"?> | |
| 2 | +<manifest xmlns:android="http://schemas.android.com/apk/res/android" | |
| 3 | + xmlns:tools="http://schemas.android.com/tools" | |
| 4 | + package="com.xgimi.gimicinema" | |
| 5 | + android:sharedUserId="android.uid.system"> | |
| 6 | + | |
| 7 | + <uses-permission android:name="android.permission.INTERNET"/> | |
| 8 | + <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> | |
| 9 | + <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/> | |
| 10 | + <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> | |
| 11 | + <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/> | |
| 12 | + <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/> | |
| 13 | + <uses-permission android:name="android.permission.RESTART_PACKAGES"/> | |
| 14 | + <uses-permission android:name="android.permission.KILL_BACKGROUND_PROCESSES"/> | |
| 15 | + <uses-permission | |
| 16 | + android:name="android.permission.FORCE_STOP_PACKAGES" | |
| 17 | + tools:ignore="ProtectedPermissions"/> | |
| 18 | + <uses-permission android:name="android.permission.READ_PHONE_STATE"/> | |
| 19 | + <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> | |
| 20 | + | |
| 21 | + <!-- | |
| 22 | + windows not support lable replace by gradle,just replace by string values | |
| 23 | + occour error: AndroidMainfest.xml:line:AAPT:Error parsing XML:not well-formed(invalid toke) -v.8.3 | |
| 24 | + --> | |
| 25 | + <application | |
| 26 | + android:allowBackup="true" | |
| 27 | + android:hardwareAccelerated="true" | |
| 28 | + android:icon="${icon}" | |
| 29 | + android:label="@string/app_name" | |
| 30 | + android:theme="@android:style/Theme.NoTitleBar.Fullscreen"> | |
| 31 | + <meta-data | |
| 32 | + android:name="UMENG_APPKEY" | |
| 33 | + android:value="556ff5c367e58e3d5900180b"/> | |
| 34 | + <meta-data | |
| 35 | + android:name="UMENG_CHANNEL" | |
| 36 | + android:value="${channel}"/> | |
| 37 | + <!-- <meta-data android:name="com.gimi.common.cinema.utils.CustomCachingGlideModule" android:value="GlideModule" /> --> | |
| 38 | + | |
| 39 | + <activity | |
| 40 | + android:name=".activity.StartActivity" | |
| 41 | + android:theme="@style/AppStartTheme"> | |
| 42 | + <intent-filter> | |
| 43 | + <action android:name="android.intent.action.MAIN"/> | |
| 44 | + | |
| 45 | + <category android:name="android.intent.category.LAUNCHER"/> | |
| 46 | + </intent-filter> | |
| 47 | + </activity> | |
| 48 | + <activity | |
| 49 | + android:name=".activity.CinemaConfig" | |
| 50 | + android:theme="@style/AppStartTheme"> | |
| 51 | + </activity> | |
| 52 | + <activity android:name=".activity.NewMovieActivity1"/> | |
| 53 | + <activity android:name=".activity.SearchActivity"/> | |
| 54 | + <activity android:name=".activity.SearchNewActivity"/> | |
| 55 | + <activity android:name=".activity.PlayListActivity"/> | |
| 56 | + <activity android:name=".activity.SettingActivity"/> | |
| 57 | + <activity android:name=".activity.AlarmAlert"/> | |
| 58 | + <activity android:name=".activity.MovieDetailActivity"/> | |
| 59 | + <activity android:name=".activity.MovieInHDActivity"/> | |
| 60 | + <activity | |
| 61 | + android:name=".activity.EnterPassWordActivity" | |
| 62 | + android:theme="@style/DialogActivity"/> | |
| 63 | + <activity android:name=".activity.MainActivity"/> | |
| 64 | + <activity android:name=".activity.MovieDetailInHDActivity"/> | |
| 65 | + <activity android:name=".activity.MovieListActivity"/> | |
| 66 | + <activity android:name=".activity.ChoseSourceActivity"/> | |
| 67 | + <activity android:name=".activity.NewMovie4HJActivity"/> | |
| 68 | + <activity android:name=".cctvsix.activity.M1905MovieDetailActivity"/> | |
| 69 | + <activity android:name=".cctvsix.activity.M1905MovieDetailActivity1"/> | |
| 70 | + <activity android:name=".cctvsix.activity.M1905VideoListActivity"/> | |
| 71 | + <activity android:name=".activity.AddCActivity"/> | |
| 72 | + <activity android:name=".activity.OtherMovieActivity"/> | |
| 73 | + <activity android:name=".activity.SimpleAdsPlayActivity"/> | |
| 74 | + <activity android:name=".activity.SimpleAdsPlayer2"/> | |
| 75 | + <activity android:name=".activity.AdsPreVideoPlayerActivity"/> | |
| 76 | + <activity android:name=".activity.OtherMovieActivityTv"/> | |
| 77 | + <activity android:name=".activity.OtherMovieActivityHome"/> | |
| 78 | + <activity android:name=".activity.ImageShowActivity"/> | |
| 79 | + <activity android:name=".activity.CheckActivity"/> | |
| 80 | + | |
| 81 | + <service android:name=".service.MovieMessageService"/> | |
| 82 | + <service android:name=".service.SearchMovieMessageService"/> | |
| 83 | + <service | |
| 84 | + android:name=".service.AskService" | |
| 85 | + android:persistent="true" | |
| 86 | + android:priority="1000"> <!-- 免杀,?有没有起作用 --> | |
| 87 | + <!-- 提高service优先级 --> | |
| 88 | + <intent-filter> | |
| 89 | + <action android:name="com.qnbar.ask.service"/> | |
| 90 | + </intent-filter> | |
| 91 | + </service> | |
| 92 | + | |
| 93 | + <receiver android:name=".receiver.AlarmReceiver"/> | |
| 94 | + <receiver android:name=".receiver.BootReceiver"> | |
| 95 | + <intent-filter> | |
| 96 | + <action android:name="android.intent.action.BOOT_COMPLETED"/> | |
| 97 | + </intent-filter> | |
| 98 | + </receiver> | |
| 99 | + <receiver android:name=".service.MovieCompleteReceiver"> | |
| 100 | + <intent-filter> | |
| 101 | + <action android:name="com.xgimi.gimicinema.get_data.movie_complete"/> | |
| 102 | + </intent-filter> | |
| 103 | + </receiver> | |
| 104 | + | |
| 105 | + <activity android:name=".activity.MovieListsActivity"/> | |
| 106 | + <activity android:name=".activity.MovieDetailMsgActivity"/> | |
| 107 | + | |
| 108 | + <service | |
| 109 | + android:name=".service.CinemaControlService" | |
| 110 | + android:enabled="true" | |
| 111 | + android:exported="true"> | |
| 112 | + <intent-filter> | |
| 113 | + <action android:name="com.gimicinema.cinemacontrol"/> | |
| 114 | + | |
| 115 | + <category android:name="android.intent.category.DEFAULT"/> | |
| 116 | + </intent-filter> | |
| 117 | + </service> | |
| 118 | + <service | |
| 119 | + android:name=".service.ProguardService" > | |
| 120 | + <intent-filter> | |
| 121 | + <action android:name="com.qnbar.proguard.service"/> | |
| 122 | + </intent-filter> | |
| 123 | + </service> | |
| 124 | + </application> | |
| 125 | + | |
| 126 | +</manifest> | |
| \ No newline at end of file | ... | ... |
| 1 | +// ICinemaControl.aidl | |
| 2 | +package com.xgimi.gimicinema; | |
| 3 | + | |
| 4 | +// Declare any non-default types here with import statements | |
| 5 | +interface ICinemaControl { | |
| 6 | + /** | |
| 7 | + * Demonstrates some basic types that you can use as parameters | |
| 8 | + * and return values in AIDL. | |
| 9 | + */ | |
| 10 | + void basicTypes(int anInt, long aLong, boolean aBoolean, float aFloat, | |
| 11 | + double aDouble, String aString); | |
| 12 | + //设置当前播放电影总时长. | |
| 13 | + void setMovieDuration(long duration); | |
| 14 | + | |
| 15 | + // 获取当前播放电影总时长. | |
| 16 | + long getMovieDuration(); | |
| 17 | + | |
| 18 | + //设置当前播放电影进度. | |
| 19 | + void setCurrentMoviePosition(long duration); | |
| 20 | + | |
| 21 | + //获取当前播放电影进度. | |
| 22 | + long getCurrentMoviePosition(); | |
| 23 | + | |
| 24 | + int getCurrentStatus(); | |
| 25 | + | |
| 26 | + void setCurrentStatus(int state); | |
| 27 | + | |
| 28 | + // 添加新的播放路径到播放列表. | |
| 29 | + void addPlayPath(String path); | |
| 30 | + | |
| 31 | + //设置当前播放电影.if null 播放器没有播放电影 | |
| 32 | + void setCurrentPlayPath(String path); | |
| 33 | + | |
| 34 | + //获取当前播放路径,可以从中获取电影名 | |
| 35 | + String getCurrentPath(); | |
| 36 | + | |
| 37 | + List<String> getPlayList(); | |
| 38 | + | |
| 39 | + void setPlayList(in List<String> movies); | |
| 40 | +} | ... | ... |
| 1 | +// ICinemaSMC.aidl | |
| 2 | +package com.xgimi.gimicinema; | |
| 3 | + | |
| 4 | +// Declare any non-default types here with import statements | |
| 5 | + | |
| 6 | +interface ICinemaSMC { | |
| 7 | + /** | |
| 8 | + * Demonstrates some basic types that you can use as parameters | |
| 9 | + * and return values in AIDL. | |
| 10 | + */ | |
| 11 | + void basicTypes(int anInt, long aLong, boolean aBoolean, float aFloat, | |
| 12 | + double aDouble, String aString); | |
| 13 | + | |
| 14 | + boolean open(); | |
| 15 | + | |
| 16 | + boolean close(); | |
| 17 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.db; | |
| 2 | + | |
| 3 | +import android.content.Context; | |
| 4 | +import android.database.sqlite.SQLiteDatabase; | |
| 5 | +import android.database.sqlite.SQLiteOpenHelper; | |
| 6 | + | |
| 7 | +public class NewDBHelper extends SQLiteOpenHelper { | |
| 8 | + | |
| 9 | + private static final String DATABASE_NAME = "xgimi_cinema_movie.db"; | |
| 10 | + private static final int DATABASE_VERSION = 5; | |
| 11 | + private static final String CREATE_TABLE = "create table movie_message(id integer primary key autoincrement," + | |
| 12 | + "name text," + | |
| 13 | + "path text UNIQUE," + | |
| 14 | + "poster_path text," + | |
| 15 | + "pinyin text," + | |
| 16 | + "md5 text," + | |
| 17 | + "type text," + | |
| 18 | + "douban_id text)"; | |
| 19 | + public static final String TABLE_NAME = "movie_message"; | |
| 20 | + public static final String ID = "id"; | |
| 21 | + public static final String NAME = "name"; | |
| 22 | + public static final String PATH = "path"; | |
| 23 | + public static final String POSTER_PATH = "poster_path"; | |
| 24 | + public static final String PINYIN = "pinyin"; | |
| 25 | + public static final String TYPE = "type"; | |
| 26 | + public static final String DOUBAN_ID = "douban_id"; | |
| 27 | + public static final String MD5 = "md5"; | |
| 28 | + public static final String CLASS_DESCRIBE = "class_describe"; | |
| 29 | + public static final String MOVIE_LENGTH = "movie_length"; | |
| 30 | + public static final String DOUBAN_RATING = "douban_rating"; | |
| 31 | + public static final String LAST_PLAY_TIME = "last_play_time"; | |
| 32 | + public static final String SCREEN_TIME = "screen_time"; | |
| 33 | + public static final String MOVIE_COUNT = "movie_count"; | |
| 34 | + public static final String MOVIE_DL_TIME = "movie_dl_time"; | |
| 35 | + | |
| 36 | + | |
| 37 | + public NewDBHelper(Context context) { | |
| 38 | + //CursorFactory设置为null,使用默认值 | |
| 39 | + super(context, DATABASE_NAME, null, DATABASE_VERSION); | |
| 40 | + } | |
| 41 | + | |
| 42 | + //数据库第一次被创建时onCreate会被调用 | |
| 43 | + @Override | |
| 44 | + public void onCreate(SQLiteDatabase db) { | |
| 45 | + db.execSQL(CREATE_TABLE); | |
| 46 | + db.execSQL(ADD_COLUMNS); | |
| 47 | + db.execSQL(ADD_COLUMNS1); | |
| 48 | + db.execSQL(ADD_COLUMNS2); | |
| 49 | + db.execSQL(ADD_COLUMNS3); | |
| 50 | + db.execSQL(ADD_COLUMNS4); | |
| 51 | + db.execSQL(ADD_COLUMNS5); | |
| 52 | + db.execSQL(ADD_COLUMNS6); | |
| 53 | + } | |
| 54 | + | |
| 55 | + private static final String ADD_COLUMNS = "ALTER TABLE movie_message ADD class_describe TEXT"; | |
| 56 | + private static final String ADD_COLUMNS1 = "ALTER TABLE movie_message ADD movie_length TEXT"; | |
| 57 | + private static final String ADD_COLUMNS2 = "ALTER TABLE movie_message ADD douban_rating TEXT"; | |
| 58 | + private static final String ADD_COLUMNS3 = "ALTER TABLE movie_message ADD last_play_time TEXT"; | |
| 59 | + private static final String ADD_COLUMNS4 = "ALTER TABLE movie_message ADD screen_time TEXT"; | |
| 60 | + private static final String ADD_COLUMNS5 = "ALTER TABLE movie_message ADD movie_count TEXT"; | |
| 61 | + private static final String ADD_COLUMNS6 = "ALTER TABLE movie_message ADD movie_dl_time TEXT"; | |
| 62 | + | |
| 63 | + | |
| 64 | + private static final String DROP_TABLE = "drop table if exists movie_message"; | |
| 65 | + //如果DATABASE_VERSION值被改为2,系统发现现有数据库版本不同,即会调用onUpgrade | |
| 66 | + @Override | |
| 67 | + public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { | |
| 68 | + if (newVersion != oldVersion) { | |
| 69 | + db.execSQL(DROP_TABLE); | |
| 70 | + onCreate(db); | |
| 71 | + } | |
| 72 | + } | |
| 73 | + | |
| 74 | + @Override | |
| 75 | + public void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) { | |
| 76 | + if (newVersion != oldVersion) { | |
| 77 | + db.execSQL(DROP_TABLE); | |
| 78 | + onCreate(db); | |
| 79 | + } | |
| 80 | + } | |
| 81 | +} | |
| \ No newline at end of file | ... | ... |
| 1 | +package com.gimi.common.cinema.db; | |
| 2 | + | |
| 3 | +import android.content.ContentValues; | |
| 4 | +import android.content.Context; | |
| 5 | +import android.database.Cursor; | |
| 6 | +import android.database.sqlite.SQLiteDatabase; | |
| 7 | +import android.text.TextUtils; | |
| 8 | +import android.util.Log; | |
| 9 | +import com.gimi.common.cinema.model.LocalMovieMessage; | |
| 10 | +import com.gimi.common.cinema.model.QueryType; | |
| 11 | +import com.gimi.common.cinema.model.SourceType; | |
| 12 | +import com.xgimi.gimicinema.activity.CinemaConfig; | |
| 13 | + | |
| 14 | +import java.io.File; | |
| 15 | +import java.util.ArrayList; | |
| 16 | +import java.util.List; | |
| 17 | + | |
| 18 | +public class NewDBManager { | |
| 19 | + private SQLiteDatabase db; | |
| 20 | + | |
| 21 | + public NewDBManager(Context context) { | |
| 22 | + NewDBHelper helper = new NewDBHelper(context); | |
| 23 | + //因为getWritableDatabase内部调用了mContext.openOrCreateDatabase(mName, 0, mFactory); | |
| 24 | + //所以要确保context已初始化,可以把实例化DBManager的步骤放在Activity的onCreate里 | |
| 25 | + db = helper.getWritableDatabase(); | |
| 26 | + } | |
| 27 | + | |
| 28 | + /** | |
| 29 | + * 利用事务批量添加本地数据 | |
| 30 | + * | |
| 31 | + * @param localMovieMessageList movie list | |
| 32 | + * @param clear if clear | |
| 33 | + * @return boolean | |
| 34 | + */ | |
| 35 | + public boolean add(List<LocalMovieMessage> localMovieMessageList, boolean clear) { | |
| 36 | + boolean result = false; | |
| 37 | + db.beginTransaction(); //开始事务 | |
| 38 | + try { | |
| 39 | + //do delete if need | |
| 40 | + if (clear) { | |
| 41 | + db.delete(NewDBHelper.TABLE_NAME, null, null); | |
| 42 | + } | |
| 43 | + for (LocalMovieMessage person : localMovieMessageList) { | |
| 44 | + ContentValues cv = constructCv(person); | |
| 45 | + db.insert(NewDBHelper.TABLE_NAME, null, cv); | |
| 46 | + } | |
| 47 | + db.setTransactionSuccessful(); //设置事务成功完成 | |
| 48 | + result = true; | |
| 49 | + } catch (Exception e) { | |
| 50 | + e.printStackTrace(); | |
| 51 | + result = false; | |
| 52 | + } finally { | |
| 53 | + db.endTransaction(); //结束事务 | |
| 54 | + } | |
| 55 | + return result; | |
| 56 | + } | |
| 57 | + | |
| 58 | + /** | |
| 59 | + * public static final String ID = "id"; | |
| 60 | + * public static final String NAME = "name"; | |
| 61 | + * public static final String PATH = "path"; | |
| 62 | + * public static final String POSTER_PATH = "poster_path"; | |
| 63 | + * public static final String PINYIN = "pinyin"; | |
| 64 | + * public static final String TYPE = "type"; | |
| 65 | + * public static final String DOUBAN_ID = "douban_id"; | |
| 66 | + * public static final String MD5 = "md5"; | |
| 67 | + * public static final String CLASS_DESCRIBE = "class_describe"; | |
| 68 | + * public static final String MOVIE_LENGTH = "movie_length"; | |
| 69 | + * public static final String DOUBAN_RATING = "douban_rating"; | |
| 70 | + * | |
| 71 | + * @param localMovieMessage movie msg | |
| 72 | + * @return contentValues | |
| 73 | + */ | |
| 74 | + private ContentValues constructCv(LocalMovieMessage localMovieMessage) { | |
| 75 | + ContentValues cv = new ContentValues(); | |
| 76 | + cv.put(NewDBHelper.NAME, localMovieMessage.getMovieName()); | |
| 77 | + cv.put(NewDBHelper.PATH, localMovieMessage.getPlayPath().replace(CinemaConfig.BASIC_ROOT, "")); | |
| 78 | + String posterPath = localMovieMessage.getPosterPath(); | |
| 79 | + if (!TextUtils.isEmpty(posterPath)) { | |
| 80 | + cv.put(NewDBHelper.POSTER_PATH, posterPath.replace(CinemaConfig.BASIC_ROOT, "")); | |
| 81 | + } | |
| 82 | + cv.put(NewDBHelper.PINYIN, localMovieMessage.getNamePinyin()); | |
| 83 | + cv.put(NewDBHelper.MD5, localMovieMessage.getMd5()); | |
| 84 | + if (localMovieMessage.getDoubanRating() != 0) { | |
| 85 | + cv.put(NewDBHelper.DOUBAN_RATING, localMovieMessage.getDoubanRating()); | |
| 86 | + } | |
| 87 | + if (localMovieMessage.getCount() != 0) { | |
| 88 | + cv.put(NewDBHelper.MOVIE_COUNT, localMovieMessage.getCount()); | |
| 89 | + } | |
| 90 | + if (!TextUtils.isEmpty(localMovieMessage.getDoubanId())) { | |
| 91 | + cv.put(NewDBHelper.DOUBAN_ID, localMovieMessage.getDoubanId()); | |
| 92 | + } | |
| 93 | + if (!TextUtils.isEmpty(localMovieMessage.getDlTime())) { | |
| 94 | + cv.put(NewDBHelper.MOVIE_DL_TIME, localMovieMessage.getDlTime()); | |
| 95 | + } | |
| 96 | + if (localMovieMessage.getClassDescribe() != null) { | |
| 97 | + cv.put(NewDBHelper.CLASS_DESCRIBE, localMovieMessage.getClassDescribe()); | |
| 98 | + } | |
| 99 | + if (localMovieMessage.getMovieLength() != null) { | |
| 100 | + cv.put(NewDBHelper.MOVIE_LENGTH, localMovieMessage.getMovieLength()); | |
| 101 | + } | |
| 102 | + if (localMovieMessage.getType() != null) { | |
| 103 | + cv.put(NewDBHelper.TYPE, localMovieMessage.getType()); | |
| 104 | + } | |
| 105 | + if (localMovieMessage.getScreenTime() != null) { | |
| 106 | + cv.put(NewDBHelper.SCREEN_TIME, localMovieMessage.getScreenTime()); | |
| 107 | + } | |
| 108 | + return cv; | |
| 109 | + } | |
| 110 | + | |
| 111 | + /** | |
| 112 | + * 利用事务批量添加本地数据,存在的数据不再更新,不存在的直接插入 | |
| 113 | + * | |
| 114 | + * @param localMovieMessageList lst | |
| 115 | + * @return boolean | |
| 116 | + */ | |
| 117 | + public boolean add1905(List<LocalMovieMessage> localMovieMessageList) { | |
| 118 | + boolean result = false; | |
| 119 | + for (LocalMovieMessage localMovieMessage : localMovieMessageList) { | |
| 120 | + result = insertLocalMM1905(localMovieMessage); | |
| 121 | + } | |
| 122 | + return result; | |
| 123 | + } | |
| 124 | + | |
| 125 | + private boolean insertLocalMM1905(LocalMovieMessage localMovieMessage) { | |
| 126 | + int id = queryId1905(localMovieMessage); | |
| 127 | + return updateLocalMM1905(localMovieMessage, id); | |
| 128 | + } | |
| 129 | + | |
| 130 | + private int queryId1905(LocalMovieMessage lmm) { | |
| 131 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 132 | + Cursor c = db.query(NewDBHelper.TABLE_NAME, null, "md5 = ? and path = ?", | |
| 133 | + new String[]{"qnyb_abc_test", lmm.getPlayPath()}, null, null, null); | |
| 134 | + readCursor2List(persons, c); | |
| 135 | + c.close(); | |
| 136 | + if (persons.size() == 0) { | |
| 137 | + return -1; | |
| 138 | + } else { | |
| 139 | + for (LocalMovieMessage person : persons) { | |
| 140 | + if (person.getPlayPath().equals(lmm.getPlayPath()) | |
| 141 | + && person.getMd5().equals(lmm.getMd5())) { | |
| 142 | + return person.getId(); | |
| 143 | + } | |
| 144 | + } | |
| 145 | + return -1; | |
| 146 | + } | |
| 147 | + } | |
| 148 | + | |
| 149 | + private boolean updateLocalMM1905(LocalMovieMessage localMovieMessage, int id) { | |
| 150 | + boolean result; | |
| 151 | + if (id == -1) { | |
| 152 | + result = add(localMovieMessage, true); | |
| 153 | + } else { | |
| 154 | + return updateDoubanMsg(localMovieMessage); | |
| 155 | + } | |
| 156 | + return result; | |
| 157 | + } | |
| 158 | + | |
| 159 | + /** | |
| 160 | + * 利用事务批量添加本地数据,存在的数据不再更新,不存在的直接插入 | |
| 161 | + * | |
| 162 | + * @param localMovieMessageList lst | |
| 163 | + * @return boolean | |
| 164 | + */ | |
| 165 | + public boolean add(List<LocalMovieMessage> localMovieMessageList) { | |
| 166 | + boolean result = false; | |
| 167 | + for (LocalMovieMessage localMovieMessage : localMovieMessageList) { | |
| 168 | + result = insertLocalMM(localMovieMessage); | |
| 169 | + } | |
| 170 | + return result; | |
| 171 | + } | |
| 172 | + | |
| 173 | + public void deleteFileNotExists() { | |
| 174 | + List<LocalMovieMessage> result = query(); | |
| 175 | + for (LocalMovieMessage lmm : result) | |
| 176 | + if (!new File(lmm.getPlayPath()).exists() | |
| 177 | + && !"qnyb_abc_test".equals(lmm.getMd5())) { | |
| 178 | + delete(lmm); | |
| 179 | + Log.d("lovely", "delete success " + lmm.getMovieName()); | |
| 180 | + } | |
| 181 | + } | |
| 182 | + | |
| 183 | + /** | |
| 184 | + * 单个添加本地数据 | |
| 185 | + * | |
| 186 | + * @param localMovieMessage movie message | |
| 187 | + */ | |
| 188 | + public void add(LocalMovieMessage localMovieMessage) { | |
| 189 | + db.beginTransaction(); //开始事务 | |
| 190 | + try { | |
| 191 | + ContentValues contentValues = constructCv(localMovieMessage); | |
| 192 | + db.insert(NewDBHelper.TABLE_NAME, null, contentValues); | |
| 193 | + db.setTransactionSuccessful(); //设置事务成功完成 | |
| 194 | + } finally { | |
| 195 | + db.endTransaction(); //结束事务 | |
| 196 | + } | |
| 197 | + } | |
| 198 | + | |
| 199 | + /** | |
| 200 | + * 单个添加本地数据 | |
| 201 | + * | |
| 202 | + * @param localMovieMessage local | |
| 203 | + */ | |
| 204 | + public boolean add(LocalMovieMessage localMovieMessage, boolean insert) { | |
| 205 | + boolean result = false; | |
| 206 | + db.beginTransaction(); //开始事务 | |
| 207 | + try { | |
| 208 | + if (insert) { | |
| 209 | + ContentValues contentValues = constructCv(localMovieMessage); | |
| 210 | + db.insert(NewDBHelper.TABLE_NAME, null, contentValues); | |
| 211 | + } else { | |
| 212 | + ContentValues contentValues = constructCv(localMovieMessage); | |
| 213 | + db.updateWithOnConflict(NewDBHelper.TABLE_NAME, contentValues, "id=?", | |
| 214 | + new String[]{String.valueOf(localMovieMessage.getId())}, SQLiteDatabase.CONFLICT_REPLACE); | |
| 215 | +// db.update(NewDBoHelper.TABLE_NAME, contentValues, " id = ", new String[]{String.valueOf(localMovieMessage.getId())}); | |
| 216 | + } | |
| 217 | + db.setTransactionSuccessful(); //设置事务成功完成 | |
| 218 | + result = true; | |
| 219 | + } catch (Exception e) { | |
| 220 | + e.printStackTrace(); | |
| 221 | + } finally { | |
| 222 | + db.endTransaction(); //结束事务 | |
| 223 | + } | |
| 224 | + return result; | |
| 225 | + } | |
| 226 | + | |
| 227 | + | |
| 228 | + private int queryId(LocalMovieMessage lmm) {//not right | |
| 229 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 230 | + Cursor c = db.query(NewDBHelper.TABLE_NAME, null, "md5 = ?", new String[]{lmm.getMd5()}, null, null, null); | |
| 231 | + readCursor2List(persons, c); | |
| 232 | + c.close(); | |
| 233 | + if (persons.size() == 0) { | |
| 234 | + return -1; | |
| 235 | + } else { | |
| 236 | + for (LocalMovieMessage person : persons) { | |
| 237 | + if (person.getPlayPath().equals(lmm.getPlayPath()) && person.getMd5().equals(lmm.getMd5()) | |
| 238 | + && person.getPlayPath().startsWith("/mnt/samba")) { | |
| 239 | + return person.getId(); | |
| 240 | + } | |
| 241 | + } | |
| 242 | + return -1; | |
| 243 | + } | |
| 244 | + } | |
| 245 | + | |
| 246 | + private LocalMovieMessage queryByPath(String lmm) { | |
| 247 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 248 | + Cursor c = db.query(NewDBHelper.TABLE_NAME, null, "path = ?", new String[]{lmm}, null, null, null); | |
| 249 | + readCursor2List(persons, c); | |
| 250 | + c.close(); | |
| 251 | + if (persons.size() == 0) { | |
| 252 | + return null; | |
| 253 | + } else { | |
| 254 | + for (LocalMovieMessage person : persons) { | |
| 255 | + if (person.getPlayPath().equals(lmm)) { | |
| 256 | + return person; | |
| 257 | + } | |
| 258 | + } | |
| 259 | + return null; | |
| 260 | + } | |
| 261 | + } | |
| 262 | + | |
| 263 | + private void readCursor2List(ArrayList<LocalMovieMessage> persons, Cursor c) { | |
| 264 | + while (c.moveToNext()) { | |
| 265 | + LocalMovieMessage person = new LocalMovieMessage(); | |
| 266 | + person.setId(c.getInt(c.getColumnIndex(NewDBHelper.ID))); | |
| 267 | + person.setMovieName(c.getString(c.getColumnIndex(NewDBHelper.NAME))); | |
| 268 | + person.setPlayPath(c.getString(c.getColumnIndex(NewDBHelper.PATH))); | |
| 269 | + person.setPosterPath(c.getString(c.getColumnIndex(NewDBHelper.POSTER_PATH))); | |
| 270 | + person.setNamePinyin(c.getString(c.getColumnIndex(NewDBHelper.PINYIN))); | |
| 271 | + person.setType(c.getString(c.getColumnIndex(NewDBHelper.TYPE))); | |
| 272 | + person.setDoubanId(c.getString(c.getColumnIndex(NewDBHelper.DOUBAN_ID))); | |
| 273 | + person.setMd5(c.getString(c.getColumnIndex(NewDBHelper.MD5))); | |
| 274 | + person.setClassDescribe(c.getString(c.getColumnIndex(NewDBHelper.CLASS_DESCRIBE))); | |
| 275 | + person.setMovieLength(c.getString(c.getColumnIndex(NewDBHelper.MOVIE_LENGTH))); | |
| 276 | + int columnIndex = c.getColumnIndex(NewDBHelper.DOUBAN_RATING); | |
| 277 | + person.setDoubanRating(c.getDouble(columnIndex)); | |
| 278 | + int timeIndex = c.getColumnIndex(NewDBHelper.LAST_PLAY_TIME); | |
| 279 | + if (timeIndex != -1) { | |
| 280 | + person.setLastPlayTime(c.getLong(timeIndex)); | |
| 281 | + } | |
| 282 | + int screenIndex = c.getColumnIndex(NewDBHelper.SCREEN_TIME); | |
| 283 | + if (screenIndex != -1) { | |
| 284 | + person.setScreenTime(c.getString(screenIndex)); | |
| 285 | + } | |
| 286 | + int dlTimeIdx = c.getColumnIndex(NewDBHelper.MOVIE_DL_TIME); | |
| 287 | + if (dlTimeIdx != -1) { | |
| 288 | + person.setDlTime(c.getString(dlTimeIdx)); | |
| 289 | + } | |
| 290 | + int countIdx = c.getColumnIndex(NewDBHelper.MOVIE_COUNT); | |
| 291 | + if (countIdx != -1) { | |
| 292 | + person.setCount(c.getInt(countIdx)); | |
| 293 | + } | |
| 294 | + persons.add(person); | |
| 295 | + } | |
| 296 | + } | |
| 297 | + | |
| 298 | + private boolean insertLocalMM(LocalMovieMessage localMovieMessage) { | |
| 299 | + int id = queryId(localMovieMessage); | |
| 300 | + return updateLocalMM(localMovieMessage, id); | |
| 301 | + } | |
| 302 | + | |
| 303 | + private boolean updateLocalMM(LocalMovieMessage localMovieMessage, int id) { | |
| 304 | + boolean result; | |
| 305 | + if (id == -1) { | |
| 306 | + result = add(localMovieMessage, true); | |
| 307 | + } else { | |
| 308 | + localMovieMessage.setId(id); | |
| 309 | + result = add(localMovieMessage, false); | |
| 310 | + } | |
| 311 | + return result; | |
| 312 | + } | |
| 313 | + | |
| 314 | + /** | |
| 315 | + * query all | |
| 316 | + * | |
| 317 | + * @return persons | |
| 318 | + */ | |
| 319 | + public List<LocalMovieMessage> query() { | |
| 320 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 321 | + Cursor c = db.query(NewDBHelper.TABLE_NAME, null, null, null, null, null, null); | |
| 322 | + readCursor2List(persons, c); | |
| 323 | + c.close(); | |
| 324 | + return persons; | |
| 325 | + } | |
| 326 | + | |
| 327 | + /** | |
| 328 | + * query queryIdNotNullAndPostNull | |
| 329 | + * | |
| 330 | + * @return persons | |
| 331 | + */ | |
| 332 | + public List<LocalMovieMessage> queryIdNotNullAndPostNull() { | |
| 333 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 334 | + getNullItems(persons, NewDBHelper.DOUBAN_ID + " is not null and " + NewDBHelper.POSTER_PATH + " is null"); | |
| 335 | + return persons; | |
| 336 | + } | |
| 337 | + | |
| 338 | + private void getNullItems(ArrayList<LocalMovieMessage> persons, String condition) { | |
| 339 | + Cursor c = db.query(NewDBHelper.TABLE_NAME, null, condition, null, null, null, null); | |
| 340 | + readCursor2List(persons, c); | |
| 341 | + c.close(); | |
| 342 | + } | |
| 343 | + | |
| 344 | + /** | |
| 345 | + * query poster | |
| 346 | + * | |
| 347 | + * @return persons | |
| 348 | + */ | |
| 349 | + public ArrayList<LocalMovieMessage> queryPosterDoubanIdNull() { | |
| 350 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 351 | + getNullItems(persons, NewDBHelper.POSTER_PATH + " is null and " + NewDBHelper.DOUBAN_ID + " is null"); | |
| 352 | + return persons; | |
| 353 | + } | |
| 354 | + | |
| 355 | + /** | |
| 356 | + * query all movie from 1905 and qn | |
| 357 | + * | |
| 358 | + * @return persons | |
| 359 | + */ | |
| 360 | + public List<LocalMovieMessage> queryType(String key, QueryType queryType, SourceType sourceType) { | |
| 361 | + String sql = "SELECT distinct(path),id,name,poster_path,path,pinyin,md5,douban_id,type,class_describe,movie_length,douban_rating,screen_time" + | |
| 362 | + " FROM movie_message where";/* + " path like '%" + key + "%'";*/ | |
| 363 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 364 | + StringBuffer sb = new StringBuffer(sql); | |
| 365 | + | |
| 366 | + String queryQn = " path like '%/" + key + "/%'"; | |
| 367 | + if (sourceType == SourceType.SOURCE_ALL || sourceType == SourceType.SOURCE_JUST_QN) { | |
| 368 | + sb.append(queryQn); | |
| 369 | + } | |
| 370 | + | |
| 371 | + String order = " order by pinyin asc"; | |
| 372 | + switch (queryType) { | |
| 373 | + case QUERY_TYPE_SCREEN_TIME: | |
| 374 | + order = " order by screen_time desc"; | |
| 375 | + break; | |
| 376 | + case QUERY_TYPE_RATING: | |
| 377 | + order = " order by douban_rating desc"; | |
| 378 | + break; | |
| 379 | + case QUERY_TYPE_DOWNLOAD_TIME: | |
| 380 | + order = " order by cast(movie_dl_time as int) desc"; | |
| 381 | + break; | |
| 382 | + case QUERY_TYPE_DEMAND: | |
| 383 | + order = " order by cast(movie_count as int) desc"; | |
| 384 | + break; | |
| 385 | + } | |
| 386 | +// String order = " order by " + orderKey + (isUp ? " desc" : " asc"); | |
| 387 | + String sqlSub = " and path not like '%/LXJ/%'"; | |
| 388 | + if (key.equals("XJ/")) { | |
| 389 | + if (sourceType == SourceType.SOURCE_ALL || sourceType == SourceType.SOURCE_JUST_QN) { | |
| 390 | + sb.append(sqlSub); | |
| 391 | + } | |
| 392 | + } | |
| 393 | + | |
| 394 | + //if use 1905 | |
| 395 | + String query1905 = getAppendCond(key); | |
| 396 | + if (sourceType == SourceType.SOURCE_ALL || sourceType == SourceType.SOURCE_JUST_1905) { | |
| 397 | + if (sourceType == SourceType.SOURCE_ALL) { | |
| 398 | + if (!TextUtils.isEmpty(query1905)) { | |
| 399 | + sb.append(" or "); | |
| 400 | + } | |
| 401 | + } | |
| 402 | + sb.append(query1905); | |
| 403 | + } | |
| 404 | + if (sourceType == SourceType.SOURCE_JUST_1905 && TextUtils.isEmpty(query1905)) { | |
| 405 | + return persons; | |
| 406 | + } | |
| 407 | +// sb.append(query1905); | |
| 408 | + | |
| 409 | + sb.append(order); | |
| 410 | + | |
| 411 | + Cursor c = db.rawQuery(sb.toString(), null); | |
| 412 | + readCursor2List(persons, c); | |
| 413 | + c.close(); | |
| 414 | + return persons; | |
| 415 | + } | |
| 416 | + | |
| 417 | + private static final int RECOMMEND_MOVIE_COUNT = 200; | |
| 418 | + private static final int PXB_MOVIE_COUNT = 200; | |
| 419 | + | |
| 420 | + /** | |
| 421 | + * query all recommend qn | |
| 422 | + * | |
| 423 | + * @return persons | |
| 424 | + */ | |
| 425 | + public List<LocalMovieMessage> queryAllNewMovies() { | |
| 426 | + String sql = "SELECT * FROM movie_message order by cast(movie_dl_time as int) desc limit " + RECOMMEND_MOVIE_COUNT;/* + " path like '%" + key + "%'";*/ | |
| 427 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 428 | + StringBuffer sb = new StringBuffer(sql); | |
| 429 | + | |
| 430 | + Cursor c = db.rawQuery(sb.toString(), null); | |
| 431 | + readCursor2List(persons, c); | |
| 432 | + c.close(); | |
| 433 | + return persons; | |
| 434 | + } | |
| 435 | + | |
| 436 | + /** | |
| 437 | + * query all recommend qn | |
| 438 | + * | |
| 439 | + * @return persons | |
| 440 | + */ | |
| 441 | + public List<LocalMovieMessage> queryAllDemandMovies() { | |
| 442 | + String sql = "SELECT * FROM movie_message order by cast(" + NewDBHelper.MOVIE_COUNT + " as int) desc, cast(movie_dl_time as int) desc limit " + PXB_MOVIE_COUNT;/* + " path like '%" + key + "%'";*/ | |
| 443 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 444 | + StringBuffer sb = new StringBuffer(sql); | |
| 445 | + | |
| 446 | + Cursor c = db.rawQuery(sb.toString(), null); | |
| 447 | + readCursor2List(persons, c); | |
| 448 | + c.close(); | |
| 449 | + return persons; | |
| 450 | + } | |
| 451 | + | |
| 452 | + private String getAppendCond(String key) { | |
| 453 | + String rtn = ""; | |
| 454 | + if (key.contains("KH")) { | |
| 455 | + rtn = " class_describe like '%科幻%' and md5 = 'qnyb_abc_test'"; | |
| 456 | + return rtn; | |
| 457 | + } else if (key.contains("DZ")) { | |
| 458 | + rtn = " class_describe like '%动作%' and md5 = 'qnyb_abc_test'"; | |
| 459 | + return rtn; | |
| 460 | + } else if (key.contains("KB")) { | |
| 461 | + rtn = " class_describe like '%恐怖%' and md5 = 'qnyb_abc_test'"; | |
| 462 | + return rtn; | |
| 463 | + } else if (key.contains("XJ")) { | |
| 464 | + if (!key.contains("LXJ")) { | |
| 465 | + rtn = " class_describe like '%喜剧%' and md5 = 'qnyb_abc_test'"; | |
| 466 | + } | |
| 467 | + return rtn; | |
| 468 | + } else if (key.contains("AQ")) { | |
| 469 | + rtn = " class_describe like '%爱情%' and md5 = 'qnyb_abc_test'"; | |
| 470 | + return rtn; | |
| 471 | + } else if (key.contains("JQ")) { | |
| 472 | + rtn = " class_describe like '%剧情%' and md5 = 'qnyb_abc_test'"; | |
| 473 | + return rtn; | |
| 474 | + } else if (key.contains("DM")) { | |
| 475 | + rtn = " class_describe like '%儿童%' and md5 = 'qnyb_abc_test' or class_describe like '%动画%' and md5 = 'qnyb_abc_test'"; | |
| 476 | + return rtn; | |
| 477 | + } else if (key.contains("TJ")) { | |
| 478 | + rtn = " class_describe like '%经典%' and md5 = 'qnyb_abc_test'"; | |
| 479 | + return rtn; | |
| 480 | + } else if (key.contains("TY")) { | |
| 481 | + rtn = " class_describe like '%运动%' and md5 = 'qnyb_abc_test'"; | |
| 482 | + return rtn; | |
| 483 | + } | |
| 484 | + return rtn; | |
| 485 | + } | |
| 486 | + | |
| 487 | + public List<LocalMovieMessage> queryTop(int top, QueryType queryType) { | |
| 488 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 489 | + String orderBy = NewDBHelper.DOUBAN_RATING + " desc"; | |
| 490 | + switch (queryType) { | |
| 491 | + case QUERY_TYPE_NAME: | |
| 492 | + orderBy = NewDBHelper.PINYIN + " asc"; | |
| 493 | + break; | |
| 494 | + case QUERY_TYPE_SCREEN_TIME: | |
| 495 | + orderBy = "screen_time desc"; | |
| 496 | + break; | |
| 497 | + } | |
| 498 | + Cursor c = db.query(NewDBHelper.TABLE_NAME, null, null, null, null, null, orderBy, String.valueOf(top)); | |
| 499 | + readCursor2List(persons, c); | |
| 500 | + c.close(); | |
| 501 | + return persons; | |
| 502 | + } | |
| 503 | + | |
| 504 | + /** | |
| 505 | + * query all | |
| 506 | + * | |
| 507 | + * @return persons | |
| 508 | + */ | |
| 509 | + public List<LocalMovieMessage> queryRecommend() { | |
| 510 | + return queryTJLimit(4); | |
| 511 | + } | |
| 512 | + | |
| 513 | + private List<LocalMovieMessage> queryTJLimit(int limitNum) { | |
| 514 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 515 | + String sql = "SELECT * FROM movie_message where path like '%/TJ/%' and poster_path is not null"; | |
| 516 | + StringBuffer sb = new StringBuffer(sql); | |
| 517 | +// String order = " order by douban_rating desc"; | |
| 518 | + String order = " order by random()"; | |
| 519 | + String limit = " limit " + limitNum; | |
| 520 | + sb.append(order).append(limit); | |
| 521 | + | |
| 522 | + Cursor c = db.rawQuery(sb.toString(), null); | |
| 523 | + readCursor2List(persons, c); | |
| 524 | + c.close(); | |
| 525 | + return persons; | |
| 526 | + } | |
| 527 | + | |
| 528 | + /** | |
| 529 | + * query all | |
| 530 | + * | |
| 531 | + * @return persons | |
| 532 | + */ | |
| 533 | + public List<LocalMovieMessage> queryRecommendInDetail() { | |
| 534 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 535 | +// String sql = "SELECT * FROM movie_message where path like '%/TJ/%' and poster_path is not null"; | |
| 536 | + String sql = "SELECT * FROM movie_message where path like '%/TJ/%'" + " order by random() limit 7 "; | |
| 537 | + StringBuffer sb = new StringBuffer(sql); | |
| 538 | + | |
| 539 | + Cursor c = db.rawQuery(sb.toString(), null); | |
| 540 | + readCursor2List(persons, c); | |
| 541 | +// if (persons.size() < 5) { | |
| 542 | +// sql = sql + " class_describe like '%经典%' and md5 = 'qnyb_abc_test'"; | |
| 543 | +// } | |
| 544 | + c.close(); | |
| 545 | + return persons; | |
| 546 | + } | |
| 547 | + | |
| 548 | + /** | |
| 549 | + * query all record contain key, return list | |
| 550 | + * | |
| 551 | + * @return List<Person> | |
| 552 | + */ | |
| 553 | + public List<LocalMovieMessage> queryKey(String key) { | |
| 554 | + key = key.toLowerCase(); | |
| 555 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 556 | + /*StringBuffer keyBuffer = new StringBuffer(); | |
| 557 | + keyBuffer.append("'"); | |
| 558 | + for (int i = 0; i < key.length(); i++) { | |
| 559 | + keyBuffer.append("%").append(key.charAt(i)).append("%"); | |
| 560 | + } | |
| 561 | + keyBuffer.append("'");*/ | |
| 562 | +// Cursor c = db.rawQuery("SELECT * FROM movie_message where pinyin LIKE '%" + key + "%' order by length(pinyin) asc limit 0,20", null); | |
| 563 | + String sql = "SELECT * FROM movie_message where pinyin LIKE " + "'%" + key + "%'" + " order by length(name) asc limit 20"; | |
| 564 | + Cursor c = db.rawQuery(sql, null); | |
| 565 | + readCursor2List(persons, c); | |
| 566 | + c.close(); | |
| 567 | + return persons; | |
| 568 | + } | |
| 569 | + | |
| 570 | + /** | |
| 571 | + * query all record contain key, return list | |
| 572 | + * | |
| 573 | + * @return List<Person> | |
| 574 | + */ | |
| 575 | + public List<LocalMovieMessage> querySearchRecommend() { | |
| 576 | + return queryTJLimit(22); | |
| 577 | + } | |
| 578 | + | |
| 579 | + /** | |
| 580 | + * 删除 | |
| 581 | + * | |
| 582 | + * @param lmm movie message | |
| 583 | + * @return boolean | |
| 584 | + */ | |
| 585 | + public boolean delete(LocalMovieMessage lmm) { | |
| 586 | + db.delete(NewDBHelper.TABLE_NAME, "id = ?", new String[]{String.valueOf(lmm.getId())}); | |
| 587 | +// String sql = "DELETE FROM movie_message where id = " + lmm.getId(); | |
| 588 | +// db.execSQL(sql); | |
| 589 | + return false; | |
| 590 | + } | |
| 591 | + | |
| 592 | + /** | |
| 593 | + * 更新电影分类,豆瓣评分 | |
| 594 | + * | |
| 595 | + * @param lmm movie message | |
| 596 | + * @return boolean | |
| 597 | + */ | |
| 598 | + public boolean updateDoubanMsg(LocalMovieMessage lmm) { | |
| 599 | + boolean result = false; | |
| 600 | + db.beginTransaction(); | |
| 601 | + try { | |
| 602 | + ContentValues cv = constructCv(lmm); | |
| 603 | + db.update(NewDBHelper.TABLE_NAME, cv, "id = ? ", new String[]{String.valueOf(lmm.getId())}); | |
| 604 | + db.setTransactionSuccessful(); // changes get rolled back if this not called | |
| 605 | + result = true; | |
| 606 | + } catch (Exception e) { | |
| 607 | + e.printStackTrace(); | |
| 608 | + result = false; | |
| 609 | + } finally { | |
| 610 | + db.endTransaction(); // commit or rollback | |
| 611 | + } | |
| 612 | + return result; | |
| 613 | + } | |
| 614 | + | |
| 615 | + /** | |
| 616 | + * 更新电影分类,豆瓣评分 | |
| 617 | + * | |
| 618 | + * @param lmm movie message | |
| 619 | + * @return boolean | |
| 620 | + */ | |
| 621 | + public boolean updateMovieMsg(LocalMovieMessage lmm) { | |
| 622 | + boolean result; | |
| 623 | + db.beginTransaction(); | |
| 624 | + ContentValues cv = constructCv(lmm); | |
| 625 | +// db.update(NewDBHelper.TABLE_NAME, cv, "id = ? ", new String[]{String.valueOf(lmm.getId())}); | |
| 626 | + db.updateWithOnConflict(NewDBHelper.TABLE_NAME, cv, "id = ? ", new String[]{String.valueOf(lmm.getId())},SQLiteDatabase.CONFLICT_REPLACE); | |
| 627 | + db.setTransactionSuccessful(); // changes get rolled back if this not called | |
| 628 | + result = true; | |
| 629 | + db.endTransaction(); // commit or rollback | |
| 630 | + return result; | |
| 631 | + } | |
| 632 | + | |
| 633 | + /** | |
| 634 | + * updateMovieCount,现想主要用于已有本地数据,更新网络数据 | |
| 635 | + * | |
| 636 | + * @param lmm movie message | |
| 637 | + * @return boolean | |
| 638 | + */ | |
| 639 | + public boolean updateMovieCount(LocalMovieMessage lmm) { | |
| 640 | + boolean result = false; | |
| 641 | + db.beginTransaction(); | |
| 642 | + try { | |
| 643 | + ContentValues cv = new ContentValues(); | |
| 644 | + cv.put(NewDBHelper.MOVIE_COUNT, lmm.getCount()); | |
| 645 | + db.update(NewDBHelper.TABLE_NAME, cv, "id = ? ", new String[]{String.valueOf(lmm.getId())}); | |
| 646 | + db.setTransactionSuccessful(); // changes get rolled back if this not called | |
| 647 | + result = true; | |
| 648 | + } catch (Exception e) { | |
| 649 | + e.printStackTrace(); | |
| 650 | + result = false; | |
| 651 | + } finally { | |
| 652 | + db.endTransaction(); // commit or rollback | |
| 653 | + } | |
| 654 | + return result; | |
| 655 | + } | |
| 656 | + | |
| 657 | + /** | |
| 658 | + * updateMovieCount,现想主要用于已有本地数据,更新网络数据 | |
| 659 | + * | |
| 660 | + * @param path movie path | |
| 661 | + * @param count movie click count | |
| 662 | + * @return boolean | |
| 663 | + */ | |
| 664 | + public boolean updateMovieCount(String path, int count) { | |
| 665 | + LocalMovieMessage localMovieMessage = queryByPath(path); | |
| 666 | + if (localMovieMessage != null) { | |
| 667 | + localMovieMessage.setCount(count); | |
| 668 | + return updateMovieCount(localMovieMessage); | |
| 669 | + } | |
| 670 | + return false; | |
| 671 | + } | |
| 672 | + | |
| 673 | + | |
| 674 | + public boolean updatePlayTime(LocalMovieMessage lmm) { | |
| 675 | + boolean result = false; | |
| 676 | + db.beginTransaction(); | |
| 677 | + try { | |
| 678 | + ContentValues cv = new ContentValues(); | |
| 679 | + cv.put(NewDBHelper.LAST_PLAY_TIME, System.currentTimeMillis()); | |
| 680 | + db.update(NewDBHelper.TABLE_NAME, cv, "id = ? ", new String[]{String.valueOf(lmm.getId())}); | |
| 681 | + db.setTransactionSuccessful(); // changes get rolled back if this not called | |
| 682 | + result = true; | |
| 683 | + } catch (Exception e) { | |
| 684 | + e.printStackTrace(); | |
| 685 | + result = false; | |
| 686 | + } finally { | |
| 687 | + db.endTransaction(); // commit or rollback | |
| 688 | + } | |
| 689 | + return result; | |
| 690 | + } | |
| 691 | + | |
| 692 | + public List<LocalMovieMessage> queryLastPlay(int top) { | |
| 693 | + ArrayList<LocalMovieMessage> persons = new ArrayList<LocalMovieMessage>(); | |
| 694 | + Cursor c = db.query(NewDBHelper.TABLE_NAME, null, | |
| 695 | + NewDBHelper.LAST_PLAY_TIME + " != ?", new String[]{String.valueOf(0)}, | |
| 696 | + null, null, NewDBHelper.LAST_PLAY_TIME + " desc", String.valueOf(top)); | |
| 697 | + readCursor2List(persons, c); | |
| 698 | + c.close(); | |
| 699 | + return persons; | |
| 700 | + } | |
| 701 | + | |
| 702 | + | |
| 703 | + /** | |
| 704 | + * close database | |
| 705 | + */ | |
| 706 | + public void closeDB() { | |
| 707 | + db.close(); | |
| 708 | + } | |
| 709 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by wugian on 2016/8/4 | |
| 5 | + */ | |
| 6 | +public class AdsProof { | |
| 7 | + | |
| 8 | + /** | |
| 9 | + * code : 0 | |
| 10 | + * message : 成功 | |
| 11 | + */ | |
| 12 | + | |
| 13 | + private int code; | |
| 14 | + private String msg; | |
| 15 | + | |
| 16 | + public int getCode() { | |
| 17 | + return code; | |
| 18 | + } | |
| 19 | + | |
| 20 | + public void setCode(int code) { | |
| 21 | + this.code = code; | |
| 22 | + } | |
| 23 | + | |
| 24 | + public String getMsg() { | |
| 25 | + return msg; | |
| 26 | + } | |
| 27 | + | |
| 28 | + public void setMsg(String msg) { | |
| 29 | + this.msg = msg; | |
| 30 | + } | |
| 31 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by wugian on 2016/12/17 | |
| 5 | + */ | |
| 6 | + | |
| 7 | +public class AgentInfo { | |
| 8 | + | |
| 9 | + /** | |
| 10 | + * code : 0 | |
| 11 | + * msg : 成功 | |
| 12 | + * data : {"agent":{"agentId":"81","agentName":"广东省廉江市花田影咖","agentPic":"","agentAddr":"广东省湛江市廉江市石城大道东66号","agentTel":"13724745600","agentType":"2","addTime":"1454763474","distTime":"1486656000","status":"1","agentSequence":"1","sysVersion":"1"}} | |
| 13 | + */ | |
| 14 | + | |
| 15 | + private int code; | |
| 16 | + private String msg; | |
| 17 | + private DataBean data; | |
| 18 | + | |
| 19 | + public int getCode() { | |
| 20 | + return code; | |
| 21 | + } | |
| 22 | + | |
| 23 | + public void setCode(int code) { | |
| 24 | + this.code = code; | |
| 25 | + } | |
| 26 | + | |
| 27 | + public String getMsg() { | |
| 28 | + return msg; | |
| 29 | + } | |
| 30 | + | |
| 31 | + public void setMsg(String msg) { | |
| 32 | + this.msg = msg; | |
| 33 | + } | |
| 34 | + | |
| 35 | + public DataBean getData() { | |
| 36 | + return data; | |
| 37 | + } | |
| 38 | + | |
| 39 | + public void setData(DataBean data) { | |
| 40 | + this.data = data; | |
| 41 | + } | |
| 42 | + | |
| 43 | + public static class DataBean { | |
| 44 | + /** | |
| 45 | + * agent : {"agentId":"81","agentName":"广东省廉江市花田影咖","agentPic":"","agentAddr":"广东省湛江市廉江市石城大道东66号","agentTel":"13724745600","agentType":"2","addTime":"1454763474","distTime":"1486656000","status":"1","agentSequence":"1","sysVersion":"1"} | |
| 46 | + */ | |
| 47 | + | |
| 48 | + private AgentBean agent; | |
| 49 | + | |
| 50 | + public AgentBean getAgent() { | |
| 51 | + return agent; | |
| 52 | + } | |
| 53 | + | |
| 54 | + public void setAgent(AgentBean agent) { | |
| 55 | + this.agent = agent; | |
| 56 | + } | |
| 57 | + | |
| 58 | + public static class AgentBean { | |
| 59 | + /** | |
| 60 | + * agentId : 81 | |
| 61 | + * agentName : 广东省廉江市花田影咖 | |
| 62 | + * agentPic : | |
| 63 | + * agentAddr : 广东省湛江市廉江市石城大道东66号 | |
| 64 | + * agentTel : 13724745600 | |
| 65 | + * agentType : 2 | |
| 66 | + * addTime : 1454763474 | |
| 67 | + * distTime : 1486656000 | |
| 68 | + * status : 1 | |
| 69 | + * agentSequence : 1 | |
| 70 | + * sysVersion : 1 | |
| 71 | + */ | |
| 72 | + | |
| 73 | + private String agentId; | |
| 74 | + private String agentName; | |
| 75 | + private String agentPic; | |
| 76 | + private String agentAddr; | |
| 77 | + private String agentTel; | |
| 78 | + private String agentType; | |
| 79 | + private String addTime; | |
| 80 | + private String distTime; | |
| 81 | + private String status; | |
| 82 | + private String agentSequence; | |
| 83 | + private String sysVersion; | |
| 84 | + | |
| 85 | + public String getAgentId() { | |
| 86 | + return agentId; | |
| 87 | + } | |
| 88 | + | |
| 89 | + public void setAgentId(String agentId) { | |
| 90 | + this.agentId = agentId; | |
| 91 | + } | |
| 92 | + | |
| 93 | + public String getAgentName() { | |
| 94 | + return agentName; | |
| 95 | + } | |
| 96 | + | |
| 97 | + public void setAgentName(String agentName) { | |
| 98 | + this.agentName = agentName; | |
| 99 | + } | |
| 100 | + | |
| 101 | + public String getAgentPic() { | |
| 102 | + return agentPic; | |
| 103 | + } | |
| 104 | + | |
| 105 | + public void setAgentPic(String agentPic) { | |
| 106 | + this.agentPic = agentPic; | |
| 107 | + } | |
| 108 | + | |
| 109 | + public String getAgentAddr() { | |
| 110 | + return agentAddr; | |
| 111 | + } | |
| 112 | + | |
| 113 | + public void setAgentAddr(String agentAddr) { | |
| 114 | + this.agentAddr = agentAddr; | |
| 115 | + } | |
| 116 | + | |
| 117 | + public String getAgentTel() { | |
| 118 | + return agentTel; | |
| 119 | + } | |
| 120 | + | |
| 121 | + public void setAgentTel(String agentTel) { | |
| 122 | + this.agentTel = agentTel; | |
| 123 | + } | |
| 124 | + | |
| 125 | + public String getAgentType() { | |
| 126 | + return agentType; | |
| 127 | + } | |
| 128 | + | |
| 129 | + public void setAgentType(String agentType) { | |
| 130 | + this.agentType = agentType; | |
| 131 | + } | |
| 132 | + | |
| 133 | + public String getAddTime() { | |
| 134 | + return addTime; | |
| 135 | + } | |
| 136 | + | |
| 137 | + public void setAddTime(String addTime) { | |
| 138 | + this.addTime = addTime; | |
| 139 | + } | |
| 140 | + | |
| 141 | + public String getDistTime() { | |
| 142 | + return distTime; | |
| 143 | + } | |
| 144 | + | |
| 145 | + public void setDistTime(String distTime) { | |
| 146 | + this.distTime = distTime; | |
| 147 | + } | |
| 148 | + | |
| 149 | + public String getStatus() { | |
| 150 | + return status; | |
| 151 | + } | |
| 152 | + | |
| 153 | + public void setStatus(String status) { | |
| 154 | + this.status = status; | |
| 155 | + } | |
| 156 | + | |
| 157 | + public String getAgentSequence() { | |
| 158 | + return agentSequence; | |
| 159 | + } | |
| 160 | + | |
| 161 | + public void setAgentSequence(String agentSequence) { | |
| 162 | + this.agentSequence = agentSequence; | |
| 163 | + } | |
| 164 | + | |
| 165 | + public String getSysVersion() { | |
| 166 | + return sysVersion; | |
| 167 | + } | |
| 168 | + | |
| 169 | + public void setSysVersion(String sysVersion) { | |
| 170 | + this.sysVersion = sysVersion; | |
| 171 | + } | |
| 172 | + } | |
| 173 | + } | |
| 174 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by wugian on 2016/8/5 | |
| 5 | + */ | |
| 6 | +public class ApkMessage { | |
| 7 | + /** | |
| 8 | + * code : 0 | |
| 9 | + * msg : 成功 | |
| 10 | + * data : {"verCode":"41","verName":"v4.1","description":"1,数据库共用.#2,搜索功能优化.#3,扫描优化.#3,其他片源兼容测试","appUrl":"http://apkhome.qiniudn.com/088/GimiCinema-qinlin-4.0-40-1.apk"} | |
| 11 | + */ | |
| 12 | + | |
| 13 | + private int code; | |
| 14 | + private String msg; | |
| 15 | + /** | |
| 16 | + * verCode : 41 | |
| 17 | + * verName : v4.1 | |
| 18 | + * description : 1,数据库共用.#2,搜索功能优化.#3,扫描优化.#3,其他片源兼容测试 | |
| 19 | + * appUrl : http://apkhome.qiniudn.com/088/GimiCinema-qinlin-4.0-40-1.apk | |
| 20 | + */ | |
| 21 | + | |
| 22 | + private DataEntity data; | |
| 23 | + | |
| 24 | + public int getCode() { | |
| 25 | + return code; | |
| 26 | + } | |
| 27 | + | |
| 28 | + public void setCode(int code) { | |
| 29 | + this.code = code; | |
| 30 | + } | |
| 31 | + | |
| 32 | + public String getMsg() { | |
| 33 | + return msg; | |
| 34 | + } | |
| 35 | + | |
| 36 | + public void setMsg(String msg) { | |
| 37 | + this.msg = msg; | |
| 38 | + } | |
| 39 | + | |
| 40 | + public DataEntity getData() { | |
| 41 | + return data; | |
| 42 | + } | |
| 43 | + | |
| 44 | + public void setData(DataEntity data) { | |
| 45 | + this.data = data; | |
| 46 | + } | |
| 47 | + | |
| 48 | + public static class DataEntity { | |
| 49 | + private int verCode; | |
| 50 | + private String verName; | |
| 51 | + private String description; | |
| 52 | + private String appUrl; | |
| 53 | + | |
| 54 | + public int getVerCode() { | |
| 55 | + return verCode; | |
| 56 | + } | |
| 57 | + | |
| 58 | + public void setVerCode(int verCode) { | |
| 59 | + this.verCode = verCode; | |
| 60 | + } | |
| 61 | + | |
| 62 | + public String getVerName() { | |
| 63 | + return verName; | |
| 64 | + } | |
| 65 | + | |
| 66 | + public void setVerName(String verName) { | |
| 67 | + this.verName = verName; | |
| 68 | + } | |
| 69 | + | |
| 70 | + public String getDescription() { | |
| 71 | + return description; | |
| 72 | + } | |
| 73 | + | |
| 74 | + public void setDescription(String description) { | |
| 75 | + this.description = description; | |
| 76 | + } | |
| 77 | + | |
| 78 | + public String getAppUrl() { | |
| 79 | + return appUrl; | |
| 80 | + } | |
| 81 | + | |
| 82 | + public void setAppUrl(String appUrl) { | |
| 83 | + this.appUrl = appUrl; | |
| 84 | + } | |
| 85 | + } | |
| 86 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +public class AsyncCallback<T> { | |
| 4 | + // private static final String TAG = AsynCallback.class.getSimpleName(); | |
| 5 | + | |
| 6 | + public void onStart() { | |
| 7 | + } | |
| 8 | + | |
| 9 | + public void onDone() { | |
| 10 | + } | |
| 11 | + | |
| 12 | + public void onSuccess(T data) { | |
| 13 | + } | |
| 14 | + | |
| 15 | + public void onMessage(String data) { | |
| 16 | + } | |
| 17 | + | |
| 18 | + public void onFailure(final WrongMsg caught) { | |
| 19 | + } | |
| 20 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import android.os.Parcel; | |
| 4 | +import android.os.Parcelable; | |
| 5 | + | |
| 6 | +/** | |
| 7 | + * Data provide foundation class(photo Music Video Other search). | |
| 8 | + */ | |
| 9 | +public class BaseData implements Parcelable { | |
| 10 | + private String name; | |
| 11 | + private String path; | |
| 12 | + private long duration; | |
| 13 | + private int doubanId; | |
| 14 | + private String doubanUrl; | |
| 15 | + private String posterUrl; | |
| 16 | + private long lastPlayPosition; | |
| 17 | + private long lastPlayTime; | |
| 18 | + | |
| 19 | + public BaseData() { | |
| 20 | + } | |
| 21 | + | |
| 22 | + public int getDoubanId() { | |
| 23 | + return doubanId; | |
| 24 | + } | |
| 25 | + | |
| 26 | + public void setDoubanId(int doubanId) { | |
| 27 | + this.doubanId = doubanId; | |
| 28 | + } | |
| 29 | + | |
| 30 | + public String getDoubanUrl() { | |
| 31 | + return doubanUrl; | |
| 32 | + } | |
| 33 | + | |
| 34 | + public void setDoubanUrl(String doubanUrl) { | |
| 35 | + this.doubanUrl = doubanUrl; | |
| 36 | + } | |
| 37 | + | |
| 38 | + public String getPosterUrl() { | |
| 39 | + return posterUrl; | |
| 40 | + } | |
| 41 | + | |
| 42 | + public void setPosterUrl(String posterUrl) { | |
| 43 | + this.posterUrl = posterUrl; | |
| 44 | + } | |
| 45 | + | |
| 46 | + public long getLastPlayPosition() { | |
| 47 | + return lastPlayPosition; | |
| 48 | + } | |
| 49 | + | |
| 50 | + public void setLastPlayPosition(long lastPlayPosition) { | |
| 51 | + this.lastPlayPosition = lastPlayPosition; | |
| 52 | + } | |
| 53 | + | |
| 54 | + public long getLastPlayTime() { | |
| 55 | + return lastPlayTime; | |
| 56 | + } | |
| 57 | + | |
| 58 | + public void setLastPlayTime(long lastPlayTime) { | |
| 59 | + this.lastPlayTime = lastPlayTime; | |
| 60 | + } | |
| 61 | + | |
| 62 | + public void setDuration(long duration) { | |
| 63 | + this.duration = duration; | |
| 64 | + } | |
| 65 | + | |
| 66 | + public long getDuration() { | |
| 67 | + return duration; | |
| 68 | + } | |
| 69 | + | |
| 70 | + /** | |
| 71 | + * @return the name | |
| 72 | + */ | |
| 73 | + public String getName() { | |
| 74 | + return name; | |
| 75 | + } | |
| 76 | + | |
| 77 | + /** | |
| 78 | + * @param name the name to set | |
| 79 | + */ | |
| 80 | + public void setName(String name) { | |
| 81 | + this.name = name; | |
| 82 | + } | |
| 83 | + | |
| 84 | + /** | |
| 85 | + * @return the path | |
| 86 | + */ | |
| 87 | + public String getPath() { | |
| 88 | + return path; | |
| 89 | + } | |
| 90 | + | |
| 91 | + /** | |
| 92 | + * @param path the path to set | |
| 93 | + */ | |
| 94 | + public void setPath(String path) { | |
| 95 | + this.path = path; | |
| 96 | + } | |
| 97 | + | |
| 98 | + @Override | |
| 99 | + public String toString() { | |
| 100 | + return "BaseData{" + | |
| 101 | + "name='" + name + '\'' + | |
| 102 | + ", path='" + path + '\'' + | |
| 103 | + ", duration=" + duration + | |
| 104 | + ", doubanId=" + doubanId + | |
| 105 | + ", doubanUrl='" + doubanUrl + '\'' + | |
| 106 | + ", posterUrl='" + posterUrl + '\'' + | |
| 107 | + ", lastPlayPosition=" + lastPlayPosition + | |
| 108 | + ", lastPlayTime=" + lastPlayTime + | |
| 109 | + '}'; | |
| 110 | + } | |
| 111 | + | |
| 112 | + | |
| 113 | + @Override | |
| 114 | + public int describeContents() { | |
| 115 | + return 0; | |
| 116 | + } | |
| 117 | + | |
| 118 | + @Override | |
| 119 | + public void writeToParcel(Parcel dest, int flags) { | |
| 120 | + dest.writeString(this.name); | |
| 121 | + dest.writeString(this.path); | |
| 122 | + dest.writeLong(this.duration); | |
| 123 | + dest.writeInt(this.doubanId); | |
| 124 | + dest.writeString(this.doubanUrl); | |
| 125 | + dest.writeString(this.posterUrl); | |
| 126 | + dest.writeLong(this.lastPlayPosition); | |
| 127 | + dest.writeLong(this.lastPlayTime); | |
| 128 | + } | |
| 129 | + | |
| 130 | + protected BaseData(Parcel in) { | |
| 131 | + this.name = in.readString(); | |
| 132 | + this.path = in.readString(); | |
| 133 | + this.duration = in.readLong(); | |
| 134 | + this.doubanId = in.readInt(); | |
| 135 | + this.doubanUrl = in.readString(); | |
| 136 | + this.posterUrl = in.readString(); | |
| 137 | + this.lastPlayPosition = in.readLong(); | |
| 138 | + this.lastPlayTime = in.readLong(); | |
| 139 | + } | |
| 140 | + | |
| 141 | + public static final Creator<BaseData> CREATOR = new Creator<BaseData>() { | |
| 142 | + public BaseData createFromParcel(Parcel source) { | |
| 143 | + return new BaseData(source); | |
| 144 | + } | |
| 145 | + | |
| 146 | + public BaseData[] newArray(int size) { | |
| 147 | + return new BaseData[size]; | |
| 148 | + } | |
| 149 | + }; | |
| 150 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by 李攀 on 2015/12/21. | |
| 5 | + */ | |
| 6 | +public class CinemaConfig { | |
| 7 | + private int dbVersion; | |
| 8 | + private int classVersion; | |
| 9 | + private String[] classArray; | |
| 10 | + | |
| 11 | + public CinemaConfig() { | |
| 12 | + } | |
| 13 | + | |
| 14 | + public int getDbVersion() { | |
| 15 | + return dbVersion; | |
| 16 | + } | |
| 17 | + | |
| 18 | + public void setDbVersion(int dbVersion) { | |
| 19 | + this.dbVersion = dbVersion; | |
| 20 | + } | |
| 21 | + | |
| 22 | + public int getClassVersion() { | |
| 23 | + return classVersion; | |
| 24 | + } | |
| 25 | + | |
| 26 | + public void setClassVersion(int classVersion) { | |
| 27 | + this.classVersion = classVersion; | |
| 28 | + } | |
| 29 | + | |
| 30 | + | |
| 31 | + public String[] getClassArray() { | |
| 32 | + return classArray; | |
| 33 | + } | |
| 34 | + | |
| 35 | + public void setClassArray(String[] classArray) { | |
| 36 | + this.classArray = classArray; | |
| 37 | + } | |
| 38 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by 李攀 on 2015/7/7. | |
| 5 | + */ | |
| 6 | +public class ClassificationItem { | |
| 7 | + private int color; | |
| 8 | + private String name; | |
| 9 | + private int icon; | |
| 10 | + | |
| 11 | + public int getColor() { | |
| 12 | + return color; | |
| 13 | + } | |
| 14 | + | |
| 15 | + public void setColor(int color) { | |
| 16 | + this.color = color; | |
| 17 | + } | |
| 18 | + | |
| 19 | + public String getName() { | |
| 20 | + return name; | |
| 21 | + } | |
| 22 | + | |
| 23 | + public void setName(String name) { | |
| 24 | + this.name = name; | |
| 25 | + } | |
| 26 | + | |
| 27 | + public int getIcon() { | |
| 28 | + return icon; | |
| 29 | + } | |
| 30 | + | |
| 31 | + public void setIcon(int icon) { | |
| 32 | + this.icon = icon; | |
| 33 | + } | |
| 34 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by wugian on 2016/3/1. | |
| 5 | + */ | |
| 6 | +public class CodeData { | |
| 7 | + | |
| 8 | + /** | |
| 9 | + * data : | |
| 10 | + * code : 602 | |
| 11 | + * message : 此机器未被分配! | |
| 12 | + */ | |
| 13 | + | |
| 14 | + private int code; | |
| 15 | + private String message; | |
| 16 | + | |
| 17 | + public void setCode(int code) { | |
| 18 | + this.code = code; | |
| 19 | + } | |
| 20 | + | |
| 21 | + public void setMessage(String message) { | |
| 22 | + this.message = message; | |
| 23 | + } | |
| 24 | + | |
| 25 | + public int getCode() { | |
| 26 | + return code; | |
| 27 | + } | |
| 28 | + | |
| 29 | + public String getMessage() { | |
| 30 | + return message; | |
| 31 | + } | |
| 32 | + | |
| 33 | + @Override | |
| 34 | + public String toString() { | |
| 35 | + return "CodeData{" + | |
| 36 | + "code=" + code + | |
| 37 | + ", message='" + message + '\'' + | |
| 38 | + '}'; | |
| 39 | + } | |
| 40 | +} | |
| \ No newline at end of file | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import com.xgimi.gimicinema.BuildConfig; | |
| 4 | + | |
| 5 | +/** | |
| 6 | + * Created by pc on 2014/12/11 | |
| 7 | + */ | |
| 8 | +public class Constant { | |
| 9 | + public static final String XML_NAME = "gimi-cinema-pref"; | |
| 10 | + | |
| 11 | + public static final String ACTION_GET_MESSAGE_MEDIA_PLAYER_MOVIE_COMPLETE = "com.xgimi.gimicinema.get_data.movie_complete"; | |
| 12 | + public static final String ACTION_GET_MESSAGE_CLOSE_LED = "com.xgimi.gimicinema_close_led"; | |
| 13 | + public static final String GIMI_AUTHENTICATION = "gimi-authentication"; | |
| 14 | + public static boolean run = true; | |
| 15 | + public static boolean messageRun = true; | |
| 16 | + public static boolean startAds = false;//现定义每部电影放完后播放两次广告,若系统结算则及时关闭光机,反之播放两次视频后再关闭光机 | |
| 17 | + public static boolean isAdsOn = false; | |
| 18 | + | |
| 19 | + public static boolean gimiAuth = true; | |
| 20 | + | |
| 21 | + | |
| 22 | + public static String MOVIE_MESSAGE_NAME_NEW = "/mm.qnt"; | |
| 23 | + public static String MOVIE_MESSAGE_NAME_OLD = "/mm.txt"; | |
| 24 | + | |
| 25 | + public static String MOVIE_POSTER_GIF = "/video.gif"; | |
| 26 | + public static String MOVIE_POSTER_NEW = "/poster.qnj"; | |
| 27 | + public static String MOVIE_POSTER_OLD = "/poster.jpg"; | |
| 28 | + public static String MOVIE_COUNT = "/.count.qdat"; | |
| 29 | + | |
| 30 | + public static final int DB_INIT_SUCCESS = 0x0; | |
| 31 | + public static final int DB_INIT_FAILURE = 0x1; | |
| 32 | + public static final int DB_INIT_ZERO = 0x2; | |
| 33 | + public static final int DB_INIT_DONE = 0x3; | |
| 34 | + public static final int DB_INIT_START = 0x5; | |
| 35 | + public static final int DB_INIT_MSG = 0xE; | |
| 36 | + public static final int DB_DELETE_NOT_EXIST_START = 0x1A; | |
| 37 | + public static final int DB_DELETE_NOT_EXIST_SUCCESS = 0x1B; | |
| 38 | + public static final int DB_DELETE_NOT_EXIST_FAILURE = 0x1C; | |
| 39 | + public static final int DB_DELETE_NOT_EXIST_END = 0x1D; | |
| 40 | + | |
| 41 | + public static final int DB_UPDATE_DOUBAN_MSG_START = 0x20; | |
| 42 | + public static final int DB_UPDATE_DOUBAN_MSG_SUCCESS = 0x21; | |
| 43 | + public static final int DB_UPDATE_DOUBAN_MSG_FAILURE = 0x22; | |
| 44 | + public static final int DB_UPDATE_DOUBAN_MSG_END = 0x23; | |
| 45 | + | |
| 46 | + public static final String DEFAULT_IP = BuildConfig.DEFAULT_IP; | |
| 47 | + public static final String DEFAULT_USER = "admin"; | |
| 48 | + public static final String DEFAULT_PWD = "Asd123456"; | |
| 49 | + public static final String DEFAULT_FOLDER = "root"; | |
| 50 | + public static final String DEFAULT_PATH = ""; | |
| 51 | + public static boolean userOpen = false; | |
| 52 | +} | ... | ... |
| 1 | +/* | |
| 2 | + * Copyright 2016 wugian | |
| 3 | + * | |
| 4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | |
| 5 | + * you may not use this file except in compliance with the License. | |
| 6 | + * You may obtain a copy of the License at | |
| 7 | + * | |
| 8 | + * http://www.apache.org/licenses/LICENSE-2.0 | |
| 9 | + * | |
| 10 | + * Unless required by applicable law or agreed to in writing, software | |
| 11 | + * distributed under the License is distributed on an "AS IS" BASIS, | |
| 12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 13 | + * See the License for the specific language governing permissions and | |
| 14 | + * limitations under the License. | |
| 15 | + */ | |
| 16 | + | |
| 17 | +package com.gimi.common.cinema.model; | |
| 18 | + | |
| 19 | +/** | |
| 20 | + * Created by wugian on 2016/12/28 | |
| 21 | + */ | |
| 22 | + | |
| 23 | +public class ControlMessage { | |
| 24 | + public int action;//0:默认播放单个电影,1:播放列表电影,2,同步播放电影相关状态(电影路径, | |
| 25 | + // 播放列表,电影进度,电影长度,电影播放状态 ) | |
| 26 | + public UdpModel udpModel; | |
| 27 | + | |
| 28 | + public int getAction() { | |
| 29 | + return action; | |
| 30 | + } | |
| 31 | + | |
| 32 | + public void setAction(int action) { | |
| 33 | + this.action = action; | |
| 34 | + } | |
| 35 | + | |
| 36 | + public UdpModel getUdpModel() { | |
| 37 | + return udpModel; | |
| 38 | + } | |
| 39 | + | |
| 40 | + public void setUdpModel(UdpModel udpModel) { | |
| 41 | + this.udpModel = udpModel; | |
| 42 | + } | |
| 43 | + | |
| 44 | + @Override | |
| 45 | + public String toString() { | |
| 46 | + return "ControlMessage{" + | |
| 47 | + "action=" + action + | |
| 48 | + ", status=" + udpModel + | |
| 49 | + '}'; | |
| 50 | + } | |
| 51 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import java.io.Serializable; | |
| 4 | + | |
| 5 | +/** | |
| 6 | + * Created by pc on 2014/12/9 | |
| 7 | + */ | |
| 8 | +//@Table(name = "type_table") | |
| 9 | +public class FolderItem implements Serializable { | |
| 10 | +// @Property(column = "_id") | |
| 11 | + private int id; | |
| 12 | +// @Property(column = "folder_name") | |
| 13 | + private String folderName; | |
| 14 | +// @Property(column = "poster_path") | |
| 15 | + private String posterPath; | |
| 16 | +// @Property(column = "folder_path") | |
| 17 | + private String folderPath; | |
| 18 | + | |
| 19 | + | |
| 20 | + public int getId() { | |
| 21 | + return id; | |
| 22 | + } | |
| 23 | + | |
| 24 | + public void setId(int id) { | |
| 25 | + this.id = id; | |
| 26 | + } | |
| 27 | + | |
| 28 | + public String getFolderName() { | |
| 29 | + return folderName; | |
| 30 | + } | |
| 31 | + | |
| 32 | + public void setFolderName(String folderName) { | |
| 33 | + this.folderName = folderName; | |
| 34 | + } | |
| 35 | + | |
| 36 | + public String getPosterPath() { | |
| 37 | + return posterPath; | |
| 38 | + } | |
| 39 | + | |
| 40 | + public void setPosterPath(String posterPath) { | |
| 41 | + this.posterPath = posterPath; | |
| 42 | + } | |
| 43 | + | |
| 44 | + public String getFolderPath() { | |
| 45 | + return folderPath; | |
| 46 | + } | |
| 47 | + | |
| 48 | + public void setFolderPath(String folderPath) { | |
| 49 | + this.folderPath = folderPath; | |
| 50 | + } | |
| 51 | + | |
| 52 | + @Override | |
| 53 | + public String toString() { | |
| 54 | + return "FolderItem{" + | |
| 55 | + "id=" + id + | |
| 56 | + ", folderName='" + folderName + '\'' + | |
| 57 | + ", posterPath='" + posterPath + '\'' + | |
| 58 | + ", folderPath='" + folderPath + '\'' + | |
| 59 | + '}'; | |
| 60 | + } | |
| 61 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by pc on 2015/1/6 | |
| 5 | + */ | |
| 6 | +public class GimiData { | |
| 7 | + // "status":"on","delay":300 | |
| 8 | + private String status; | |
| 9 | + private int delay; | |
| 10 | + | |
| 11 | + public String getStatus() { | |
| 12 | + return status; | |
| 13 | + } | |
| 14 | + | |
| 15 | + public void setStatus(String status) { | |
| 16 | + this.status = status; | |
| 17 | + } | |
| 18 | + | |
| 19 | + public int getDelay() { | |
| 20 | + return delay; | |
| 21 | + } | |
| 22 | + | |
| 23 | + public void setDelay(int delay) { | |
| 24 | + this.delay = delay; | |
| 25 | + } | |
| 26 | + | |
| 27 | + @Override | |
| 28 | + public String toString() { | |
| 29 | + return "GimiData{" + | |
| 30 | + "status='" + status + '\'' + | |
| 31 | + ", delay=" + delay + | |
| 32 | + '}'; | |
| 33 | + } | |
| 34 | +} | |
| 35 | + | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import com.google.gson.annotations.Expose; | |
| 4 | + | |
| 5 | +/** | |
| 6 | + * Created by pc on 2015/1/6. | |
| 7 | + * 服务器的消息用来判定系统的状态开关 | |
| 8 | + */ | |
| 9 | +public class GimiMessage { | |
| 10 | + // {"data":{"status":"on","delay":300},"code":200,"message":"ok"} | |
| 11 | + @Expose | |
| 12 | + private int code; | |
| 13 | + @Expose | |
| 14 | + private String message; | |
| 15 | + @Expose | |
| 16 | + private GimiData data; | |
| 17 | + | |
| 18 | + public int getCode() { | |
| 19 | + return code; | |
| 20 | + } | |
| 21 | + | |
| 22 | + public void setCode(int code) { | |
| 23 | + this.code = code; | |
| 24 | + } | |
| 25 | + | |
| 26 | + public String getMessage() { | |
| 27 | + return message; | |
| 28 | + } | |
| 29 | + | |
| 30 | + public void setMessage(String message) { | |
| 31 | + this.message = message; | |
| 32 | + } | |
| 33 | + | |
| 34 | + public GimiData getData() { | |
| 35 | + return data; | |
| 36 | + } | |
| 37 | + | |
| 38 | + public void setData(GimiData data) { | |
| 39 | + this.data = data; | |
| 40 | + } | |
| 41 | + | |
| 42 | + @Override | |
| 43 | + public String toString() { | |
| 44 | + return "GimiMessage{" + | |
| 45 | + "code=" + code + | |
| 46 | + ", message='" + message + '\'' + | |
| 47 | + ", data=" + (data == null ? "data is null" : data.toString()) + | |
| 48 | + '}'; | |
| 49 | + } | |
| 50 | +} | |
| 51 | + | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import com.google.gson.annotations.Expose; | |
| 4 | + | |
| 5 | +/** | |
| 6 | + * Created by pc on 2015/1/6. | |
| 7 | + * 系统所发的信息,用以展示给用户 | |
| 8 | + */ | |
| 9 | +public class GimiSysData { | |
| 10 | +// "data":[ | |
| 11 | +// | |
| 12 | +// { | |
| 13 | +// "Messages":{ | |
| 14 | +// "msg_content":"asdfagsdfgasdf", | |
| 15 | +// "msg_type":"0", | |
| 16 | +// "addtime":"1420532750" | |
| 17 | +// } | |
| 18 | +// } | |
| 19 | +// | |
| 20 | +// ], | |
| 21 | + @Expose | |
| 22 | + Message Messages; | |
| 23 | + | |
| 24 | + public Message getMessages() { | |
| 25 | + return Messages; | |
| 26 | + } | |
| 27 | + | |
| 28 | + public void setMessages(Message messages) { | |
| 29 | + Messages = messages; | |
| 30 | + } | |
| 31 | + | |
| 32 | + @Override | |
| 33 | + public String toString() { | |
| 34 | + return "GimiSysData{" + | |
| 35 | + "Messages=" + Messages.toString() + | |
| 36 | + '}'; | |
| 37 | + } | |
| 38 | + | |
| 39 | + public class Message { | |
| 40 | + @Expose | |
| 41 | + private String msg_content; | |
| 42 | + @Expose | |
| 43 | + private String msg_type; | |
| 44 | + @Expose | |
| 45 | + private String addtime; | |
| 46 | + | |
| 47 | + | |
| 48 | + public String getMsg_content() { | |
| 49 | + return msg_content; | |
| 50 | + } | |
| 51 | + | |
| 52 | + public String getMsg_type() { | |
| 53 | + return msg_type; | |
| 54 | + } | |
| 55 | + | |
| 56 | + public String getAddtime() { | |
| 57 | + return addtime; | |
| 58 | + } | |
| 59 | + | |
| 60 | + @Override | |
| 61 | + public String toString() { | |
| 62 | + return "Message{" + | |
| 63 | + "addtime='" + addtime + '\'' + | |
| 64 | + ", msg_type='" + msg_type + '\'' + | |
| 65 | + ", msg_content='" + msg_content + '\'' + | |
| 66 | + '}'; | |
| 67 | + } | |
| 68 | + } | |
| 69 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import com.google.gson.annotations.Expose; | |
| 4 | + | |
| 5 | +/** | |
| 6 | + * Created by pc on 2015/1/6 | |
| 7 | + */ | |
| 8 | +public class GimiSysMsg { | |
| 9 | +// "data": [ | |
| 10 | +// { | |
| 11 | +// "Messages": { | |
| 12 | +// "msg_content": "asdfagsdfgasdf", | |
| 13 | +// "msg_type": "0", | |
| 14 | +// "addtime": "1420532750" | |
| 15 | +// } | |
| 16 | +// } | |
| 17 | +// ], | |
| 18 | +// "code": 200, | |
| 19 | +// "message": "ok" | |
| 20 | + | |
| 21 | + @Expose | |
| 22 | + String message; | |
| 23 | + @Expose | |
| 24 | + int code; | |
| 25 | + @Expose | |
| 26 | + GimiSysData[] data; | |
| 27 | + | |
| 28 | + public String getMessage() { | |
| 29 | + return message; | |
| 30 | + } | |
| 31 | + | |
| 32 | + public void setMessage(String message) { | |
| 33 | + this.message = message; | |
| 34 | + } | |
| 35 | + | |
| 36 | + public int getCode() { | |
| 37 | + return code; | |
| 38 | + } | |
| 39 | + | |
| 40 | + public void setCode(int code) { | |
| 41 | + this.code = code; | |
| 42 | + } | |
| 43 | + | |
| 44 | + public GimiSysData[] getData() { | |
| 45 | + return data; | |
| 46 | + } | |
| 47 | + | |
| 48 | + public void setData(GimiSysData[] data) { | |
| 49 | + this.data = data; | |
| 50 | + } | |
| 51 | + | |
| 52 | + @Override | |
| 53 | + public String toString() { | |
| 54 | + return "GimiSysMsg{" + | |
| 55 | + "message='" + message + '\'' + | |
| 56 | + ", code=" + code + | |
| 57 | + ", data=" + (data != null ? data.toString() : "data is null") + | |
| 58 | + '}'; | |
| 59 | + } | |
| 60 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import android.text.TextUtils; | |
| 4 | +import com.xgimi.gimicinema.activity.CinemaConfig; | |
| 5 | + | |
| 6 | +import java.io.Serializable; | |
| 7 | +import java.text.DateFormat; | |
| 8 | +import java.text.SimpleDateFormat; | |
| 9 | +import java.util.Calendar; | |
| 10 | + | |
| 11 | +/** | |
| 12 | + * Created by 李攀 on 2015/4/29 | |
| 13 | + */ | |
| 14 | +public class LocalMovieMessage implements Serializable { | |
| 15 | + private int id; | |
| 16 | + private String movieName; | |
| 17 | + private String posterPath; | |
| 18 | + private String playPath; | |
| 19 | + private String namePinyin; | |
| 20 | + private String md5; | |
| 21 | + private String type; | |
| 22 | + private String doubanId; | |
| 23 | + private String classDescribe; | |
| 24 | + private String movieLength; | |
| 25 | + private double doubanRating; | |
| 26 | + private String lastPlayTime; | |
| 27 | + private String screenTime; | |
| 28 | + private int count; | |
| 29 | + private String dlTime; | |
| 30 | + | |
| 31 | + public int getId() { | |
| 32 | + return id; | |
| 33 | + } | |
| 34 | + | |
| 35 | + public void setId(int id) { | |
| 36 | + this.id = id; | |
| 37 | + } | |
| 38 | + | |
| 39 | + public String getMovieName() { | |
| 40 | + return movieName; | |
| 41 | + } | |
| 42 | + | |
| 43 | + public void setMovieName(String movieName) { | |
| 44 | + this.movieName = movieName; | |
| 45 | + } | |
| 46 | + | |
| 47 | + public String getPosterPath() { | |
| 48 | + if (TextUtils.isEmpty(posterPath) || posterPath.startsWith("/mnt/samba/")|| posterPath.startsWith("/Uploads/pic/") | |
| 49 | + || posterPath.startsWith("/mnt/usb/")) { | |
| 50 | + return posterPath; | |
| 51 | + } | |
| 52 | + return CinemaConfig.BASIC_ROOT + posterPath; | |
| 53 | + } | |
| 54 | + | |
| 55 | + public void setPosterPath(String posterPath) { | |
| 56 | + if (TextUtils.isEmpty(posterPath)) { | |
| 57 | + this.posterPath = null; | |
| 58 | + } else { | |
| 59 | + this.posterPath = posterPath.replace(CinemaConfig.BASIC_ROOT, ""); | |
| 60 | + } | |
| 61 | + } | |
| 62 | + | |
| 63 | + public String getPlayPath() { | |
| 64 | + if (TextUtils.isEmpty(playPath) || playPath.startsWith("/mnt/samba/")|| playPath.startsWith("/mnt/usb/")) { | |
| 65 | + return playPath; | |
| 66 | + } | |
| 67 | + return CinemaConfig.BASIC_ROOT + playPath; | |
| 68 | + } | |
| 69 | + | |
| 70 | + public void setPlayPath(String playPath) { | |
| 71 | + if (TextUtils.isEmpty(playPath)) { | |
| 72 | + this.playPath = null; | |
| 73 | + } else { | |
| 74 | + this.playPath = playPath.replace(CinemaConfig.BASIC_ROOT, ""); | |
| 75 | + } | |
| 76 | + } | |
| 77 | + | |
| 78 | + public String getNamePinyin() { | |
| 79 | + return namePinyin; | |
| 80 | + } | |
| 81 | + | |
| 82 | + public void setNamePinyin(String namePinyin) { | |
| 83 | + this.namePinyin = namePinyin; | |
| 84 | + } | |
| 85 | + | |
| 86 | + public String getMd5() { | |
| 87 | + return md5; | |
| 88 | + } | |
| 89 | + | |
| 90 | + public void setMd5(String md5) { | |
| 91 | + this.md5 = md5; | |
| 92 | + } | |
| 93 | + | |
| 94 | + public String getType() { | |
| 95 | + return type; | |
| 96 | + } | |
| 97 | + | |
| 98 | + public void setType(String type) { | |
| 99 | + this.type = type; | |
| 100 | + } | |
| 101 | + | |
| 102 | + public String getDoubanId() { | |
| 103 | + return doubanId; | |
| 104 | + } | |
| 105 | + | |
| 106 | + public void setDoubanId(String doubanId) { | |
| 107 | + this.doubanId = doubanId; | |
| 108 | + } | |
| 109 | + | |
| 110 | + public String getClassDescribe() { | |
| 111 | + return classDescribe; | |
| 112 | + } | |
| 113 | + | |
| 114 | + public void setClassDescribe(String classDescribe) { | |
| 115 | + this.classDescribe = classDescribe; | |
| 116 | + } | |
| 117 | + | |
| 118 | + public String getMovieLength() { | |
| 119 | + return movieLength; | |
| 120 | + } | |
| 121 | + | |
| 122 | + public void setMovieLength(String movieLength) { | |
| 123 | + this.movieLength = movieLength; | |
| 124 | + } | |
| 125 | + | |
| 126 | + public double getDoubanRating() { | |
| 127 | + return doubanRating; | |
| 128 | + } | |
| 129 | + | |
| 130 | + public void setDoubanRating(double doubanRating) { | |
| 131 | + this.doubanRating = doubanRating; | |
| 132 | + } | |
| 133 | + | |
| 134 | + public String getLastPlayTime() { | |
| 135 | + return lastPlayTime; | |
| 136 | + } | |
| 137 | + | |
| 138 | + public void setLastPlayTime(long lastPlayTime1) { | |
| 139 | + DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm"); | |
| 140 | + Calendar calendar = Calendar.getInstance(); | |
| 141 | + calendar.setTimeInMillis(lastPlayTime1); | |
| 142 | + String format = formatter.format(calendar.getTime()); | |
| 143 | + this.lastPlayTime = format; | |
| 144 | + } | |
| 145 | + | |
| 146 | + public void setLastPlayTime(String lastPlayTime) { | |
| 147 | + this.lastPlayTime = lastPlayTime; | |
| 148 | + } | |
| 149 | + | |
| 150 | + public String getScreenTime() { | |
| 151 | + return screenTime; | |
| 152 | + } | |
| 153 | + | |
| 154 | + public void setScreenTime(String screenTime) { | |
| 155 | + this.screenTime = screenTime; | |
| 156 | + } | |
| 157 | + | |
| 158 | + | |
| 159 | + public int getCount() { | |
| 160 | + return count; | |
| 161 | + } | |
| 162 | + | |
| 163 | + public void setCount(int count) { | |
| 164 | + this.count = count; | |
| 165 | + } | |
| 166 | + | |
| 167 | + public String getDlTime() { | |
| 168 | + return dlTime; | |
| 169 | + } | |
| 170 | + | |
| 171 | + public void setDlTime(String dlTime) { | |
| 172 | + this.dlTime = dlTime; | |
| 173 | + } | |
| 174 | + | |
| 175 | + @Override | |
| 176 | + public String toString() { | |
| 177 | + return "LocalMovieMessage{" + | |
| 178 | + "id=" + id + | |
| 179 | + ", movieName='" + movieName + '\'' + | |
| 180 | + ", posterPath='" + posterPath + '\'' + | |
| 181 | + ", playPath='" + playPath + '\'' + | |
| 182 | + ", namePinyin='" + namePinyin + '\'' + | |
| 183 | + ", md5='" + md5 + '\'' + | |
| 184 | + ", type='" + type + '\'' + | |
| 185 | + ", doubanId='" + doubanId + '\'' + | |
| 186 | + ", classDescribe='" + classDescribe + '\'' + | |
| 187 | + ", movieLength='" + movieLength + '\'' + | |
| 188 | + ", doubanRating='" + doubanRating + '\'' + | |
| 189 | + ", lastPlayTime=" + lastPlayTime + | |
| 190 | + ", screenTime=" + screenTime + | |
| 191 | + '}'; | |
| 192 | + } | |
| 193 | +} | ... | ... |
| 1 | +/* | |
| 2 | + * Copyright (c) 2016. wugian | |
| 3 | + * Licensed under the Apache License, Version 2.0 (the "License"); | |
| 4 | + * you may not use this file except in compliance with the License. | |
| 5 | + * You may obtain a copy of the License at | |
| 6 | + * | |
| 7 | + * http://www.apache.org/licenses/LICENSE-2.0 | |
| 8 | + * | |
| 9 | + * Unless required by applicable law or agreed to in writing, software | |
| 10 | + * distributed under the License is distributed on an "AS IS" BASIS, | |
| 11 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 12 | + * See the License for the specific language governing permissions and | |
| 13 | + * limitations under the License. | |
| 14 | + * | |
| 15 | + */ | |
| 16 | + | |
| 17 | +package com.gimi.common.cinema.model; | |
| 18 | + | |
| 19 | +import com.google.gson.annotations.Expose; | |
| 20 | + | |
| 21 | +/** | |
| 22 | + * Created by pc on 2015/1/6. | |
| 23 | + * 系统所发的信息,用以展示给用户 | |
| 24 | + */ | |
| 25 | +public class MessageData { | |
| 26 | +// "data":[ | |
| 27 | +// | |
| 28 | +// { | |
| 29 | +// "Messages":{ | |
| 30 | +// "msg_content":"asdfagsdfgasdf", | |
| 31 | +// "msg_type":"0", | |
| 32 | +// "addtime":"1420532750" | |
| 33 | +// } | |
| 34 | +// } | |
| 35 | +// | |
| 36 | +// ], | |
| 37 | + @Expose | |
| 38 | + Message Messages; | |
| 39 | + | |
| 40 | + public Message getMessages() { | |
| 41 | + return Messages; | |
| 42 | + } | |
| 43 | + | |
| 44 | + public void setMessages(Message messages) { | |
| 45 | + Messages = messages; | |
| 46 | + } | |
| 47 | + | |
| 48 | + @Override | |
| 49 | + public String toString() { | |
| 50 | + return "MessageData{" + | |
| 51 | + "Messages=" + Messages.toString() + | |
| 52 | + '}'; | |
| 53 | + } | |
| 54 | + | |
| 55 | + public class Message { | |
| 56 | + @Expose | |
| 57 | + private String msg_content; | |
| 58 | + @Expose | |
| 59 | + private String msg_type; | |
| 60 | + @Expose | |
| 61 | + private String addtime; | |
| 62 | + | |
| 63 | + | |
| 64 | + public String getMsg_content() { | |
| 65 | + return msg_content; | |
| 66 | + } | |
| 67 | + | |
| 68 | + public String getMsg_type() { | |
| 69 | + return msg_type; | |
| 70 | + } | |
| 71 | + | |
| 72 | + public String getAddtime() { | |
| 73 | + return addtime; | |
| 74 | + } | |
| 75 | + | |
| 76 | + @Override | |
| 77 | + public String toString() { | |
| 78 | + return "Message{" + | |
| 79 | + "addtime='" + addtime + '\'' + | |
| 80 | + ", msg_type='" + msg_type + '\'' + | |
| 81 | + ", msg_content='" + msg_content + '\'' + | |
| 82 | + '}'; | |
| 83 | + } | |
| 84 | + } | |
| 85 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +public class MessageEvent { | |
| 4 | + private int eventId; | |
| 5 | + private String message; | |
| 6 | + | |
| 7 | + public int getEventId() { | |
| 8 | + return eventId; | |
| 9 | + } | |
| 10 | + | |
| 11 | + public void setEventId(int eventId) { | |
| 12 | + this.eventId = eventId; | |
| 13 | + } | |
| 14 | + | |
| 15 | + public String getMessage() { | |
| 16 | + return message; | |
| 17 | + } | |
| 18 | + | |
| 19 | + public void setMessage(String message) { | |
| 20 | + this.message = message; | |
| 21 | + } | |
| 22 | +} | |
| \ No newline at end of file | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by pc on 2014/12/24.演员,导演属性 | |
| 5 | + */ | |
| 6 | +public class MovieCast { | |
| 7 | + | |
| 8 | + | |
| 9 | + private MovieImages avatars; | |
| 10 | + private String alt; | |
| 11 | + private String id; | |
| 12 | + private String name; | |
| 13 | + | |
| 14 | + public MovieImages getAvatars() { | |
| 15 | + return avatars; | |
| 16 | + } | |
| 17 | + | |
| 18 | + public void setAvatars(MovieImages avatars) { | |
| 19 | + this.avatars = avatars; | |
| 20 | + } | |
| 21 | + | |
| 22 | + public String getAlt() { | |
| 23 | + return alt; | |
| 24 | + } | |
| 25 | + | |
| 26 | + public void setAlt(String alt) { | |
| 27 | + this.alt = alt; | |
| 28 | + } | |
| 29 | + | |
| 30 | + public String getId() { | |
| 31 | + return id; | |
| 32 | + } | |
| 33 | + | |
| 34 | + public void setId(String id) { | |
| 35 | + this.id = id; | |
| 36 | + } | |
| 37 | + | |
| 38 | + public String getName() { | |
| 39 | + return name; | |
| 40 | + } | |
| 41 | + | |
| 42 | + public void setName(String name) { | |
| 43 | + this.name = name; | |
| 44 | + } | |
| 45 | + | |
| 46 | + @Override | |
| 47 | + public String toString() { | |
| 48 | + return "MovieCast{" + | |
| 49 | + "avatars=" + avatars + | |
| 50 | + ", alt='" + alt + '\'' + | |
| 51 | + ", id='" + id + '\'' + | |
| 52 | + ", name='" + name + '\'' + | |
| 53 | + '}'; | |
| 54 | + } | |
| 55 | +} | |
| 56 | + | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by pc on 2014/12/24 | |
| 5 | + */ | |
| 6 | +public class MovieImages { | |
| 7 | + private String small; | |
| 8 | + private String large; | |
| 9 | + private String medium; | |
| 10 | + | |
| 11 | + public String getSmall() { | |
| 12 | + return small; | |
| 13 | + } | |
| 14 | + | |
| 15 | + public void setSmall(String small) { | |
| 16 | + this.small = small; | |
| 17 | + } | |
| 18 | + | |
| 19 | + public String getLarge() { | |
| 20 | + return large; | |
| 21 | + } | |
| 22 | + | |
| 23 | + public void setLarge(String large) { | |
| 24 | + this.large = large; | |
| 25 | + } | |
| 26 | + | |
| 27 | + public String getMedium() { | |
| 28 | + return medium; | |
| 29 | + } | |
| 30 | + | |
| 31 | + public void setMedium(String medium) { | |
| 32 | + this.medium = medium; | |
| 33 | + } | |
| 34 | + | |
| 35 | + @Override | |
| 36 | + public String toString() { | |
| 37 | + return "MovieImages{" + | |
| 38 | + "small='" + small + '\'' + | |
| 39 | + ", large='" + large + '\'' + | |
| 40 | + ", medium='" + medium + '\'' + | |
| 41 | + '}'; | |
| 42 | + } | |
| 43 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import com.google.gson.annotations.Expose; | |
| 4 | + | |
| 5 | +import java.util.Arrays; | |
| 6 | + | |
| 7 | +/** | |
| 8 | + * Created by pc on 2014/12/24. | |
| 9 | + */ | |
| 10 | +public class MovieMessage { | |
| 11 | + @Expose | |
| 12 | + private Rating rating; | |
| 13 | + @Expose | |
| 14 | + private int reviews_count; | |
| 15 | + @Expose | |
| 16 | + private int wish_count; | |
| 17 | + @Expose | |
| 18 | + private int collect_count; | |
| 19 | + @Expose | |
| 20 | + private String douban_site; | |
| 21 | + @Expose | |
| 22 | + private String year; | |
| 23 | + @Expose | |
| 24 | + private MovieImages images; | |
| 25 | + @Expose | |
| 26 | + private String alt; | |
| 27 | + @Expose | |
| 28 | + private String id; | |
| 29 | + @Expose | |
| 30 | + private String mobile_url; | |
| 31 | + @Expose | |
| 32 | + private String title; | |
| 33 | + @Expose | |
| 34 | + private String do_count;// not confirm type | |
| 35 | + @Expose | |
| 36 | + private String seasons_count;// not confirm type | |
| 37 | + @Expose | |
| 38 | + private String schedule_url;// not confirm type | |
| 39 | + @Expose | |
| 40 | + private String episodes_count;// not confirm type | |
| 41 | + @Expose | |
| 42 | + private String[] genres;//分类,关键词 | |
| 43 | + @Expose | |
| 44 | + private String[] countries; | |
| 45 | + @Expose | |
| 46 | + private MovieCast[] casts;//演员列表 | |
| 47 | + @Expose | |
| 48 | + private String current_season;// | |
| 49 | + @Expose | |
| 50 | + private String original_title;//原名 | |
| 51 | + @Expose | |
| 52 | + private String summary;//电影简介:互相猜忌,却无意间发现了彼此间的联系。但是,大家怀疑的嫌疑人却纷纷死去,谜团笼罩在旅馆狭小的空间里,这样的凶杀案件却有着人们猜不到的真相……©豆瓣", | |
| 53 | + @Expose | |
| 54 | + private String subtype;// 电影 音乐 图书 (英文)…… | |
| 55 | + @Expose | |
| 56 | + private MovieCast[] directors; | |
| 57 | + @Expose | |
| 58 | + private int comments_count; | |
| 59 | + @Expose | |
| 60 | + private int ratings_count; | |
| 61 | + @Expose | |
| 62 | + private String []aka;//应该是别名 | |
| 63 | + | |
| 64 | + public Rating getRating() { | |
| 65 | + return rating; | |
| 66 | + } | |
| 67 | + | |
| 68 | + public void setRating(Rating rating) { | |
| 69 | + this.rating = rating; | |
| 70 | + } | |
| 71 | + | |
| 72 | + public int getReviews_count() { | |
| 73 | + return reviews_count; | |
| 74 | + } | |
| 75 | + | |
| 76 | + public void setReviews_count(int reviews_count) { | |
| 77 | + this.reviews_count = reviews_count; | |
| 78 | + } | |
| 79 | + | |
| 80 | + public int getWish_count() { | |
| 81 | + return wish_count; | |
| 82 | + } | |
| 83 | + | |
| 84 | + public void setWish_count(int wish_count) { | |
| 85 | + this.wish_count = wish_count; | |
| 86 | + } | |
| 87 | + | |
| 88 | + public int getCollect_count() { | |
| 89 | + return collect_count; | |
| 90 | + } | |
| 91 | + | |
| 92 | + public void setCollect_count(int collect_count) { | |
| 93 | + this.collect_count = collect_count; | |
| 94 | + } | |
| 95 | + | |
| 96 | + public String getDouban_site() { | |
| 97 | + return douban_site; | |
| 98 | + } | |
| 99 | + | |
| 100 | + public void setDouban_site(String douban_site) { | |
| 101 | + this.douban_site = douban_site; | |
| 102 | + } | |
| 103 | + | |
| 104 | + public String getYear() { | |
| 105 | + return year; | |
| 106 | + } | |
| 107 | + | |
| 108 | + public void setYear(String year) { | |
| 109 | + this.year = year; | |
| 110 | + } | |
| 111 | + | |
| 112 | + public MovieImages getImages() { | |
| 113 | + return images; | |
| 114 | + } | |
| 115 | + | |
| 116 | + public void setImages(MovieImages images) { | |
| 117 | + this.images = images; | |
| 118 | + } | |
| 119 | + | |
| 120 | + public String getAlt() { | |
| 121 | + return alt; | |
| 122 | + } | |
| 123 | + | |
| 124 | + public void setAlt(String alt) { | |
| 125 | + this.alt = alt; | |
| 126 | + } | |
| 127 | + | |
| 128 | + public String getId() { | |
| 129 | + return id; | |
| 130 | + } | |
| 131 | + | |
| 132 | + public void setId(String id) { | |
| 133 | + this.id = id; | |
| 134 | + } | |
| 135 | + | |
| 136 | + public String getMobile_url() { | |
| 137 | + return mobile_url; | |
| 138 | + } | |
| 139 | + | |
| 140 | + public void setMobile_url(String mobile_url) { | |
| 141 | + this.mobile_url = mobile_url; | |
| 142 | + } | |
| 143 | + | |
| 144 | + public String getTitle() { | |
| 145 | + return title; | |
| 146 | + } | |
| 147 | + | |
| 148 | + public void setTitle(String title) { | |
| 149 | + this.title = title; | |
| 150 | + } | |
| 151 | + | |
| 152 | + public String getDo_count() { | |
| 153 | + return do_count; | |
| 154 | + } | |
| 155 | + | |
| 156 | + public void setDo_count(String do_count) { | |
| 157 | + this.do_count = do_count; | |
| 158 | + } | |
| 159 | + | |
| 160 | + public String getSeasons_count() { | |
| 161 | + return seasons_count; | |
| 162 | + } | |
| 163 | + | |
| 164 | + public void setSeasons_count(String seasons_count) { | |
| 165 | + this.seasons_count = seasons_count; | |
| 166 | + } | |
| 167 | + | |
| 168 | + public String getSchedule_url() { | |
| 169 | + return schedule_url; | |
| 170 | + } | |
| 171 | + | |
| 172 | + public void setSchedule_url(String schedule_url) { | |
| 173 | + this.schedule_url = schedule_url; | |
| 174 | + } | |
| 175 | + | |
| 176 | + public String getEpisodes_count() { | |
| 177 | + return episodes_count; | |
| 178 | + } | |
| 179 | + | |
| 180 | + public void setEpisodes_count(String episodes_count) { | |
| 181 | + this.episodes_count = episodes_count; | |
| 182 | + } | |
| 183 | + | |
| 184 | + public String[] getGenres() { | |
| 185 | + return genres; | |
| 186 | + } | |
| 187 | + | |
| 188 | + public void setGenres(String[] genres) { | |
| 189 | + this.genres = genres; | |
| 190 | + } | |
| 191 | + | |
| 192 | + public String[] getCountries() { | |
| 193 | + return countries; | |
| 194 | + } | |
| 195 | + | |
| 196 | + public void setCountries(String[] countries) { | |
| 197 | + this.countries = countries; | |
| 198 | + } | |
| 199 | + | |
| 200 | + public MovieCast[] getCasts() { | |
| 201 | + return casts; | |
| 202 | + } | |
| 203 | + | |
| 204 | + public void setCasts(MovieCast[] casts) { | |
| 205 | + this.casts = casts; | |
| 206 | + } | |
| 207 | + | |
| 208 | + public String getCurrent_season() { | |
| 209 | + return current_season; | |
| 210 | + } | |
| 211 | + | |
| 212 | + public void setCurrent_season(String current_season) { | |
| 213 | + this.current_season = current_season; | |
| 214 | + } | |
| 215 | + | |
| 216 | + public String getOriginal_title() { | |
| 217 | + return original_title; | |
| 218 | + } | |
| 219 | + | |
| 220 | + public void setOriginal_title(String original_title) { | |
| 221 | + this.original_title = original_title; | |
| 222 | + } | |
| 223 | + | |
| 224 | + public String getSummary() { | |
| 225 | + return summary; | |
| 226 | + } | |
| 227 | + | |
| 228 | + public void setSummary(String summary) { | |
| 229 | + this.summary = summary; | |
| 230 | + } | |
| 231 | + | |
| 232 | + public String getSubtype() { | |
| 233 | + return subtype; | |
| 234 | + } | |
| 235 | + | |
| 236 | + public void setSubtype(String subtype) { | |
| 237 | + this.subtype = subtype; | |
| 238 | + } | |
| 239 | + | |
| 240 | + public MovieCast[] getDirectors() { | |
| 241 | + return directors; | |
| 242 | + } | |
| 243 | + | |
| 244 | + public void setDirectors(MovieCast[] directors) { | |
| 245 | + this.directors = directors; | |
| 246 | + } | |
| 247 | + | |
| 248 | + public int getComments_count() { | |
| 249 | + return comments_count; | |
| 250 | + } | |
| 251 | + | |
| 252 | + public void setComments_count(int comments_count) { | |
| 253 | + this.comments_count = comments_count; | |
| 254 | + } | |
| 255 | + | |
| 256 | + public int getRatings_count() { | |
| 257 | + return ratings_count; | |
| 258 | + } | |
| 259 | + | |
| 260 | + public void setRatings_count(int ratings_count) { | |
| 261 | + this.ratings_count = ratings_count; | |
| 262 | + } | |
| 263 | + | |
| 264 | + public String[] getAka() { | |
| 265 | + return aka; | |
| 266 | + } | |
| 267 | + | |
| 268 | + public void setAka(String[] aka) { | |
| 269 | + this.aka = aka; | |
| 270 | + } | |
| 271 | + | |
| 272 | + @Override | |
| 273 | + public String toString() { | |
| 274 | + return "MM{" + | |
| 275 | + "rating=" + rating + | |
| 276 | + ", reviews_count=" + reviews_count + | |
| 277 | + ", wish_count=" + wish_count + | |
| 278 | + ", collect_count=" + collect_count + | |
| 279 | + ", douban_site='" + douban_site + '\'' + | |
| 280 | + ", year='" + year + '\'' + | |
| 281 | + ", images=" + images + | |
| 282 | + ", alt='" + alt + '\'' + | |
| 283 | + ", id='" + id + '\'' + | |
| 284 | + ", mobile_url='" + mobile_url + '\'' + | |
| 285 | + ", title='" + title + '\'' + | |
| 286 | + ", do_count='" + do_count + '\'' + | |
| 287 | + ", seasons_count='" + seasons_count + '\'' + | |
| 288 | + ", schedule_url='" + schedule_url + '\'' + | |
| 289 | + ", episodes_count='" + episodes_count + '\'' + | |
| 290 | + ", genres=" + Arrays.toString(genres) + | |
| 291 | + ", countries=" + Arrays.toString(countries) + | |
| 292 | + ", casts=" + Arrays.toString(casts) + | |
| 293 | + ", current_season='" + current_season + '\'' + | |
| 294 | + ", original_title='" + original_title + '\'' + | |
| 295 | + ", summary='" + summary + '\'' + | |
| 296 | + ", subtype='" + subtype + '\'' + | |
| 297 | + ", directors=" + Arrays.toString(directors) + | |
| 298 | + ", comments_count=" + comments_count + | |
| 299 | + ", ratings_count=" + ratings_count + | |
| 300 | + ", aka=" + Arrays.toString(aka) + | |
| 301 | + '}'; | |
| 302 | + } | |
| 303 | +} | ... | ... |
| 1 | +/* | |
| 2 | + * Copyright 2016 wugian | |
| 3 | + * | |
| 4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | |
| 5 | + * you may not use this file except in compliance with the License. | |
| 6 | + * You may obtain a copy of the License at | |
| 7 | + * | |
| 8 | + * http://www.apache.org/licenses/LICENSE-2.0 | |
| 9 | + * | |
| 10 | + * Unless required by applicable law or agreed to in writing, software | |
| 11 | + * distributed under the License is distributed on an "AS IS" BASIS, | |
| 12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 13 | + * See the License for the specific language governing permissions and | |
| 14 | + * limitations under the License. | |
| 15 | + */ | |
| 16 | + | |
| 17 | +package com.gimi.common.cinema.model; | |
| 18 | + | |
| 19 | +import java.util.List; | |
| 20 | + | |
| 21 | +public class PlayStatus { | |
| 22 | + | |
| 23 | + public PlayStatus(){} | |
| 24 | + public int state; | |
| 25 | + public long currentPosition; | |
| 26 | + public long movieLength; | |
| 27 | + public String path; | |
| 28 | + public List<String> movieUrls; | |
| 29 | + | |
| 30 | + public int getState() { | |
| 31 | + return state; | |
| 32 | + } | |
| 33 | + | |
| 34 | + public void setState(int state) { | |
| 35 | + this.state = state; | |
| 36 | + } | |
| 37 | + | |
| 38 | + public long getCurrentPosition() { | |
| 39 | + return currentPosition; | |
| 40 | + } | |
| 41 | + | |
| 42 | + public void setCurrentPosition(long currentPosition) { | |
| 43 | + this.currentPosition = currentPosition; | |
| 44 | + } | |
| 45 | + | |
| 46 | + public long getMovieLength() { | |
| 47 | + return movieLength; | |
| 48 | + } | |
| 49 | + | |
| 50 | + public void setMovieLength(long movieLength) { | |
| 51 | + this.movieLength = movieLength; | |
| 52 | + } | |
| 53 | + | |
| 54 | + public String getPath() { | |
| 55 | + return path; | |
| 56 | + } | |
| 57 | + | |
| 58 | + public void setPath(String path) { | |
| 59 | + this.path = path; | |
| 60 | + } | |
| 61 | + | |
| 62 | + public List<String> getMovieUrls() { | |
| 63 | + return movieUrls; | |
| 64 | + } | |
| 65 | + | |
| 66 | + public void setMovieUrls(List<String> movieUrls) { | |
| 67 | + this.movieUrls = movieUrls; | |
| 68 | + } | |
| 69 | + | |
| 70 | + @Override | |
| 71 | + public String toString() { | |
| 72 | + return "PlayStatus{" + | |
| 73 | + "state=" + state + | |
| 74 | + ", currentPosition=" + currentPosition + | |
| 75 | + ", movieLength=" + movieLength + | |
| 76 | + ", path='" + path + '\'' + | |
| 77 | + ", movieUrls=" + movieUrls + | |
| 78 | + '}'; | |
| 79 | + } | |
| 80 | + } | ... | ... |
| 1 | +/* | |
| 2 | + * Copyright 2016 wugian | |
| 3 | + * | |
| 4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | |
| 5 | + * you may not use this file except in compliance with the License. | |
| 6 | + * You may obtain a copy of the License at | |
| 7 | + * | |
| 8 | + * http://www.apache.org/licenses/LICENSE-2.0 | |
| 9 | + * | |
| 10 | + * Unless required by applicable law or agreed to in writing, software | |
| 11 | + * distributed under the License is distributed on an "AS IS" BASIS, | |
| 12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 13 | + * See the License for the specific language governing permissions and | |
| 14 | + * limitations under the License. | |
| 15 | + */ | |
| 16 | + | |
| 17 | +package com.gimi.common.cinema.model; | |
| 18 | + | |
| 19 | +/** | |
| 20 | + * Created by wugian on 2016/12/28 | |
| 21 | + */ | |
| 22 | + | |
| 23 | +public class PlayStatusMessage { | |
| 24 | + public int action; | |
| 25 | + public PlayStatus status; | |
| 26 | + | |
| 27 | + public int getAction() { | |
| 28 | + return action; | |
| 29 | + } | |
| 30 | + | |
| 31 | + public void setAction(int action) { | |
| 32 | + this.action = action; | |
| 33 | + } | |
| 34 | + | |
| 35 | + public PlayStatus getStatus() { | |
| 36 | + return status; | |
| 37 | + } | |
| 38 | + | |
| 39 | + public void setStatus(PlayStatus status) { | |
| 40 | + this.status = status; | |
| 41 | + } | |
| 42 | + | |
| 43 | + @Override | |
| 44 | + public String toString() { | |
| 45 | + return "PlayStatusMessage{" + | |
| 46 | + "action=" + action + | |
| 47 | + ", status=" + status + | |
| 48 | + '}'; | |
| 49 | + } | |
| 50 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by wugian on 2016/8/4 | |
| 5 | + */ | |
| 6 | +public class PosterMessage { | |
| 7 | + | |
| 8 | + /** | |
| 9 | + * code : 0 | |
| 10 | + * msg : 成功 | |
| 11 | + * data : {"versionId":"b52b6c33","posterUrl":"http://qnbar-test.oss-cn-hangzhou.aliyuncs.com/fbms/upload/img/57a2f46039dd1.jpg"} | |
| 12 | + */ | |
| 13 | + | |
| 14 | + private int code; | |
| 15 | + private String msg; | |
| 16 | + /** | |
| 17 | + * versionId : b52b6c33 | |
| 18 | + * posterUrl : http://qnbar-test.oss-cn-hangzhou.aliyuncs.com/fbms/upload/img/57a2f46039dd1.jpg | |
| 19 | + */ | |
| 20 | + | |
| 21 | + private DataEntity data; | |
| 22 | + | |
| 23 | + public int getCode() { | |
| 24 | + return code; | |
| 25 | + } | |
| 26 | + | |
| 27 | + public void setCode(int code) { | |
| 28 | + this.code = code; | |
| 29 | + } | |
| 30 | + | |
| 31 | + public String getMsg() { | |
| 32 | + return msg; | |
| 33 | + } | |
| 34 | + | |
| 35 | + public void setMsg(String msg) { | |
| 36 | + this.msg = msg; | |
| 37 | + } | |
| 38 | + | |
| 39 | + public DataEntity getData() { | |
| 40 | + return data; | |
| 41 | + } | |
| 42 | + | |
| 43 | + public void setData(DataEntity data) { | |
| 44 | + this.data = data; | |
| 45 | + } | |
| 46 | + | |
| 47 | + public class DataEntity { | |
| 48 | + private String versionId; | |
| 49 | + private String posterUrl; | |
| 50 | + | |
| 51 | + public String getVersionId() { | |
| 52 | + return versionId; | |
| 53 | + } | |
| 54 | + | |
| 55 | + public void setVersionId(String versionId) { | |
| 56 | + this.versionId = versionId; | |
| 57 | + } | |
| 58 | + | |
| 59 | + public String getPosterUrl() { | |
| 60 | + return posterUrl; | |
| 61 | + } | |
| 62 | + | |
| 63 | + public void setPosterUrl(String posterUrl) { | |
| 64 | + this.posterUrl = posterUrl; | |
| 65 | + } | |
| 66 | + } | |
| 67 | +} | ... | ... |
| 1 | +/* | |
| 2 | + * Copyright (c) 2016. wugian | |
| 3 | + * Licensed under the Apache License, Version 2.0 (the "License"); | |
| 4 | + * you may not use this file except in compliance with the License. | |
| 5 | + * You may obtain a copy of the License at | |
| 6 | + * | |
| 7 | + * http://www.apache.org/licenses/LICENSE-2.0 | |
| 8 | + * | |
| 9 | + * Unless required by applicable law or agreed to in writing, software | |
| 10 | + * distributed under the License is distributed on an "AS IS" BASIS, | |
| 11 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 12 | + * See the License for the specific language governing permissions and | |
| 13 | + * limitations under the License. | |
| 14 | + * | |
| 15 | + */ | |
| 16 | + | |
| 17 | +package com.gimi.common.cinema.model; | |
| 18 | + | |
| 19 | + | |
| 20 | +/** | |
| 21 | + * Created by wugian on 2016/11/15 | |
| 22 | + */ | |
| 23 | +public class QnResult<ObjectType> { | |
| 24 | + private int code; | |
| 25 | + private String message; | |
| 26 | + private int error; | |
| 27 | + private ObjectType t;//t is List<MessageData> StatusData | |
| 28 | + | |
| 29 | + public int getCode() { | |
| 30 | + return code; | |
| 31 | + } | |
| 32 | + | |
| 33 | + public void setCode(int code) { | |
| 34 | + this.code = code; | |
| 35 | + } | |
| 36 | + | |
| 37 | + public String getMessage() { | |
| 38 | + return message; | |
| 39 | + } | |
| 40 | + | |
| 41 | + public void setMessage(String message) { | |
| 42 | + this.message = message; | |
| 43 | + } | |
| 44 | + | |
| 45 | + public int getError() { | |
| 46 | + return error; | |
| 47 | + } | |
| 48 | + | |
| 49 | + public void setError(int error) { | |
| 50 | + this.error = error; | |
| 51 | + } | |
| 52 | + | |
| 53 | + public ObjectType getT() { | |
| 54 | + return t; | |
| 55 | + } | |
| 56 | + | |
| 57 | + public void setT(ObjectType t) { | |
| 58 | + this.t = t; | |
| 59 | + } | |
| 60 | + | |
| 61 | + @Override | |
| 62 | + public String toString() { | |
| 63 | + return "QnResult{" + | |
| 64 | + "code=" + code + | |
| 65 | + ", message='" + message + '\'' + | |
| 66 | + ", error=" + error + | |
| 67 | + ", t=" + (t == null ? "type is null" : t.toString()) + | |
| 68 | + '}'; | |
| 69 | + } | |
| 70 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import java.util.List; | |
| 4 | + | |
| 5 | +/** | |
| 6 | + * Created by wugian on 2015/12/29 | |
| 7 | + */ | |
| 8 | +public class QueryBean { | |
| 9 | + | |
| 10 | + /** | |
| 11 | + * count : 3 | |
| 12 | + * start : 0 | |
| 13 | + * total : 2 | |
| 14 | + * subjects : [{"rating":{"max":10,"average":9.6,"stars":"50","min":0},"genres":["犯罪","剧情"],"collect_count":888203,"casts":[{"avatars":{"small":"https://img1.doubanio.com/img/celebrity/small/1679.jpg","large":"https://img1.doubanio.com/img/celebrity/large/1679.jpg","medium":"https://img1.doubanio.com/img/celebrity/medium/1679.jpg"},"alt":"http://movie.douban.com/celebrity/1054521/","id":"1054521","name":"蒂姆·罗宾斯"},{"avatars":{"small":"https://img1.doubanio.com/img/celebrity/small/34642.jpg","large":"https://img1.doubanio.com/img/celebrity/large/34642.jpg","medium":"https://img1.doubanio.com/img/celebrity/medium/34642.jpg"},"alt":"http://movie.douban.com/celebrity/1054534/","id":"1054534","name":"摩根·弗里曼"},{"avatars":{"small":"https://img1.doubanio.com/img/celebrity/small/5837.jpg","large":"https://img1.doubanio.com/img/celebrity/large/5837.jpg","medium":"https://img1.doubanio.com/img/celebrity/medium/5837.jpg"},"alt":"http://movie.douban.com/celebrity/1041179/","id":"1041179","name":"鲍勃·冈顿"}],"title":"肖申克的救赎","original_title":"The Shawshank Redemption","subtype":"movie","directors":[{"avatars":{"small":"https://img3.doubanio.com/img/celebrity/small/230.jpg","large":"https://img3.doubanio.com/img/celebrity/large/230.jpg","medium":"https://img3.doubanio.com/img/celebrity/medium/230.jpg"},"alt":"http://movie.douban.com/celebrity/1047973/","id":"1047973","name":"弗兰克·德拉邦特"}],"year":"1994","images":{"small":"https://img1.doubanio.com/view/movie_poster_cover/ipst/public/p480747492.jpg","large":"https://img1.doubanio.com/view/movie_poster_cover/lpst/public/p480747492.jpg","medium":"https://img1.doubanio.com/view/movie_poster_cover/spst/public/p480747492.jpg"},"alt":"http://movie.douban.com/subject/1292052/","id":"1292052"},{"rating":{"max":10,"average":0,"stars":"00","min":0},"genres":["科幻","短片"],"collect_count":15,"casts":[],"title":"搏击之王第五集","original_title":"Redemption","subtype":"movie","directors":[{"avatars":null,"alt":null,"id":null,"name":"Balthasar von Weymarn"}],"year":"1995","images":{"small":"https://img1.doubanio.com/spic/s6810648.jpg","large":"https://img1.doubanio.com/lpic/s6810648.jpg","medium":"https://img1.doubanio.com/mpic/s6810648.jpg"},"alt":"http://movie.douban.com/subject/1306171/","id":"1306171"}] | |
| 15 | + * title : 搜索 "肖申克的救赎" 的结果 | |
| 16 | + */ | |
| 17 | + | |
| 18 | + private int count; | |
| 19 | + private int start; | |
| 20 | + private int total; | |
| 21 | + private String title; | |
| 22 | + /** | |
| 23 | + * rating : {"max":10,"average":9.6,"stars":"50","min":0} | |
| 24 | + * genres : ["犯罪","剧情"] | |
| 25 | + * collect_count : 888203 | |
| 26 | + * casts : [{"avatars":{"small":"https://img1.doubanio.com/img/celebrity/small/1679.jpg","large":"https://img1.doubanio.com/img/celebrity/large/1679.jpg","medium":"https://img1.doubanio.com/img/celebrity/medium/1679.jpg"},"alt":"http://movie.douban.com/celebrity/1054521/","id":"1054521","name":"蒂姆·罗宾斯"},{"avatars":{"small":"https://img1.doubanio.com/img/celebrity/small/34642.jpg","large":"https://img1.doubanio.com/img/celebrity/large/34642.jpg","medium":"https://img1.doubanio.com/img/celebrity/medium/34642.jpg"},"alt":"http://movie.douban.com/celebrity/1054534/","id":"1054534","name":"摩根·弗里曼"},{"avatars":{"small":"https://img1.doubanio.com/img/celebrity/small/5837.jpg","large":"https://img1.doubanio.com/img/celebrity/large/5837.jpg","medium":"https://img1.doubanio.com/img/celebrity/medium/5837.jpg"},"alt":"http://movie.douban.com/celebrity/1041179/","id":"1041179","name":"鲍勃·冈顿"}] | |
| 27 | + * title : 肖申克的救赎 | |
| 28 | + * original_title : The Shawshank Redemption | |
| 29 | + * subtype : movie | |
| 30 | + * directors : [{"avatars":{"small":"https://img3.doubanio.com/img/celebrity/small/230.jpg","large":"https://img3.doubanio.com/img/celebrity/large/230.jpg","medium":"https://img3.doubanio.com/img/celebrity/medium/230.jpg"},"alt":"http://movie.douban.com/celebrity/1047973/","id":"1047973","name":"弗兰克·德拉邦特"}] | |
| 31 | + * year : 1994 | |
| 32 | + * images : {"small":"https://img1.doubanio.com/view/movie_poster_cover/ipst/public/p480747492.jpg","large":"https://img1.doubanio.com/view/movie_poster_cover/lpst/public/p480747492.jpg","medium":"https://img1.doubanio.com/view/movie_poster_cover/spst/public/p480747492.jpg"} | |
| 33 | + * alt : http://movie.douban.com/subject/1292052/ | |
| 34 | + * id : 1292052 | |
| 35 | + */ | |
| 36 | + | |
| 37 | + private List<SubjectsEntity> subjects; | |
| 38 | + | |
| 39 | + public void setCount(int count) { | |
| 40 | + this.count = count; | |
| 41 | + } | |
| 42 | + | |
| 43 | + public void setStart(int start) { | |
| 44 | + this.start = start; | |
| 45 | + } | |
| 46 | + | |
| 47 | + public void setTotal(int total) { | |
| 48 | + this.total = total; | |
| 49 | + } | |
| 50 | + | |
| 51 | + public void setTitle(String title) { | |
| 52 | + this.title = title; | |
| 53 | + } | |
| 54 | + | |
| 55 | + public void setSubjects(List<SubjectsEntity> subjects) { | |
| 56 | + this.subjects = subjects; | |
| 57 | + } | |
| 58 | + | |
| 59 | + public int getCount() { | |
| 60 | + return count; | |
| 61 | + } | |
| 62 | + | |
| 63 | + public int getStart() { | |
| 64 | + return start; | |
| 65 | + } | |
| 66 | + | |
| 67 | + public int getTotal() { | |
| 68 | + return total; | |
| 69 | + } | |
| 70 | + | |
| 71 | + public String getTitle() { | |
| 72 | + return title; | |
| 73 | + } | |
| 74 | + | |
| 75 | + public List<SubjectsEntity> getSubjects() { | |
| 76 | + return subjects; | |
| 77 | + } | |
| 78 | + | |
| 79 | + public static class SubjectsEntity { | |
| 80 | + /** | |
| 81 | + * max : 10 | |
| 82 | + * average : 9.6 | |
| 83 | + * stars : 50 | |
| 84 | + * min : 0 | |
| 85 | + */ | |
| 86 | + | |
| 87 | + private RatingEntity rating; | |
| 88 | + private int collect_count; | |
| 89 | + private String title; | |
| 90 | + private String original_title; | |
| 91 | + private String subtype; | |
| 92 | + private String year; | |
| 93 | + /** | |
| 94 | + * small : https://img1.doubanio.com/view/movie_poster_cover/ipst/public/p480747492.jpg | |
| 95 | + * large : https://img1.doubanio.com/view/movie_poster_cover/lpst/public/p480747492.jpg | |
| 96 | + * medium : https://img1.doubanio.com/view/movie_poster_cover/spst/public/p480747492.jpg | |
| 97 | + */ | |
| 98 | + | |
| 99 | + private ImagesEntity images; | |
| 100 | + private String alt; | |
| 101 | + private String id; | |
| 102 | + private List<String> genres; | |
| 103 | + /** | |
| 104 | + * avatars : {"small":"https://img1.doubanio.com/img/celebrity/small/1679.jpg","large":"https://img1.doubanio.com/img/celebrity/large/1679.jpg","medium":"https://img1.doubanio.com/img/celebrity/medium/1679.jpg"} | |
| 105 | + * alt : http://movie.douban.com/celebrity/1054521/ | |
| 106 | + * id : 1054521 | |
| 107 | + * name : 蒂姆·罗宾斯 | |
| 108 | + */ | |
| 109 | + | |
| 110 | + private List<CastsEntity> casts; | |
| 111 | + /** | |
| 112 | + * avatars : {"small":"https://img3.doubanio.com/img/celebrity/small/230.jpg","large":"https://img3.doubanio.com/img/celebrity/large/230.jpg","medium":"https://img3.doubanio.com/img/celebrity/medium/230.jpg"} | |
| 113 | + * alt : http://movie.douban.com/celebrity/1047973/ | |
| 114 | + * id : 1047973 | |
| 115 | + * name : 弗兰克·德拉邦特 | |
| 116 | + */ | |
| 117 | + | |
| 118 | + private List<DirectorsEntity> directors; | |
| 119 | + | |
| 120 | + public void setRating(RatingEntity rating) { | |
| 121 | + this.rating = rating; | |
| 122 | + } | |
| 123 | + | |
| 124 | + public void setCollect_count(int collect_count) { | |
| 125 | + this.collect_count = collect_count; | |
| 126 | + } | |
| 127 | + | |
| 128 | + public void setTitle(String title) { | |
| 129 | + this.title = title; | |
| 130 | + } | |
| 131 | + | |
| 132 | + public void setOriginal_title(String original_title) { | |
| 133 | + this.original_title = original_title; | |
| 134 | + } | |
| 135 | + | |
| 136 | + public void setSubtype(String subtype) { | |
| 137 | + this.subtype = subtype; | |
| 138 | + } | |
| 139 | + | |
| 140 | + public void setYear(String year) { | |
| 141 | + this.year = year; | |
| 142 | + } | |
| 143 | + | |
| 144 | + public void setImages(ImagesEntity images) { | |
| 145 | + this.images = images; | |
| 146 | + } | |
| 147 | + | |
| 148 | + public void setAlt(String alt) { | |
| 149 | + this.alt = alt; | |
| 150 | + } | |
| 151 | + | |
| 152 | + public void setId(String id) { | |
| 153 | + this.id = id; | |
| 154 | + } | |
| 155 | + | |
| 156 | + public void setGenres(List<String> genres) { | |
| 157 | + this.genres = genres; | |
| 158 | + } | |
| 159 | + | |
| 160 | + public void setCasts(List<CastsEntity> casts) { | |
| 161 | + this.casts = casts; | |
| 162 | + } | |
| 163 | + | |
| 164 | + public void setDirectors(List<DirectorsEntity> directors) { | |
| 165 | + this.directors = directors; | |
| 166 | + } | |
| 167 | + | |
| 168 | + public RatingEntity getRating() { | |
| 169 | + return rating; | |
| 170 | + } | |
| 171 | + | |
| 172 | + public int getCollect_count() { | |
| 173 | + return collect_count; | |
| 174 | + } | |
| 175 | + | |
| 176 | + public String getTitle() { | |
| 177 | + return title; | |
| 178 | + } | |
| 179 | + | |
| 180 | + public String getOriginal_title() { | |
| 181 | + return original_title; | |
| 182 | + } | |
| 183 | + | |
| 184 | + public String getSubtype() { | |
| 185 | + return subtype; | |
| 186 | + } | |
| 187 | + | |
| 188 | + public String getYear() { | |
| 189 | + return year; | |
| 190 | + } | |
| 191 | + | |
| 192 | + public ImagesEntity getImages() { | |
| 193 | + return images; | |
| 194 | + } | |
| 195 | + | |
| 196 | + public String getAlt() { | |
| 197 | + return alt; | |
| 198 | + } | |
| 199 | + | |
| 200 | + public String getId() { | |
| 201 | + return id; | |
| 202 | + } | |
| 203 | + | |
| 204 | + public List<String> getGenres() { | |
| 205 | + return genres; | |
| 206 | + } | |
| 207 | + | |
| 208 | + public List<CastsEntity> getCasts() { | |
| 209 | + return casts; | |
| 210 | + } | |
| 211 | + | |
| 212 | + public List<DirectorsEntity> getDirectors() { | |
| 213 | + return directors; | |
| 214 | + } | |
| 215 | + | |
| 216 | + public static class RatingEntity { | |
| 217 | + private int max; | |
| 218 | + private double average; | |
| 219 | + private String stars; | |
| 220 | + private int min; | |
| 221 | + | |
| 222 | + public void setMax(int max) { | |
| 223 | + this.max = max; | |
| 224 | + } | |
| 225 | + | |
| 226 | + public void setAverage(double average) { | |
| 227 | + this.average = average; | |
| 228 | + } | |
| 229 | + | |
| 230 | + public void setStars(String stars) { | |
| 231 | + this.stars = stars; | |
| 232 | + } | |
| 233 | + | |
| 234 | + public void setMin(int min) { | |
| 235 | + this.min = min; | |
| 236 | + } | |
| 237 | + | |
| 238 | + public int getMax() { | |
| 239 | + return max; | |
| 240 | + } | |
| 241 | + | |
| 242 | + public double getAverage() { | |
| 243 | + return average; | |
| 244 | + } | |
| 245 | + | |
| 246 | + public String getStars() { | |
| 247 | + return stars; | |
| 248 | + } | |
| 249 | + | |
| 250 | + public int getMin() { | |
| 251 | + return min; | |
| 252 | + } | |
| 253 | + } | |
| 254 | + | |
| 255 | + public static class ImagesEntity { | |
| 256 | + private String small; | |
| 257 | + private String large; | |
| 258 | + private String medium; | |
| 259 | + | |
| 260 | + public void setSmall(String small) { | |
| 261 | + this.small = small; | |
| 262 | + } | |
| 263 | + | |
| 264 | + public void setLarge(String large) { | |
| 265 | + this.large = large; | |
| 266 | + } | |
| 267 | + | |
| 268 | + public void setMedium(String medium) { | |
| 269 | + this.medium = medium; | |
| 270 | + } | |
| 271 | + | |
| 272 | + public String getSmall() { | |
| 273 | + return small; | |
| 274 | + } | |
| 275 | + | |
| 276 | + public String getLarge() { | |
| 277 | + return large; | |
| 278 | + } | |
| 279 | + | |
| 280 | + public String getMedium() { | |
| 281 | + return medium; | |
| 282 | + } | |
| 283 | + } | |
| 284 | + | |
| 285 | + public static class CastsEntity { | |
| 286 | + /** | |
| 287 | + * small : https://img1.doubanio.com/img/celebrity/small/1679.jpg | |
| 288 | + * large : https://img1.doubanio.com/img/celebrity/large/1679.jpg | |
| 289 | + * medium : https://img1.doubanio.com/img/celebrity/medium/1679.jpg | |
| 290 | + */ | |
| 291 | + | |
| 292 | + private AvatarsEntity avatars; | |
| 293 | + private String alt; | |
| 294 | + private String id; | |
| 295 | + private String name; | |
| 296 | + | |
| 297 | + public void setAvatars(AvatarsEntity avatars) { | |
| 298 | + this.avatars = avatars; | |
| 299 | + } | |
| 300 | + | |
| 301 | + public void setAlt(String alt) { | |
| 302 | + this.alt = alt; | |
| 303 | + } | |
| 304 | + | |
| 305 | + public void setId(String id) { | |
| 306 | + this.id = id; | |
| 307 | + } | |
| 308 | + | |
| 309 | + public void setName(String name) { | |
| 310 | + this.name = name; | |
| 311 | + } | |
| 312 | + | |
| 313 | + public AvatarsEntity getAvatars() { | |
| 314 | + return avatars; | |
| 315 | + } | |
| 316 | + | |
| 317 | + public String getAlt() { | |
| 318 | + return alt; | |
| 319 | + } | |
| 320 | + | |
| 321 | + public String getId() { | |
| 322 | + return id; | |
| 323 | + } | |
| 324 | + | |
| 325 | + public String getName() { | |
| 326 | + return name; | |
| 327 | + } | |
| 328 | + | |
| 329 | + public static class AvatarsEntity { | |
| 330 | + private String small; | |
| 331 | + private String large; | |
| 332 | + private String medium; | |
| 333 | + | |
| 334 | + public void setSmall(String small) { | |
| 335 | + this.small = small; | |
| 336 | + } | |
| 337 | + | |
| 338 | + public void setLarge(String large) { | |
| 339 | + this.large = large; | |
| 340 | + } | |
| 341 | + | |
| 342 | + public void setMedium(String medium) { | |
| 343 | + this.medium = medium; | |
| 344 | + } | |
| 345 | + | |
| 346 | + public String getSmall() { | |
| 347 | + return small; | |
| 348 | + } | |
| 349 | + | |
| 350 | + public String getLarge() { | |
| 351 | + return large; | |
| 352 | + } | |
| 353 | + | |
| 354 | + public String getMedium() { | |
| 355 | + return medium; | |
| 356 | + } | |
| 357 | + } | |
| 358 | + } | |
| 359 | + | |
| 360 | + public static class DirectorsEntity { | |
| 361 | + /** | |
| 362 | + * small : https://img3.doubanio.com/img/celebrity/small/230.jpg | |
| 363 | + * large : https://img3.doubanio.com/img/celebrity/large/230.jpg | |
| 364 | + * medium : https://img3.doubanio.com/img/celebrity/medium/230.jpg | |
| 365 | + */ | |
| 366 | + | |
| 367 | + private AvatarsEntity avatars; | |
| 368 | + private String alt; | |
| 369 | + private String id; | |
| 370 | + private String name; | |
| 371 | + | |
| 372 | + public void setAvatars(AvatarsEntity avatars) { | |
| 373 | + this.avatars = avatars; | |
| 374 | + } | |
| 375 | + | |
| 376 | + public void setAlt(String alt) { | |
| 377 | + this.alt = alt; | |
| 378 | + } | |
| 379 | + | |
| 380 | + public void setId(String id) { | |
| 381 | + this.id = id; | |
| 382 | + } | |
| 383 | + | |
| 384 | + public void setName(String name) { | |
| 385 | + this.name = name; | |
| 386 | + } | |
| 387 | + | |
| 388 | + public AvatarsEntity getAvatars() { | |
| 389 | + return avatars; | |
| 390 | + } | |
| 391 | + | |
| 392 | + public String getAlt() { | |
| 393 | + return alt; | |
| 394 | + } | |
| 395 | + | |
| 396 | + public String getId() { | |
| 397 | + return id; | |
| 398 | + } | |
| 399 | + | |
| 400 | + public String getName() { | |
| 401 | + return name; | |
| 402 | + } | |
| 403 | + | |
| 404 | + public static class AvatarsEntity { | |
| 405 | + private String small; | |
| 406 | + private String large; | |
| 407 | + private String medium; | |
| 408 | + | |
| 409 | + public void setSmall(String small) { | |
| 410 | + this.small = small; | |
| 411 | + } | |
| 412 | + | |
| 413 | + public void setLarge(String large) { | |
| 414 | + this.large = large; | |
| 415 | + } | |
| 416 | + | |
| 417 | + public void setMedium(String medium) { | |
| 418 | + this.medium = medium; | |
| 419 | + } | |
| 420 | + | |
| 421 | + public String getSmall() { | |
| 422 | + return small; | |
| 423 | + } | |
| 424 | + | |
| 425 | + public String getLarge() { | |
| 426 | + return large; | |
| 427 | + } | |
| 428 | + | |
| 429 | + public String getMedium() { | |
| 430 | + return medium; | |
| 431 | + } | |
| 432 | + } | |
| 433 | + } | |
| 434 | + } | |
| 435 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import com.gimi.common.cinema.utils.OkHttpClientManager; | |
| 4 | +import com.google.gson.Gson; | |
| 5 | +import com.google.gson.JsonSyntaxException; | |
| 6 | +import com.google.gson.reflect.TypeToken; | |
| 7 | +import com.xgimi.gimicinema.model.ThreadUtils; | |
| 8 | + | |
| 9 | +import java.io.IOException; | |
| 10 | + | |
| 11 | +/** | |
| 12 | + * Created by wugian on 2015/12/29 | |
| 13 | + */ | |
| 14 | +public class QueryDoubanUtils { | |
| 15 | + private static final String SEARCH_BY_NAME_URL = | |
| 16 | + "https://api.douban.com/v2/movie/search?count=3&q="; | |
| 17 | + | |
| 18 | + public static void getQueryBeanByName( | |
| 19 | + final String name, final AsyncCallback<QueryBean> callback) { | |
| 20 | + ThreadUtils.subThread(new ThreadUtils.DoSomeThing() { | |
| 21 | + @Override | |
| 22 | + public void doSomeThing() { | |
| 23 | + callback.onStart(); | |
| 24 | + WrongMsg wrongMsg = new WrongMsg(); | |
| 25 | + QueryBean result = null; | |
| 26 | + Gson gson = new Gson(); | |
| 27 | + String s = ""; | |
| 28 | + try { | |
| 29 | + s = OkHttpClientManager.getAsString(SEARCH_BY_NAME_URL + name); | |
| 30 | + wrongMsg = gson.fromJson(s, new TypeToken<WrongMsg>() { | |
| 31 | + }.getType()); | |
| 32 | + if (wrongMsg.getCode() != 0) { | |
| 33 | + callback.onFailure(wrongMsg); | |
| 34 | + } else { | |
| 35 | + result = gson.fromJson(s, new TypeToken<QueryBean>() { | |
| 36 | + }.getType()); | |
| 37 | + | |
| 38 | + callback.onSuccess(result); | |
| 39 | + } | |
| 40 | + } catch (JsonSyntaxException | IOException e) { | |
| 41 | + e.printStackTrace(); | |
| 42 | + } | |
| 43 | + callback.onDone(); | |
| 44 | + } | |
| 45 | + }); | |
| 46 | + } | |
| 47 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by pc on 2014/12/24 | |
| 5 | + */ | |
| 6 | +public class Rating { | |
| 7 | + private int max; | |
| 8 | + private double average; | |
| 9 | + private String stars; | |
| 10 | + private int min; | |
| 11 | + | |
| 12 | + | |
| 13 | + public int getMax() { | |
| 14 | + return max; | |
| 15 | + } | |
| 16 | + | |
| 17 | + public void setMax(int max) { | |
| 18 | + this.max = max; | |
| 19 | + } | |
| 20 | + | |
| 21 | + public double getAverage() { | |
| 22 | + return average; | |
| 23 | + } | |
| 24 | + | |
| 25 | + public void setAverage(double average) { | |
| 26 | + this.average = average; | |
| 27 | + } | |
| 28 | + | |
| 29 | + public String getStars() { | |
| 30 | + return stars; | |
| 31 | + } | |
| 32 | + | |
| 33 | + public void setStars(String stars) { | |
| 34 | + this.stars = stars; | |
| 35 | + } | |
| 36 | + | |
| 37 | + public int getMin() { | |
| 38 | + return min; | |
| 39 | + } | |
| 40 | + | |
| 41 | + public void setMin(int min) { | |
| 42 | + this.min = min; | |
| 43 | + } | |
| 44 | + | |
| 45 | + | |
| 46 | + @Override | |
| 47 | + public String toString() { | |
| 48 | + return "Rating{" + | |
| 49 | + "max=" + max + | |
| 50 | + ", average=" + average + | |
| 51 | + ", stars='" + stars + '\'' + | |
| 52 | + ", min=" + min + | |
| 53 | + '}'; | |
| 54 | + } | |
| 55 | +} | ... | ... |
| 1 | +/* | |
| 2 | + * Copyright (c) 2016. wugian | |
| 3 | + * Licensed under the Apache License, Version 2.0 (the "License"); | |
| 4 | + * you may not use this file except in compliance with the License. | |
| 5 | + * You may obtain a copy of the License at | |
| 6 | + * | |
| 7 | + * http://www.apache.org/licenses/LICENSE-2.0 | |
| 8 | + * | |
| 9 | + * Unless required by applicable law or agreed to in writing, software | |
| 10 | + * distributed under the License is distributed on an "AS IS" BASIS, | |
| 11 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 12 | + * See the License for the specific language governing permissions and | |
| 13 | + * limitations under the License. | |
| 14 | + * | |
| 15 | + */ | |
| 16 | + | |
| 17 | +package com.gimi.common.cinema.model; | |
| 18 | + | |
| 19 | +/** | |
| 20 | + * Created by pc on 2015/1/6 | |
| 21 | + */ | |
| 22 | +public class StatusData { | |
| 23 | + // "status":"on","delay":300 | |
| 24 | + private String status; | |
| 25 | + private int delay; | |
| 26 | + | |
| 27 | + public String getStatus() { | |
| 28 | + return status; | |
| 29 | + } | |
| 30 | + | |
| 31 | + public void setStatus(String status) { | |
| 32 | + this.status = status; | |
| 33 | + } | |
| 34 | + | |
| 35 | + public int getDelay() { | |
| 36 | + return delay; | |
| 37 | + } | |
| 38 | + | |
| 39 | + public void setDelay(int delay) { | |
| 40 | + this.delay = delay; | |
| 41 | + } | |
| 42 | + | |
| 43 | + @Override | |
| 44 | + public String toString() { | |
| 45 | + return "GimiData{" + | |
| 46 | + "status='" + status + '\'' + | |
| 47 | + ", delay=" + delay + | |
| 48 | + '}'; | |
| 49 | + } | |
| 50 | +} | |
| 51 | + | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import java.util.Arrays; | |
| 4 | + | |
| 5 | +/** | |
| 6 | + * Created by 李攀 on 2015/9/16 | |
| 7 | + * { | |
| 8 | + "multi": "false", | |
| 9 | + "position": 2, | |
| 10 | + "movie_urls": [ | |
| 11 | + "192.168.4.214/root/TS/我不是潘金莲/【我不是潘金莲】【导演:冯小刚】【2016年】【国语】-魅族DVD高清.mp4", | |
| 12 | + "192.168.4.214/root/XS/GaIn/GaIn.ts", | |
| 13 | + "192.168.4.214/root/XS/真的喜欢你/真的喜欢你.ts", | |
| 14 | + "192.168.4.214/root/XS/岁的纯情/岁的纯情.ts" | |
| 15 | + ] | |
| 16 | + } | |
| 17 | + */ | |
| 18 | +public class UdpModel { | |
| 19 | + private String movie_url; | |
| 20 | + private boolean multi; | |
| 21 | + private int position; | |
| 22 | + private String[] movie_urls; | |
| 23 | + | |
| 24 | + public String getMovie_url() { | |
| 25 | + return movie_url; | |
| 26 | + } | |
| 27 | + | |
| 28 | + public void setMovie_url(String movie_url) { | |
| 29 | + this.movie_url = movie_url; | |
| 30 | + } | |
| 31 | + | |
| 32 | + public boolean isMulti() { | |
| 33 | + return multi; | |
| 34 | + } | |
| 35 | + | |
| 36 | + public void setMulti(boolean multi) { | |
| 37 | + this.multi = multi; | |
| 38 | + } | |
| 39 | + | |
| 40 | + public int getPosition() { | |
| 41 | + return position; | |
| 42 | + } | |
| 43 | + | |
| 44 | + public void setPosition(int position) { | |
| 45 | + this.position = position; | |
| 46 | + } | |
| 47 | + | |
| 48 | + public String[] getMovie_urls() { | |
| 49 | + return movie_urls; | |
| 50 | + } | |
| 51 | + | |
| 52 | + public void setMovie_urls(String[] movie_urls) { | |
| 53 | + this.movie_urls = movie_urls; | |
| 54 | + } | |
| 55 | + | |
| 56 | + @Override | |
| 57 | + public String toString() { | |
| 58 | + return "UdpModel{" + | |
| 59 | + "movie_url='" + movie_url + '\'' + | |
| 60 | + ", single=" + multi + | |
| 61 | + ", position=" + position + | |
| 62 | + ", movie_urls=" + Arrays.toString(movie_urls) + | |
| 63 | + '}'; | |
| 64 | + } | |
| 65 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +/** | |
| 4 | + * Created by 李攀 on 2015/11/11. | |
| 5 | + */ | |
| 6 | +public class UserInfo { | |
| 7 | + private String userName; | |
| 8 | + private String pwd; | |
| 9 | + private String serverIp; | |
| 10 | + private String ipAddr; | |
| 11 | + private String shareFolder; | |
| 12 | + | |
| 13 | + public String getUserName() { | |
| 14 | + return userName; | |
| 15 | + } | |
| 16 | + | |
| 17 | + public void setUserName(String userName) { | |
| 18 | + this.userName = userName; | |
| 19 | + } | |
| 20 | + | |
| 21 | + public String getPwd() { | |
| 22 | + return pwd; | |
| 23 | + } | |
| 24 | + | |
| 25 | + public void setPwd(String pwd) { | |
| 26 | + this.pwd = pwd; | |
| 27 | + } | |
| 28 | + | |
| 29 | + public String getServerIp() { | |
| 30 | + return serverIp; | |
| 31 | + } | |
| 32 | + | |
| 33 | + public void setServerIp(String serverIp) { | |
| 34 | + this.serverIp = serverIp; | |
| 35 | + } | |
| 36 | + | |
| 37 | + public String getIpAddr() { | |
| 38 | + return ipAddr; | |
| 39 | + } | |
| 40 | + | |
| 41 | + public void setIpAddr(String ipAddr) { | |
| 42 | + this.ipAddr = ipAddr; | |
| 43 | + } | |
| 44 | + | |
| 45 | + public String getShareFolder() { | |
| 46 | + return shareFolder; | |
| 47 | + } | |
| 48 | + | |
| 49 | + public void setShareFolder(String shareFolder) { | |
| 50 | + this.shareFolder = shareFolder; | |
| 51 | + } | |
| 52 | +} | ... | ... |
| 1 | +package com.gimi.common.cinema.model; | |
| 2 | + | |
| 3 | +import com.google.gson.annotations.Expose; | |
| 4 | + | |
| 5 | +public class WrongMsg extends Throwable { | |
| 6 | + /** | |
| 7 | + * | |
| 8 | + */ | |
| 9 | + private static final long serialVersionUID = 7457964260418110305L; | |
| 10 | + // "msg":"uri_not_found", | |
| 11 | + // "code":1001, | |
| 12 | + // "request":"GET \/v2\/photo\/132" | |
| 13 | + @Expose | |
| 14 | + private String msg;// wrong msg describe | |
| 15 | + @Expose | |
| 16 | + private String request;// request url and method | |
| 17 | + @Expose | |
| 18 | + private int code;// wrong code | |
| 19 | + | |
| 20 | + public String getMsg() { | |
| 21 | + return msg; | |
| 22 | + } | |
| 23 | + | |
| 24 | + public void setMsg(String msg) { | |
| 25 | + this.msg = msg; | |
| 26 | + } | |
| 27 | + | |
| 28 | + public String getRequest() { | |
| 29 | + return request; | |
| 30 | + } | |
| 31 | + | |
| 32 | + public void setRequest(String request) { | |
| 33 | + this.request = request; | |
| 34 | + } | |
| 35 | + | |
| 36 | + public int getCode() { | |
| 37 | + return code; | |
| 38 | + } | |
| 39 | + | |
| 40 | + public void setCode(int code) { | |
| 41 | + this.code = code; | |
| 42 | + } | |
| 43 | + | |
| 44 | +} | ... | ... |
| 1 | +/* | |
| 2 | + * Copyright (c) 2016. wugian | |
| 3 | + * Licensed under the Apache License, Version 2.0 (the "License"); | |
| 4 | + * you may not use this file except in compliance with the License. | |
| 5 | + * You may obtain a copy of the License at | |
| 6 | + * | |
| 7 | + * http://www.apache.org/licenses/LICENSE-2.0 | |
| 8 | + * | |
| 9 | + * Unless required by applicable law or agreed to in writing, software | |
| 10 | + * distributed under the License is distributed on an "AS IS" BASIS, | |
| 11 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| 12 | + * See the License for the specific language governing permissions and | |
| 13 | + * limitations under the License. | |
| 14 | + * | |
| 15 | + */ | |
| 16 | +package com.gimi.common.cinema.utils; | |
| 17 | + | |
| 18 | +import android.content.Context; | |
| 19 | +import android.graphics.Bitmap; | |
| 20 | +import android.graphics.BitmapFactory; | |
| 21 | +import android.graphics.Canvas; | |
| 22 | +import android.graphics.PixelFormat; | |
| 23 | +import android.graphics.drawable.BitmapDrawable; | |
| 24 | +import android.graphics.drawable.Drawable; | |
| 25 | +import org.json.JSONArray; | |
| 26 | +import org.json.JSONObject; | |
| 27 | + | |
| 28 | +import java.io.BufferedReader; | |
| 29 | +import java.io.BufferedWriter; | |
| 30 | +import java.io.ByteArrayInputStream; | |
| 31 | +import java.io.ByteArrayOutputStream; | |
| 32 | +import java.io.File; | |
| 33 | +import java.io.FileOutputStream; | |
| 34 | +import java.io.FileReader; | |
| 35 | +import java.io.FileWriter; | |
| 36 | +import java.io.IOException; | |
| 37 | +import java.io.ObjectInputStream; | |
| 38 | +import java.io.ObjectOutputStream; | |
| 39 | +import java.io.RandomAccessFile; | |
| 40 | +import java.io.Serializable; | |
| 41 | +import java.util.Collections; | |
| 42 | +import java.util.HashMap; | |
| 43 | +import java.util.Map; | |
| 44 | +import java.util.Map.Entry; | |
| 45 | +import java.util.Set; | |
| 46 | +import java.util.concurrent.atomic.AtomicInteger; | |
| 47 | +import java.util.concurrent.atomic.AtomicLong; | |
| 48 | + | |
| 49 | +/** | |
| 50 | + * @author Michael Yang(www.yangfuhai.com) update at 2013.08.07 | |
| 51 | + */ | |
| 52 | +public class ACache { | |
| 53 | + public static final int TIME_HOUR = 60 * 60; | |
| 54 | + public static final int TIME_DAY = TIME_HOUR * 24; | |
| 55 | + private static final int MAX_SIZE = 1000 * 1000 * 50; // 50 mb | |
| 56 | + private static final int MAX_COUNT = Integer.MAX_VALUE; // 不限制存放数据的数量 | |
| 57 | + private static Map<String, ACache> mInstanceMap = new HashMap<String, ACache>(); | |
| 58 | + private ACacheManager mCache; | |
| 59 | + | |
| 60 | + public static ACache get(Context ctx) { | |
| 61 | + return get(ctx, "ACache"); | |
| 62 | + } | |
| 63 | + | |
| 64 | + public static ACache get(Context ctx, String cacheName) { | |
| 65 | + File f = new File(ctx.getCacheDir(), cacheName); | |
| 66 | + return get(f, MAX_SIZE, MAX_COUNT); | |
| 67 | + } | |
| 68 | + | |
| 69 | + public static ACache get(File cacheDir) { | |
| 70 | + return get(cacheDir, MAX_SIZE, MAX_COUNT); | |
| 71 | + } | |
| 72 | + | |
| 73 | + public static ACache get(Context ctx, long max_zise, int max_count) { | |
| 74 | + File f = new File(ctx.getCacheDir(), "ACache"); | |
| 75 | + return get(f, max_zise, max_count); | |
| 76 | + } | |
| 77 | + | |
| 78 | + public static ACache get(File cacheDir, long max_zise, int max_count) { | |
| 79 | + ACache manager = mInstanceMap.get(cacheDir.getAbsoluteFile() + myPid()); | |
| 80 | + if (manager == null) { | |
| 81 | + manager = new ACache(cacheDir, max_zise, max_count); | |
| 82 | + mInstanceMap.put(cacheDir.getAbsolutePath() + myPid(), manager); | |
| 83 | + } | |
| 84 | + return manager; | |
| 85 | + } | |
| 86 | + | |
| 87 | + private static String myPid() { | |
| 88 | + return "_" + android.os.Process.myPid(); | |
| 89 | + } | |
| 90 | + | |
| 91 | + private ACache(File cacheDir, long max_size, int max_count) { | |
| 92 | + if (!cacheDir.exists() && !cacheDir.mkdirs()) { | |
| 93 | + throw new RuntimeException("can't make dirs in " | |
| 94 | + + cacheDir.getAbsolutePath()); | |
| 95 | + } | |
| 96 | + mCache = new ACacheManager(cacheDir, max_size, max_count); | |
| 97 | + } | |
| 98 | + | |
| 99 | + // ======================================= | |
| 100 | + // ============ String数据 读写 ============== | |
| 101 | + // ======================================= | |
| 102 | + /** | |
| 103 | + * 保存 String数据 到 缓存中 | |
| 104 | + * | |
| 105 | + * @param key | |
| 106 | + * 保存的key | |
| 107 | + * @param value | |
| 108 | + * 保存的String数据 | |
| 109 | + */ | |
| 110 | + public void put(String key, String value) { | |
| 111 | + File file = mCache.newFile(key); | |
| 112 | + BufferedWriter out = null; | |
| 113 | + try { | |
| 114 | + out = new BufferedWriter(new FileWriter(file), 1024); | |
| 115 | + out.write(value); | |
| 116 | + } catch (IOException e) { | |
| 117 | + e.printStackTrace(); | |
| 118 | + } finally { | |
| 119 | + if (out != null) { | |
| 120 | + try { | |
| 121 | + out.flush(); | |
| 122 | + out.close(); | |
| 123 | + } catch (IOException e) { | |
| 124 | + e.printStackTrace(); | |
| 125 | + } | |
| 126 | + } | |
| 127 | + mCache.put(file); | |
| 128 | + } | |
| 129 | + } | |
| 130 | + | |
| 131 | + /** | |
| 132 | + * 保存 String数据 到 缓存中 | |
| 133 | + * | |
| 134 | + * @param key | |
| 135 | + * 保存的key | |
| 136 | + * @param value | |
| 137 | + * 保存的String数据 | |
| 138 | + * @param saveTime | |
| 139 | + * 保存的时间,单位:秒 | |
| 140 | + */ | |
| 141 | + public void put(String key, String value, int saveTime) { | |
| 142 | + put(key, Utils.newStringWithDateInfo(saveTime, value)); | |
| 143 | + } | |
| 144 | + | |
| 145 | + /** | |
| 146 | + * 读取 String数据 | |
| 147 | + * | |
| 148 | + * @param key | |
| 149 | + * @return String 数据 | |
| 150 | + */ | |
| 151 | + public String getAsString(String key) { | |
| 152 | + File file = mCache.get(key); | |
| 153 | + if (!file.exists()) | |
| 154 | + return null; | |
| 155 | + boolean removeFile = false; | |
| 156 | + BufferedReader in = null; | |
| 157 | + try { | |
| 158 | + in = new BufferedReader(new FileReader(file)); | |
| 159 | + String readString = ""; | |
| 160 | + String currentLine; | |
| 161 | + while ((currentLine = in.readLine()) != null) { | |
| 162 | + readString += currentLine; | |
| 163 | + } | |
| 164 | + if (!Utils.isDue(readString)) { | |
| 165 | + return Utils.clearDateInfo(readString); | |
| 166 | + } else { | |
| 167 | + removeFile = true; | |
| 168 | + return null; | |
| 169 | + } | |
| 170 | + } catch (IOException e) { | |
| 171 | + e.printStackTrace(); | |
| 172 | + return null; | |
| 173 | + } finally { | |
| 174 | + if (in != null) { | |
| 175 | + try { | |
| 176 | + in.close(); | |
| 177 | + } catch (IOException e) { | |
| 178 | + e.printStackTrace(); | |
| 179 | + } | |
| 180 | + } | |
| 181 | + if (removeFile) | |
| 182 | + remove(key); | |
| 183 | + } | |
| 184 | + } | |
| 185 | + | |
| 186 | + // ======================================= | |
| 187 | + // ============= JSONObject 数据 读写 ============== | |
| 188 | + // ======================================= | |
| 189 | + /** | |
| 190 | + * 保存 JSONObject数据 到 缓存中 | |
| 191 | + * | |
| 192 | + * @param key | |
| 193 | + * 保存的key | |
| 194 | + * @param value | |
| 195 | + * 保存的JSON数据 | |
| 196 | + */ | |
| 197 | + public void put(String key, JSONObject value) { | |
| 198 | + put(key, value.toString()); | |
| 199 | + } | |
| 200 | + | |
| 201 | + /** | |
| 202 | + * 保存 JSONObject数据 到 缓存中 | |
| 203 | + * | |
| 204 | + * @param key | |
| 205 | + * 保存的key | |
| 206 | + * @param value | |
| 207 | + * 保存的JSONObject数据 | |
| 208 | + * @param saveTime | |
| 209 | + * 保存的时间,单位:秒 | |
| 210 | + */ | |
| 211 | + public void put(String key, JSONObject value, int saveTime) { | |
| 212 | + put(key, value.toString(), saveTime); | |
| 213 | + } | |
| 214 | + | |
| 215 | + /** | |
| 216 | + * 读取JSONObject数据 | |
| 217 | + * | |
| 218 | + * @param key | |
| 219 | + * @return JSONObject数据 | |
| 220 | + */ | |
| 221 | + public JSONObject getAsJSONObject(String key) { | |
| 222 | + String JSONString = getAsString(key); | |
| 223 | + try { | |
| 224 | + JSONObject obj = new JSONObject(JSONString); | |
| 225 | + return obj; | |
| 226 | + } catch (Exception e) { | |
| 227 | + e.printStackTrace(); | |
| 228 | + return null; | |
| 229 | + } | |
| 230 | + } | |
| 231 | + | |
| 232 | + // ======================================= | |
| 233 | + // ============ JSONArray 数据 读写 ============= | |
| 234 | + // ======================================= | |
| 235 | + /** | |
| 236 | + * 保存 JSONArray数据 到 缓存中 | |
| 237 | + * | |
| 238 | + * @param key | |
| 239 | + * 保存的key | |
| 240 | + * @param value | |
| 241 | + * 保存的JSONArray数据 | |
| 242 | + */ | |
| 243 | + public void put(String key, JSONArray value) { | |
| 244 | + put(key, value.toString()); | |
| 245 | + } | |
| 246 | + | |
| 247 | + /** | |
| 248 | + * 保存 JSONArray数据 到 缓存中 | |
| 249 | + * | |
| 250 | + * @param key | |
| 251 | + * 保存的key | |
| 252 | + * @param value | |
| 253 | + * 保存的JSONArray数据 | |
| 254 | + * @param saveTime | |
| 255 | + * 保存的时间,单位:秒 | |
| 256 | + */ | |
| 257 | + public void put(String key, JSONArray value, int saveTime) { | |
| 258 | + put(key, value.toString(), saveTime); | |
| 259 | + } | |
| 260 | + | |
| 261 | + /** | |
| 262 | + * 读取JSONArray数据 | |
| 263 | + * | |
| 264 | + * @param key | |
| 265 | + * @return JSONArray数据 | |
| 266 | + */ | |
| 267 | + public JSONArray getAsJSONArray(String key) { | |
| 268 | + String JSONString = getAsString(key); | |
| 269 | + try { | |
| 270 | + JSONArray obj = new JSONArray(JSONString); | |
| 271 | + return obj; | |
| 272 | + } catch (Exception e) { | |
| 273 | + e.printStackTrace(); | |
| 274 | + return null; | |
| 275 | + } | |
| 276 | + } | |
| 277 | + | |
| 278 | + // ======================================= | |
| 279 | + // ============== byte 数据 读写 ============= | |
| 280 | + // ======================================= | |
| 281 | + /** | |
| 282 | + * 保存 byte数据 到 缓存中 | |
| 283 | + * | |
| 284 | + * @param key | |
| 285 | + * 保存的key | |
| 286 | + * @param value | |
| 287 | + * 保存的数据 | |
| 288 | + */ | |
| 289 | + public void put(String key, byte[] value) { | |
| 290 | + File file = mCache.newFile(key); | |
| 291 | + FileOutputStream out = null; | |
| 292 | + try { | |
| 293 | + out = new FileOutputStream(file); | |
| 294 | + out.write(value); | |
| 295 | + } catch (Exception e) { | |
| 296 | + e.printStackTrace(); | |
| 297 | + } finally { | |
| 298 | + if (out != null) { | |
| 299 | + try { | |
| 300 | + out.flush(); | |
| 301 | + out.close(); | |
| 302 | + } catch (IOException e) { | |
| 303 | + e.printStackTrace(); | |
| 304 | + } | |
| 305 | + } | |
| 306 | + mCache.put(file); | |
| 307 | + } | |
| 308 | + } | |
| 309 | + | |
| 310 | + /** | |
| 311 | + * 保存 byte数据 到 缓存中 | |
| 312 | + * | |
| 313 | + * @param key | |
| 314 | + * 保存的key | |
| 315 | + * @param value | |
| 316 | + * 保存的数据 | |
| 317 | + * @param saveTime | |
| 318 | + * 保存的时间,单位:秒 | |
| 319 | + */ | |
| 320 | + public void put(String key, byte[] value, int saveTime) { | |
| 321 | + put(key, Utils.newByteArrayWithDateInfo(saveTime, value)); | |
| 322 | + } | |
| 323 | + | |
| 324 | + /** | |
| 325 | + * 获取 byte 数据 | |
| 326 | + * | |
| 327 | + * @param key | |
| 328 | + * @return byte 数据 | |
| 329 | + */ | |
| 330 | + public byte[] getAsBinary(String key) { | |
| 331 | + RandomAccessFile RAFile = null; | |
| 332 | + boolean removeFile = false; | |
| 333 | + try { | |
| 334 | + File file = mCache.get(key); | |
| 335 | + if (!file.exists()) | |
| 336 | + return null; | |
| 337 | + RAFile = new RandomAccessFile(file, "r"); | |
| 338 | + byte[] byteArray = new byte[(int) RAFile.length()]; | |
| 339 | + RAFile.read(byteArray); | |
| 340 | + if (!Utils.isDue(byteArray)) { | |
| 341 | + return Utils.clearDateInfo(byteArray); | |
| 342 | + } else { | |
| 343 | + removeFile = true; | |
| 344 | + return null; | |
| 345 | + } | |
| 346 | + } catch (Exception e) { | |
| 347 | + e.printStackTrace(); | |
| 348 | + return null; | |
| 349 | + } finally { | |
| 350 | + if (RAFile != null) { | |
| 351 | + try { | |
| 352 | + RAFile.close(); | |
| 353 | + } catch (IOException e) { | |
| 354 | + e.printStackTrace(); | |
| 355 | + } | |
| 356 | + } | |
| 357 | + if (removeFile) | |
| 358 | + remove(key); | |
| 359 | + } | |
| 360 | + } | |
| 361 | + | |
| 362 | + // ======================================= | |
| 363 | + // ============= 序列化 数据 读写 =============== | |
| 364 | + // ======================================= | |
| 365 | + /** | |
| 366 | + * 保存 Serializable数据 到 缓存中 | |
| 367 | + * | |
| 368 | + * @param key | |
| 369 | + * 保存的key | |
| 370 | + * @param value | |
| 371 | + * 保存的value | |
| 372 | + */ | |
| 373 | + public void put(String key, Serializable value) { | |
| 374 | + put(key, value, -1); | |
| 375 | + } | |
| 376 | + | |
| 377 | + /** | |
| 378 | + * 保存 Serializable数据到 缓存中 | |
| 379 | + * | |
| 380 | + * @param key | |
| 381 | + * 保存的key | |
| 382 | + * @param value | |
| 383 | + * 保存的value | |
| 384 | + * @param saveTime | |
| 385 | + * 保存的时间,单位:秒 | |
| 386 | + */ | |
| 387 | + public void put(String key, Serializable value, int saveTime) { | |
| 388 | + ByteArrayOutputStream baos = null; | |
| 389 | + ObjectOutputStream oos = null; | |
| 390 | + try { | |
| 391 | + baos = new ByteArrayOutputStream(); | |
| 392 | + oos = new ObjectOutputStream(baos); | |
| 393 | + oos.writeObject(value); | |
| 394 | + byte[] data = baos.toByteArray(); | |
| 395 | + if (saveTime != -1) { | |
| 396 | + put(key, data, saveTime); | |
| 397 | + } else { | |
| 398 | + put(key, data); | |
| 399 | + } | |
| 400 | + } catch (Exception e) { | |
| 401 | + e.printStackTrace(); | |
| 402 | + } finally { | |
| 403 | + try { | |
| 404 | + oos.close(); | |
| 405 | + } catch (IOException e) { | |
| 406 | + } | |
| 407 | + } | |
| 408 | + } | |
| 409 | + | |
| 410 | + /** | |
| 411 | + * 读取 Serializable数据 | |
| 412 | + * | |
| 413 | + * @param key | |
| 414 | + * @return Serializable 数据 | |
| 415 | + */ | |
| 416 | + public Object getAsObject(String key) { | |
| 417 | + byte[] data = getAsBinary(key); | |
| 418 | + if (data != null) { | |
| 419 | + ByteArrayInputStream bais = null; | |
| 420 | + ObjectInputStream ois = null; | |
| 421 | + try { | |
| 422 | + bais = new ByteArrayInputStream(data); | |
| 423 | + ois = new ObjectInputStream(bais); | |
| 424 | + Object reObject = ois.readObject(); | |
| 425 | + return reObject; | |
| 426 | + } catch (Exception e) { | |
| 427 | + e.printStackTrace(); | |
| 428 | + return null; | |
| 429 | + } finally { | |
| 430 | + try { | |
| 431 | + if (bais != null) | |
| 432 | + bais.close(); | |
| 433 | + } catch (IOException e) { | |
| 434 | + e.printStackTrace(); | |
| 435 | + } | |
| 436 | + try { | |
| 437 | + if (ois != null) | |
| 438 | + ois.close(); | |
| 439 | + } catch (IOException e) { | |
| 440 | + e.printStackTrace(); | |
| 441 | + } | |
| 442 | + } | |
| 443 | + } | |
| 444 | + return null; | |
| 445 | + | |
| 446 | + } | |
| 447 | + | |
| 448 | + // ======================================= | |
| 449 | + // ============== bitmap 数据 读写 ============= | |
| 450 | + // ======================================= | |
| 451 | + /** | |
| 452 | + * 保存 bitmap 到 缓存中 | |
| 453 | + * | |
| 454 | + * @param key | |
| 455 | + * 保存的key | |
| 456 | + * @param value | |
| 457 | + * 保存的bitmap数据 | |
| 458 | + */ | |
| 459 | + public void put(String key, Bitmap value) { | |
| 460 | + put(key, Utils.Bitmap2Bytes(value)); | |
| 461 | + } | |
| 462 | + | |
| 463 | + /** | |
| 464 | + * 保存 bitmap 到 缓存中 | |
| 465 | + * | |
| 466 | + * @param key | |
| 467 | + * 保存的key | |
| 468 | + * @param value | |
| 469 | + * 保存的 bitmap 数据 | |
| 470 | + * @param saveTime | |
| 471 | + * 保存的时间,单位:秒 | |
| 472 | + */ | |
| 473 | + public void put(String key, Bitmap value, int saveTime) { | |
| 474 | + put(key, Utils.Bitmap2Bytes(value), saveTime); | |
| 475 | + } | |
| 476 | + | |
| 477 | + /** | |
| 478 | + * 读取 bitmap 数据 | |
| 479 | + * | |
| 480 | + * @param key | |
| 481 | + * @return bitmap 数据 | |
| 482 | + */ | |
| 483 | + public Bitmap getAsBitmap(String key) { | |
| 484 | + if (getAsBinary(key) == null) { | |
| 485 | + return null; | |
| 486 | + } | |
| 487 | + return Utils.Bytes2Bimap(getAsBinary(key)); | |
| 488 | + } | |
| 489 | + | |
| 490 | + // ======================================= | |
| 491 | + // ============= drawable 数据 读写 ============= | |
| 492 | + // ======================================= | |
| 493 | + /** | |
| 494 | + * 保存 drawable 到 缓存中 | |
| 495 | + * | |
| 496 | + * @param key | |
| 497 | + * 保存的key | |
| 498 | + * @param value | |
| 499 | + * 保存的drawable数据 | |
| 500 | + */ | |
| 501 | + public void put(String key, Drawable value) { | |
| 502 | + put(key, Utils.drawable2Bitmap(value)); | |
| 503 | + } | |
| 504 | + | |
| 505 | + /** | |
| 506 | + * 保存 drawable 到 缓存中 | |
| 507 | + * | |
| 508 | + * @param key | |
| 509 | + * 保存的key | |
| 510 | + * @param value | |
| 511 | + * 保存的 drawable 数据 | |
| 512 | + * @param saveTime | |
| 513 | + * 保存的时间,单位:秒 | |
| 514 | + */ | |
| 515 | + public void put(String key, Drawable value, int saveTime) { | |
| 516 | + put(key, Utils.drawable2Bitmap(value), saveTime); | |
| 517 | + } | |
| 518 | + | |
| 519 | + /** | |
| 520 | + * 读取 Drawable 数据 | |
| 521 | + * | |
| 522 | + * @param key | |
| 523 | + * @return Drawable 数据 | |
| 524 | + */ | |
| 525 | + public Drawable getAsDrawable(String key) { | |
| 526 | + if (getAsBinary(key) == null) { | |
| 527 | + return null; | |
| 528 | + } | |
| 529 | + return Utils.bitmap2Drawable(Utils.Bytes2Bimap(getAsBinary(key))); | |
| 530 | + } | |
| 531 | + | |
| 532 | + /** | |
| 533 | + * 获取缓存文件 | |
| 534 | + * | |
| 535 | + * @param key | |
| 536 | + * @return value 缓存的文件 | |
| 537 | + */ | |
| 538 | + public File file(String key) { | |
| 539 | + File f = mCache.newFile(key); | |
| 540 | + if (f.exists()) | |
| 541 | + return f; | |
| 542 | + return null; | |
| 543 | + } | |
| 544 | + | |
| 545 | + /** | |
| 546 | + * 移除某个key | |
| 547 | + * | |
| 548 | + * @param key | |
| 549 | + * @return 是否移除成功 | |
| 550 | + */ | |
| 551 | + public boolean remove(String key) { | |
| 552 | + return mCache.remove(key); | |
| 553 | + } | |
| 554 | + | |
| 555 | + /** | |
| 556 | + * 清除所有数据 | |
| 557 | + */ | |
| 558 | + public void clear() { | |
| 559 | + mCache.clear(); | |
| 560 | + } | |
| 561 | + | |
| 562 | + /** | |
| 563 | + * @title 缓存管理器 | |
| 564 | + * @author 杨福海(michael) www.yangfuhai.com | |
| 565 | + * @version 1.0 | |
| 566 | + */ | |
| 567 | + public class ACacheManager { | |
| 568 | + private final AtomicLong cacheSize; | |
| 569 | + private final AtomicInteger cacheCount; | |
| 570 | + private final long sizeLimit; | |
| 571 | + private final int countLimit; | |
| 572 | + private final Map<File, Long> lastUsageDates = Collections | |
| 573 | + .synchronizedMap(new HashMap<File, Long>()); | |
| 574 | + protected File cacheDir; | |
| 575 | + | |
| 576 | + private ACacheManager(File cacheDir, long sizeLimit, int countLimit) { | |
| 577 | + this.cacheDir = cacheDir; | |
| 578 | + this.sizeLimit = sizeLimit; | |
| 579 | + this.countLimit = countLimit; | |
| 580 | + cacheSize = new AtomicLong(); | |
| 581 | + cacheCount = new AtomicInteger(); | |
| 582 | + calculateCacheSizeAndCacheCount(); | |
| 583 | + } | |
| 584 | + | |
| 585 | + /** | |
| 586 | + * 计算 cacheSize和cacheCount | |
| 587 | + */ | |
| 588 | + private void calculateCacheSizeAndCacheCount() { | |
| 589 | + new Thread(new Runnable() { | |
| 590 | + @Override | |
| 591 | + public void run() { | |
| 592 | + int size = 0; | |
| 593 | + int count = 0; | |
| 594 | + File[] cachedFiles = cacheDir.listFiles(); | |
| 595 | + if (cachedFiles != null) { | |
| 596 | + for (File cachedFile : cachedFiles) { | |
| 597 | + size += calculateSize(cachedFile); | |
| 598 | + count += 1; | |
| 599 | + lastUsageDates.put(cachedFile, | |
| 600 | + cachedFile.lastModified()); | |
| 601 | + } | |
| 602 | + cacheSize.set(size); | |
| 603 | + cacheCount.set(count); | |
| 604 | + } | |
| 605 | + } | |
| 606 | + }).start(); | |
| 607 | + } | |
| 608 | + | |
| 609 | + private void put(File file) { | |
| 610 | + int curCacheCount = cacheCount.get(); | |
| 611 | + while (curCacheCount + 1 > countLimit) { | |
| 612 | + long freedSize = removeNext(); | |
| 613 | + cacheSize.addAndGet(-freedSize); | |
| 614 | + | |
| 615 | + curCacheCount = cacheCount.addAndGet(-1); | |
| 616 | + } | |
| 617 | + cacheCount.addAndGet(1); | |
| 618 | + | |
| 619 | + long valueSize = calculateSize(file); | |
| 620 | + long curCacheSize = cacheSize.get(); | |
| 621 | + while (curCacheSize + valueSize > sizeLimit) { | |
| 622 | + long freedSize = removeNext(); | |
| 623 | + curCacheSize = cacheSize.addAndGet(-freedSize); | |
| 624 | + } | |
| 625 | + cacheSize.addAndGet(valueSize); | |
| 626 | + | |
| 627 | + Long currentTime = System.currentTimeMillis(); | |
| 628 | + file.setLastModified(currentTime); | |
| 629 | + lastUsageDates.put(file, currentTime); | |
| 630 | + } | |
| 631 | + | |
| 632 | + private File get(String key) { | |
| 633 | + File file = newFile(key); | |
| 634 | + Long currentTime = System.currentTimeMillis(); | |
| 635 | + file.setLastModified(currentTime); | |
| 636 | + lastUsageDates.put(file, currentTime); | |
| 637 | + | |
| 638 | + return file; | |
| 639 | + } | |
| 640 | + | |
| 641 | + private File newFile(String key) { | |
| 642 | + return new File(cacheDir, key.hashCode() + ""); | |
| 643 | + } | |
| 644 | + | |
| 645 | + private boolean remove(String key) { | |
| 646 | + File image = get(key); | |
| 647 | + return image.delete(); | |
| 648 | + } | |
| 649 | + | |
| 650 | + private void clear() { | |
| 651 | + lastUsageDates.clear(); | |
| 652 | + cacheSize.set(0); | |
| 653 | + File[] files = cacheDir.listFiles(); | |
| 654 | + if (files != null) { | |
| 655 | + for (File f : files) { | |
| 656 | + f.delete(); | |
| 657 | + } | |
| 658 | + } | |
| 659 | + } | |
| 660 | + | |
| 661 | + /** | |
| 662 | + * 移除旧的文件 | |
| 663 | + * | |
| 664 | + * @return | |
| 665 | + */ | |
| 666 | + private long removeNext() { | |
| 667 | + if (lastUsageDates.isEmpty()) { | |
| 668 | + return 0; | |
| 669 | + } | |
| 670 | + | |
| 671 | + Long oldestUsage = null; | |
| 672 | + File mostLongUsedFile = null; | |
| 673 | + Set<Entry<File, Long>> entries = lastUsageDates.entrySet(); | |
| 674 | + synchronized (lastUsageDates) { | |
| 675 | + for (Entry<File, Long> entry : entries) { | |
| 676 | + if (mostLongUsedFile == null) { | |
| 677 | + mostLongUsedFile = entry.getKey(); | |
| 678 | + oldestUsage = entry.getValue(); | |
| 679 | + } else { | |
| 680 | + Long lastValueUsage = entry.getValue(); | |
| 681 | + if (lastValueUsage < oldestUsage) { | |
| 682 | + oldestUsage = lastValueUsage; | |
| 683 | + mostLongUsedFile = entry.getKey(); | |
| 684 | + } | |
| 685 | + } | |
| 686 | + } | |
| 687 | + } | |
| 688 | + | |
| 689 | + long fileSize = calculateSize(mostLongUsedFile); | |
| 690 | + if (mostLongUsedFile.delete()) { | |
| 691 | + lastUsageDates.remove(mostLongUsedFile); | |
| 692 | + } | |
| 693 | + return fileSize; | |
| 694 | + } | |
| 695 | + | |
| 696 | + private long calculateSize(File file) { | |
| 697 | + return file.length(); | |
| 698 | + } | |
| 699 | + } | |
| 700 | + | |
| 701 | + /** | |
| 702 | + * @title 时间计算工具类 | |
| 703 | + * @author 杨福海(michael) www.yangfuhai.com | |
| 704 | + * @version 1.0 | |
| 705 | + */ | |
| 706 | + private static class Utils { | |
| 707 | + | |
| 708 | + /** | |
| 709 | + * 判断缓存的String数据是否到期 | |
| 710 | + * | |
| 711 | + * @param str | |
| 712 | + * @return true:到期了 false:还没有到期 | |
| 713 | + */ | |
| 714 | + private static boolean isDue(String str) { | |
| 715 | + return isDue(str.getBytes()); | |
| 716 | + } | |
| 717 | + | |
| 718 | + /** | |
| 719 | + * 判断缓存的byte数据是否到期 | |
| 720 | + * | |
| 721 | + * @param data | |
| 722 | + * @return true:到期了 false:还没有到期 | |
| 723 | + */ | |
| 724 | + private static boolean isDue(byte[] data) { | |
| 725 | + String[] strs = getDateInfoFromDate(data); | |
| 726 | + if (strs != null && strs.length == 2) { | |
| 727 | + String saveTimeStr = strs[0]; | |
| 728 | + while (saveTimeStr.startsWith("0")) { | |
| 729 | + saveTimeStr = saveTimeStr | |
| 730 | + .substring(1, saveTimeStr.length()); | |
| 731 | + } | |
| 732 | + long saveTime = Long.valueOf(saveTimeStr); | |
| 733 | + long deleteAfter = Long.valueOf(strs[1]); | |
| 734 | + if (System.currentTimeMillis() > saveTime + deleteAfter * 1000) { | |
| 735 | + return true; | |
| 736 | + } | |
| 737 | + } | |
| 738 | + return false; | |
| 739 | + } | |
| 740 | + | |
| 741 | + private static String newStringWithDateInfo(int second, String strInfo) { | |
| 742 | + return createDateInfo(second) + strInfo; | |
| 743 | + } | |
| 744 | + | |
| 745 | + private static byte[] newByteArrayWithDateInfo(int second, byte[] data2) { | |
| 746 | + byte[] data1 = createDateInfo(second).getBytes(); | |
| 747 | + byte[] retdata = new byte[data1.length + data2.length]; | |
| 748 | + System.arraycopy(data1, 0, retdata, 0, data1.length); | |
| 749 | + System.arraycopy(data2, 0, retdata, data1.length, data2.length); | |
| 750 | + return retdata; | |
| 751 | + } | |
| 752 | + | |
| 753 | + private static String clearDateInfo(String strInfo) { | |
| 754 | + if (strInfo != null && hasDateInfo(strInfo.getBytes())) { | |
| 755 | + strInfo = strInfo.substring(strInfo.indexOf(mSeparator) + 1, | |
| 756 | + strInfo.length()); | |
| 757 | + } | |
| 758 | + return strInfo; | |
| 759 | + } | |
| 760 | + | |
| 761 | + private static byte[] clearDateInfo(byte[] data) { | |
| 762 | + if (hasDateInfo(data)) { | |
| 763 | + return copyOfRange(data, indexOf(data, mSeparator) + 1, | |
| 764 | + data.length); | |
| 765 | + } | |
| 766 | + return data; | |
| 767 | + } | |
| 768 | + | |
| 769 | + private static boolean hasDateInfo(byte[] data) { | |
| 770 | + return data != null && data.length > 15 && data[13] == '-' | |
| 771 | + && indexOf(data, mSeparator) > 14; | |
| 772 | + } | |
| 773 | + | |
| 774 | + private static String[] getDateInfoFromDate(byte[] data) { | |
| 775 | + if (hasDateInfo(data)) { | |
| 776 | + String saveDate = new String(copyOfRange(data, 0, 13)); | |
| 777 | + String deleteAfter = new String(copyOfRange(data, 14, | |
| 778 | + indexOf(data, mSeparator))); | |
| 779 | + return new String[] { saveDate, deleteAfter }; | |
| 780 | + } | |
| 781 | + return null; | |
| 782 | + } | |
| 783 | + | |
| 784 | + private static int indexOf(byte[] data, char c) { | |
| 785 | + for (int i = 0; i < data.length; i++) { | |
| 786 | + if (data[i] == c) { | |
| 787 | + return i; | |
| 788 | + } | |
| 789 | + } | |
| 790 | + return -1; | |
| 791 | + } | |
| 792 | + | |
| 793 | + private static byte[] copyOfRange(byte[] original, int from, int to) { | |
| 794 | + int newLength = to - from; | |
| 795 | + if (newLength < 0) | |
| 796 | + throw new IllegalArgumentException(from + " > " + to); | |
| 797 | + byte[] copy = new byte[newLength]; | |
| 798 | + System.arraycopy(original, from, copy, 0, | |
| 799 | + Math.min(original.length - from, newLength)); | |
| 800 | + return copy; | |
| 801 | + } | |
| 802 | + | |
| 803 | + private static final char mSeparator = ' '; | |
| 804 | + | |
| 805 | + private static String createDateInfo(int second) { | |
| 806 | + String currentTime = System.currentTimeMillis() + ""; | |
| 807 | + while (currentTime.length() < 13) { | |
| 808 | + currentTime = "0" + currentTime; | |
| 809 | + } | |
| 810 | + return currentTime + "-" + second + mSeparator; | |
| 811 | + } | |
| 812 | + | |
| 813 | + /* | |
| 814 | + * Bitmap → byte[] | |
| 815 | + */ | |
| 816 | + private static byte[] Bitmap2Bytes(Bitmap bm) { | |
| 817 | + if (bm == null) { | |
| 818 | + return null; | |
| 819 | + } | |
| 820 | + ByteArrayOutputStream baos = new ByteArrayOutputStream(); | |
| 821 | + bm.compress(Bitmap.CompressFormat.PNG, 100, baos); | |
| 822 | + return baos.toByteArray(); | |
| 823 | + } | |
| 824 | + | |
| 825 | + /* | |
| 826 | + * byte[] → Bitmap | |
| 827 | + */ | |
| 828 | + private static Bitmap Bytes2Bimap(byte[] b) { | |
| 829 | + if (b.length == 0) { | |
| 830 | + return null; | |
| 831 | + } | |
| 832 | + return BitmapFactory.decodeByteArray(b, 0, b.length); | |
| 833 | + } | |
| 834 | + | |
| 835 | + /* | |
| 836 | + * Drawable → Bitmap | |
| 837 | + */ | |
| 838 | + private static Bitmap drawable2Bitmap(Drawable drawable) { | |
| 839 | + if (drawable == null) { | |
| 840 | + return null; | |
| 841 | + } | |
| 842 | + // 取 drawable 的长宽 | |
| 843 | + int w = drawable.getIntrinsicWidth(); | |
| 844 | + int h = drawable.getIntrinsicHeight(); | |
| 845 | + // 取 drawable 的颜色格式 | |
| 846 | + Bitmap.Config config = drawable.getOpacity() != PixelFormat.OPAQUE ? Bitmap.Config.ARGB_8888 | |
| 847 | + : Bitmap.Config.RGB_565; | |
| 848 | + // 建立对应 bitmap | |
| 849 | + Bitmap bitmap = Bitmap.createBitmap(w, h, config); | |
| 850 | + // 建立对应 bitmap 的画布 | |
| 851 | + Canvas canvas = new Canvas(bitmap); | |
| 852 | + drawable.setBounds(0, 0, w, h); | |
| 853 | + // 把 drawable 内容画到画布中 | |
| 854 | + drawable.draw(canvas); | |
| 855 | + return bitmap; | |
| 856 | + } | |
| 857 | + | |
| 858 | + /* | |
| 859 | + * Bitmap → Drawable | |
| 860 | + */ | |
| 861 | + @SuppressWarnings("deprecation") | |
| 862 | + private static Drawable bitmap2Drawable(Bitmap bm) { | |
| 863 | + if (bm == null) { | |
| 864 | + return null; | |
| 865 | + } | |
| 866 | + return new BitmapDrawable(bm); | |
| 867 | + } | |
| 868 | + } | |
| 869 | + | |
| 870 | +} | |
| \ No newline at end of file | ... | ... |
Please
register
or
login
to post a comment