master
lijie 2023-08-07 11:46:02 +08:00
parent 05a7d6bdff
commit 9d36282b14
23 changed files with 664 additions and 1165 deletions

View File

@ -0,0 +1,17 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="deploymentTargetDropDown">
<runningDeviceTargetSelectedWithDropDown>
<Target>
<type value="RUNNING_DEVICE_TARGET" />
<deviceKey>
<Key>
<type value="SERIAL_NUMBER" />
<value value="R5CT20CJY5V" />
</Key>
</deviceKey>
</Target>
</runningDeviceTargetSelectedWithDropDown>
<timeTargetWasSelectedWithDropDown value="2023-08-07T03:40:58.879605600Z" />
</component>
</project>

View File

@ -1,75 +1,76 @@
package com.cmx.hydrology.activity;
package com.cmx.hydrology.activity
import android.os.Bundle;
import android.webkit.WebResourceError;
import android.webkit.WebResourceRequest;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.graphics.Bitmap
import android.os.Bundle
import android.webkit.WebResourceError
import android.webkit.WebResourceRequest
import android.webkit.WebSettings
import android.webkit.WebView
import android.webkit.WebViewClient
import androidx.appcompat.app.AppCompatActivity
import com.cmx.hydrology.utils.AndroidtoJs
import com.cmx.hydrology.view.BaseLoadingDialog
import com.lsxiao.apollo.core.Apollo
import com.lsxiao.apollo.core.contract.ApolloBinder
import androidx.appcompat.app.AppCompatActivity;
import com.cmx.hydrology.view.BaseLoadingDialog;
import com.lsxiao.apollo.core.Apollo;
import com.lsxiao.apollo.core.contract.ApolloBinder;
public class BaseActivity extends AppCompatActivity {
private static final String TAG = "BaseActivity";
private BaseLoadingDialog mBaseLoadingDialog;
private ApolloBinder mApolloBinder;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mBaseLoadingDialog = new BaseLoadingDialog(this);
mApolloBinder = Apollo.bind(this);
open class BaseActivity : AppCompatActivity() {
private var mBaseLoadingDialog: BaseLoadingDialog? = null
private var mApolloBinder: ApolloBinder? = null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
mBaseLoadingDialog = BaseLoadingDialog(this)
mApolloBinder = Apollo.bind(this)
}
public void showDialog() {
if (!mBaseLoadingDialog.isShowing()) {
mBaseLoadingDialog.show();
fun showDialog() {
if (!mBaseLoadingDialog!!.isShowing) {
mBaseLoadingDialog!!.show()
}
}
public void disDialog() {
if (mBaseLoadingDialog.isShowing()) {
mBaseLoadingDialog.dismiss();
fun disDialog() {
if (mBaseLoadingDialog!!.isShowing) {
mBaseLoadingDialog!!.dismiss()
}
}
public void setWeb(WebView mWebView) {
mWebView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
//使用WebView加载显示url
view.loadUrl(url);
//返回true
return true;
}
fun setWeb(mWebView: WebView) {
val webSettings = mWebView!!.settings
webSettings.javaScriptEnabled = true
webSettings.cacheMode = WebSettings.LOAD_NO_CACHE
webSettings.domStorageEnabled = true
mWebView!!.addJavascriptInterface(AndroidtoJs(), "AndroidtoJs")
mWebView.webViewClient = object : WebViewClient() {
override fun onPageStarted(view: WebView?, url: String?, favicon: Bitmap?) {
super.onPageStarted(view, url, favicon)
showDialog()
}
@Override
public void onPageFinished(WebView view, String url) {
disDialog();
}
override fun shouldOverrideUrlLoading(view: WebView, url: String): Boolean {
//使用WebView加载显示url
view.loadUrl(url)
//返回true
return true
}
@Override
public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) {
disDialog();
}
}
override fun onPageFinished(view: WebView, url: String) {
disDialog()
}
);
override fun onReceivedError(view: WebView, request: WebResourceRequest, error: WebResourceError) {
disDialog()
}
}
}
@Override
protected void onDestroy() {
super.onDestroy();
override fun onDestroy() {
super.onDestroy()
if (mApolloBinder != null) {
mApolloBinder.unbind();
mApolloBinder!!.unbind()
}
}
companion object {
private const val TAG = "BaseActivity"
}
}

View File

@ -60,8 +60,8 @@ class LoginActivity : BaseActivity() {
LoginBean.username = binding!!.edtUsername.text.toString().trim { it <= ' ' }
LoginBean.password = binding!!.edtPassword.text.toString().trim { it <= ' ' }
val call = RetrofitAPIManager.provideClientApi().login(LoginBean)
call.enqueue(object : Callback<LoginRes> {
override fun onResponse(call: Call<LoginRes>, response: Response<LoginRes>) {
call!!.enqueue(object : Callback<LoginRes?> {
override fun onResponse(call: Call<LoginRes?>, response: Response<LoginRes?>) {
disDialog()
if (response.isSuccessful && response.body()!!.code == 0) {
SpUtils.putString(this@LoginActivity, "token", response.body()!!.access_token)
@ -69,11 +69,11 @@ class LoginActivity : BaseActivity() {
startActivity(intent)
finish()
} else {
Toasty.error(this@LoginActivity, response.body()!!.message).show()
Toasty.error(this@LoginActivity, response.body()!!.message!!).show()
}
}
override fun onFailure(call: Call<LoginRes>, t: Throwable) {
override fun onFailure(call: Call<LoginRes?>, t: Throwable) {
disDialog()
Toasty.info(this@LoginActivity, "登录失败").show()
}

View File

@ -1,40 +1,35 @@
package com.cmx.hydrology.activity;
package com.cmx.hydrology.activity
import android.app.Application;
import android.content.Context;
import android.app.Application
import android.content.Context
import com.lsxiao.apollo.core.Apollo
import io.reactivex.android.schedulers.AndroidSchedulers
import com.lsxiao.apollo.core.Apollo;
import io.reactivex.android.schedulers.AndroidSchedulers;
public class MyApplication extends Application {
private static MyApplication mInstance;
private static String mToken;
@Override
public void onCreate() {
super.onCreate();
mInstance = this;
Apollo.init(AndroidSchedulers.mainThread(), this);
class MyApplication : Application() {
override fun onCreate() {
super.onCreate()
mInstance = this
Apollo.init(AndroidSchedulers.mainThread(), this)
}
@Override
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
override fun attachBaseContext(base: Context) {
super.attachBaseContext(base)
}
companion object {
private var mInstance: MyApplication? = null
private var mToken: String? = null
@JvmStatic
fun getmInstance(): MyApplication? {
return mInstance
}
public static MyApplication getmInstance() {
return mInstance;
}
fun getmToken(): String? {
return mToken
}
public static String getmToken() {
return mToken;
fun setmToken(mToken: String?) {
Companion.mToken = mToken
}
}
public static void setmToken(String mToken) {
MyApplication.mToken = mToken;
}
}
}

View File

@ -1,179 +1,50 @@
package com.cmx.hydrology.activity;
package com.cmx.hydrology.activity
import android.app.Activity;
import android.content.ClipData;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.util.Log;
import android.webkit.ValueCallback;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.content.ClipData
import android.content.Intent
import android.net.Uri
import android.os.Bundle
import android.os.Environment
import android.provider.MediaStore
import android.util.Log
import android.webkit.ValueCallback
import android.webkit.WebChromeClient
import android.webkit.WebSettings
import android.webkit.WebView
import com.cmx.hydrology.constant.Events
import com.cmx.hydrology.databinding.ActivityWebBinding
import com.cmx.hydrology.utils.AndroidtoJs
import com.cmx.hydrology.utils.L
import com.lsxiao.apollo.core.annotations.Receive
import java.io.File
import java.io.IOException
import java.text.SimpleDateFormat
import java.util.Date
import androidx.annotation.Nullable;
class WebActivity : BaseActivity() {
private var mWebView: WebView? = null
private var binding: ActivityWebBinding? = null
private var url: String? = null
private var mUploadMessage: ValueCallback<Array<Uri>>? = null
private var mCameraPhotoPath: String? = null
private var size: Long = 0
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
binding = ActivityWebBinding.inflate(layoutInflater)
setContentView(binding!!.root)
url = intent.getStringExtra("url")
mWebView = binding!!.wvRegister
setWeb(mWebView!!)
mWebView!!.loadUrl(url!!)
}
import com.cmx.hydrology.databinding.ActivityWebBinding;
import com.cmx.hydrology.utils.AndroidtoJs;
import com.cmx.hydrology.utils.L;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class WebActivity extends BaseActivity {
private WebView mWebView;
private ActivityWebBinding binding;
private String url;
public static final int REQUEST_CODE_LIVENESS = 209;
public static final int TRUST_LEVEL = 50;
private ValueCallback<Uri[]> mUploadMessage;
private String mCameraPhotoPath = null;
private long size = 0;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
binding = ActivityWebBinding.inflate(getLayoutInflater());
setContentView(binding.getRoot());
url = getIntent().getStringExtra("url");
// MyUtils.setFullscreen(this, true, true);//影响键盘 模式 页面遮挡
// MyUtils.setAndroidNativeLightStatusBar(this, true);//影响键盘 模式 页面遮挡
mWebView = binding.wvRegister;
WebSettings webSettings = mWebView.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
webSettings.setDomStorageEnabled(true);
mWebView.addJavascriptInterface(new AndroidtoJs(), "AndroidtoJs");
mWebView.loadUrl(url);
showDialog();
setWeb(mWebView);
mWebView.setWebChromeClient(new PQChromeClient());
@Receive(Events.JS_OPEN_CLOSE_WEB)
fun fin() {
finish();
}
// @Receive(Events.JS_OPEN_CLOSE_WEB)
// public void fin() {
// finish();
// }
companion object {
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == 101 && mUploadMessage != null) {
try {
String file_path = mCameraPhotoPath.replace("file:", "");
File file = new File(file_path);
size = file.length();
if (!(data != null || size > 0)) {
mUploadMessage.onReceiveValue(null);
mUploadMessage = null;
return;
}
if (data != null || mCameraPhotoPath != null) {
Integer count = 1;
ClipData images = null;
try {
images = data.getClipData();
} catch (Exception e) {
Log.e("Error11!", e.getLocalizedMessage());
}
if (images == null && data != null && data.getDataString() != null) {
count = data.getDataString().length();
} else if (images != null) {
count = images.getItemCount();
}
Uri[] results = new Uri[count];
// Check that the response is a good one
if (resultCode == Activity.RESULT_OK) {
if (size != 0) {
// If there is not data, then we may have taken a photo
if (mCameraPhotoPath != null) {
results = new Uri[]{Uri.parse(mCameraPhotoPath)};
}
} else if (data.getClipData() == null) {
results = new Uri[]{Uri.parse(data.getDataString())};
} else {
for (int i = 0; i < images.getItemCount(); i++) {
results[i] = images.getItemAt(i).getUri();
}
}
}
mUploadMessage.onReceiveValue(results);
mUploadMessage = null;
}
} catch (Exception e) {
Log.e("Error22!", "Error while opening image file" + e.getLocalizedMessage());
}
}
}
public class PQChromeClient extends WebChromeClient {
// For Android 5.0+
public boolean onShowFileChooser(WebView view, ValueCallback<Uri[]> filePath, WebChromeClient.FileChooserParams fileChooserParams) {
L.e("点击》》", "11");
// Double check that we don't have any existing callbacks
if (mUploadMessage != null) {
L.e("点击》》", "22");
mUploadMessage.onReceiveValue(null);
}
mUploadMessage = filePath;
Log.e("FileCooserParams => ", filePath.toString());
Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
// Create the File where the photo should go
File photoFile = null;
try {
photoFile = createImageFile();
takePictureIntent.putExtra("PhotoPath", mCameraPhotoPath);
} catch (IOException ex) {
// Error occurred while creating the File
Log.e("test", "Unable to create Image File", ex);
}
// Continue only if the File was successfully created
if (photoFile != null) {
mCameraPhotoPath = "file:" + photoFile.getAbsolutePath();
takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(photoFile));
} else {
takePictureIntent = null;
}
}
Intent contentSelectionIntent = new Intent(Intent.ACTION_GET_CONTENT);
contentSelectionIntent.addCategory(Intent.CATEGORY_OPENABLE);
contentSelectionIntent.putExtra(Intent.EXTRA_ALLOW_MULTIPLE, true);
contentSelectionIntent.setType("image/*");
Intent[] intentArray;
if (takePictureIntent != null) {
intentArray = new Intent[]{takePictureIntent};
} else {
intentArray = new Intent[2];
}
Intent chooserIntent = new Intent(Intent.ACTION_CHOOSER);
chooserIntent.putExtra(Intent.EXTRA_INTENT, contentSelectionIntent);
chooserIntent.putExtra(Intent.EXTRA_TITLE, "Image Chooser");
chooserIntent.putExtra(Intent.EXTRA_INITIAL_INTENTS, intentArray);
startActivityForResult(Intent.createChooser(chooserIntent, "Select images"), 101);
return true;
}
}
private File createImageFile() throws IOException {
// Create an image file name
String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
String imageFileName = "JPEG_" + timeStamp + "_";
File storageDir = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES);
File imageFile = File.createTempFile(imageFileName, /* prefix */
".jpg", /* suffix */
storageDir /* directory */);
return imageFile;
}
}

View File

@ -1,22 +1,6 @@
package com.cmx.hydrology.model;
package com.cmx.hydrology.model
public class LoginBean {
String username;
String password;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
class LoginBean {
var username: String? = null
var password: String? = null
}

View File

@ -1,42 +1,12 @@
package com.cmx.hydrology.model;
public class LoginRes {
package com.cmx.hydrology.model
class LoginRes {
/**
* code : 0
* message : 登录成功
* access_token : 1914936f8c87fddd11836ebebb65317bb7f57506
*/
private int code;
private String message;
private String access_token;
public int getCode() {
return code;
}
public void setCode(int code) {
this.code = code;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
public String getAccess_token() {
return access_token;
}
public void setAccess_token(String access_token) {
this.access_token = access_token;
}
}
var code = 0
var message: String? = null
var access_token: String? = null
}

View File

@ -1,47 +1,42 @@
package com.cmx.hydrology.retrofit;
package com.cmx.hydrology.retrofit
import com.google.gson.reflect.TypeToken;
import com.google.gson.reflect.TypeToken
import okhttp3.ResponseBody
import org.json.JSONException
import org.json.JSONObject
import retrofit2.Call
import retrofit2.Callback
import retrofit2.Response
import java.io.IOException
import org.json.JSONException;
import org.json.JSONObject;
import java.io.IOException;
import okhttp3.ResponseBody;
import retrofit2.Call;
import retrofit2.Callback;
public class ApiRequtest<T> {
private static final String TAG = ApiRequtest.class.getSimpleName();
private TypeToken<T> mResultType;
public ApiRequtest (Call<ResponseBody> call, TypeToken<T> resultType, final ApiResponse.Listener<ApiResult<T>> listener, final ApiResponse.ErrorListener errorListener){
mResultType = resultType;
call.enqueue(new Callback<ResponseBody>() {
@Override
public void onResponse(Call<ResponseBody> call, retrofit2.Response<ResponseBody> response) {
class ApiRequtest<T>(
call: Call<ResponseBody?>,
private val mResultType: TypeToken<T>,
listener: ApiResponse.Listener<ApiResult<T>?>,
errorListener: ApiResponse.ErrorListener
) {
init {
call.enqueue(object : Callback<ResponseBody?> {
override fun onResponse(call: Call<ResponseBody?>, response: Response<ResponseBody?>) {
try {
ResponseBody responseBody = response.body();
if(responseBody != null){
String jsonString = response.body().string();
final ApiResult<T> result = new ApiResult<>(new JSONObject(jsonString), mResultType);
listener.onResponse(result);
val responseBody = response.body()
if (responseBody != null) {
val jsonString = response.body()!!.string()
val result = ApiResult(JSONObject(jsonString), mResultType)
listener.onResponse(result)
}
}catch (IOException e){
}catch (JSONException e) {
} catch (e: IOException) {
} catch (e: JSONException) {
}
}
@Override
public void onFailure(Call<ResponseBody> call, Throwable t) {
errorListener.onErrorResponse(t);
override fun onFailure(call: Call<ResponseBody?>, t: Throwable) {
errorListener.onErrorResponse(t)
}
});
})
}
}
companion object {
private val TAG = ApiRequtest::class.java.simpleName
}
}

View File

@ -1,19 +1,18 @@
package com.cmx.hydrology.retrofit;
public class ApiResponse<T> {
package com.cmx.hydrology.retrofit
class ApiResponse<T> {
/**
* network request error response
*/
public interface ErrorListener {
void onErrorResponse(Throwable requestError);
interface ErrorListener {
fun onErrorResponse(requestError: Throwable?)
}
/**
* network request success response result
* @param <T> data result
*/
public interface Listener<T> {
void onResponse(T result);
</T> */
interface Listener<T> {
fun onResponse(result: T)
}
}
}

View File

@ -1,104 +1,65 @@
package com.cmx.hydrology.retrofit;
import com.google.gson.Gson;
import com.google.gson.reflect.TypeToken;
import org.json.JSONObject;
package com.cmx.hydrology.retrofit
import com.google.gson.Gson
import com.google.gson.reflect.TypeToken
import org.json.JSONObject
/**
*
*/
public class ApiResult<T> {
class ApiResult<T> {
var success = true
var code = OK
var msg = ""
var result: T? = null
private set
val msgJson: String? = null
private final static String TAG = ApiResult.class.getSimpleName();
public static final int OK = 0;
public Boolean success = true;
private Integer code = OK;
private String msg="";
private T result;
private String msgJson;
private static Gson gson = new Gson();
public ApiResult() {
super();
// TODO Auto-generated constructor stub
constructor() : super() { // TODO Auto-generated constructor stub
}
public ApiResult(JSONObject jsonObject, TypeToken<T> typeToken) {
super();
try{
if (jsonObject.has("errcode")){
code = jsonObject.getInt("errcode");
constructor(jsonObject: JSONObject, typeToken: TypeToken<T>) : super() {
try {
if (jsonObject.has("errcode")) {
code = jsonObject.getInt("errcode")
if (code != OK) {
if (jsonObject.has("errmsg")) {
msg = jsonObject.getString("errmsg");
msg = jsonObject.getString("errmsg")
}
success = false;
success = false
}
}else{
} else {
}
if (code == OK){
if (code == OK) {
try {
result = gson.fromJson(jsonObject.toString(), typeToken.getType());
}catch (Exception ex){
result = gson.fromJson(jsonObject.toString(), typeToken.type)
} catch (ex: Exception) {
}
}
}catch (Exception e) {
} catch (e: Exception) {
// TODO: handle exception
}
}
private T testDefault(String msg){
Gson gson = new Gson();
result = gson.fromJson(msg,new TypeToken<T>(){}.getType());
return result;
}
private T test(String msg, TypeToken<T> typeToken){
Gson gson = new Gson();
result = gson.fromJson(msg,typeToken.getType());
return result;
}
public Integer getCode() {
return code;
}
public void setCode(Integer code) {
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
private fun testDefault(msg: String): T? {
val gson = Gson()
result = gson.fromJson(msg, object : TypeToken<T>() {}.type)
return result
}
public T getResult() {
return result;
private fun test(msg: String, typeToken: TypeToken<T>): T? {
val gson = Gson()
result = gson.fromJson(msg, typeToken.type)
return result
}
public void setResult(T result) {
this.result = result;
fun setResult(result: T) {
this.result = result
}
public Boolean getSuccess() {
return success;
companion object {
private val TAG = ApiResult::class.java.simpleName
const val OK = 0
private val gson = Gson()
}
public void setSuccess(Boolean success) {
this.success = success;
}
public String getMsgJson() {
return msgJson;
}
}
}

View File

@ -1,16 +1,15 @@
package com.cmx.hydrology.retrofit;
package com.cmx.hydrology.retrofit
import com.cmx.hydrology.model.LoginBean;
import com.cmx.hydrology.model.LoginRes;
import retrofit2.Call;
import retrofit2.http.Body;
import retrofit2.http.POST;
import com.cmx.hydrology.model.LoginBean
import com.cmx.hydrology.model.LoginRes
import retrofit2.Call
import retrofit2.http.Body
import retrofit2.http.POST
/**
* Created by
*/
public interface ApiService {
interface ApiService {
/**
* 登录
*
@ -18,5 +17,5 @@ public interface ApiService {
* @return
*/
@POST("/login")
Call<LoginRes> login(@Body LoginBean body);
}
fun login(@Body body: LoginBean?): Call<LoginRes?>?
}

View File

@ -1,71 +1,55 @@
package com.cmx.hydrology.retrofit;
package com.cmx.hydrology.retrofit
import static com.cmx.hydrology.constant.Events.SERVER_URL;
import android.util.Log;
import com.cmx.hydrology.activity.MyApplication;
import com.cmx.hydrology.utils.SpUtils;
import com.google.gson.reflect.TypeToken;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.util.concurrent.TimeUnit;
import okhttp3.Interceptor;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import okhttp3.ResponseBody;
import okhttp3.logging.HttpLoggingInterceptor;
import retrofit2.Call;
import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;
import android.util.Log
import com.cmx.hydrology.activity.MyApplication.Companion.getmInstance
import com.cmx.hydrology.constant.Events
import com.cmx.hydrology.utils.SpUtils
import com.google.gson.reflect.TypeToken
import okhttp3.OkHttpClient
import okhttp3.ResponseBody
import okhttp3.logging.HttpLoggingInterceptor
import retrofit2.Call
import retrofit2.Retrofit
import retrofit2.converter.gson.GsonConverterFactory
import java.util.concurrent.TimeUnit
/**
* Created by TTLock on 2018/9/5.
*/
public class RetrofitAPIManager {
public static ApiService provideClientApi() {
Retrofit retrofit = new Retrofit.Builder().client(genericClient()).baseUrl(SERVER_URL).addConverterFactory(GsonConverterFactory.create()).build();
return retrofit.create(ApiService.class);
object RetrofitAPIManager {
fun provideClientApi(): ApiService {
val retrofit = Retrofit.Builder().client(genericClient()).baseUrl(Events.SERVER_URL)
.addConverterFactory(GsonConverterFactory.create()).build()
return retrofit.create(ApiService::class.java)
}
public static OkHttpClient genericClient() {
HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor(new HttpLoggingInterceptor.Logger() {
@Override
public void log(String message) {
// try {
// String text = URLDecoder.decode(message, "utf-8");
// Log.e("OKHttp-----", text);
// } catch (UnsupportedEncodingException e) {
// e.printStackTrace();
Log.e("OKHttp-----", message);
// }
}
});
interceptor.setLevel(HttpLoggingInterceptor.Level.BODY);
OkHttpClient httpClient = new OkHttpClient.Builder().connectTimeout(35, TimeUnit.SECONDS).readTimeout(35, TimeUnit.SECONDS).writeTimeout(35, TimeUnit.SECONDS).addInterceptor(interceptor).addInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
Request original = chain.request();
Request.Builder requestBuilder = original.newBuilder().header("token", SpUtils.getString(MyApplication.getmInstance(), "token"));
Request request = requestBuilder.build();
return chain.proceed(request);
}
}).build();
return httpClient;
fun genericClient(): OkHttpClient {
val interceptor = HttpLoggingInterceptor { message ->
// try {
// String text = URLDecoder.decode(message, "utf-8");
// Log.e("OKHttp-----", text);
// } catch (UnsupportedEncodingException e) {
// e.printStackTrace();
Log.e("OKHttp-----", message)
// }
}
interceptor.level = HttpLoggingInterceptor.Level.BODY
return OkHttpClient.Builder().connectTimeout(35, TimeUnit.SECONDS).readTimeout(35, TimeUnit.SECONDS)
.writeTimeout(35, TimeUnit.SECONDS).addInterceptor(interceptor).addInterceptor { chain ->
val original = chain.request()
val requestBuilder =
original.newBuilder().header("token", SpUtils.getString(getmInstance()!!, "token"))
val request = requestBuilder.build()
chain.proceed(request)
}.build()
}
public static <T> ApiRequtest enqueue(Call<ResponseBody> call, TypeToken<T> resultType, ApiResponse.Listener<ApiResult<T>> listener, ApiResponse.ErrorListener errorListener) {
ApiRequtest<T> request = new ApiRequtest<>(call, resultType, listener, errorListener);
return request;
fun <T> enqueue(
call: Call<ResponseBody?>?,
resultType: TypeToken<T>?,
listener: ApiResponse.Listener<ApiResult<T>?>?,
errorListener: ApiResponse.ErrorListener?
): ApiRequtest<*> {
return ApiRequtest(call!!, resultType!!, listener!!, errorListener!!)
}
}

View File

@ -1,9 +1,8 @@
package com.cmx.hydrology.retrofit;
package com.cmx.hydrology.retrofit
/**
* Created by Administrator on 2018/1/17 0017.
*/
public interface onRequestResponse {
void onResult(boolean success);
}
interface onRequestResponse {
fun onResult(success: Boolean)
}

View File

@ -1,9 +1,8 @@
package com.cmx.hydrology.retrofit;
package com.cmx.hydrology.retrofit
/**
* Created by Administrator on 2018/1/17 0017.
*/
public interface onServerRequestCallBack {
void onResult(int resultCode);
}
interface onServerRequestCallBack {
fun onResult(resultCode: Int)
}

View File

@ -1,180 +1,48 @@
package com.cmx.hydrology.ui;
package com.cmx.hydrology.ui
import android.app.Activity
import android.content.ClipData
import android.content.Intent
import android.net.Uri
import android.os.Bundle
import android.os.Environment
import android.provider.MediaStore
import android.util.Log
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.webkit.ValueCallback
import android.webkit.WebChromeClient
import android.webkit.WebView
import com.cmx.hydrology.constant.Events
import com.cmx.hydrology.databinding.FragmentHomeBinding
import java.io.File
import java.io.IOException
import java.text.SimpleDateFormat
import java.util.Date
import static com.cmx.hydrology.constant.Events.WEB_HOME_URL;
import static com.cmx.hydrology.constant.Events.WEB_SERVER_URL;
class HomeFragment : BaseFragment() {
private var binding: FragmentHomeBinding? = null
private var mWebView: WebView? = null
private var mUploadMessage: ValueCallback<Array<Uri>>? = null
private var mCameraPhotoPath: String? = null
private var size: Long = 0
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
binding = FragmentHomeBinding.inflate(inflater, container, false)
val root: View = binding!!.root
mWebView = binding!!.wvHome
setWebView(mWebView!!)
mWebView!!.loadUrl(Events.WEB_HOME_URL)
return root
}
import android.app.Activity;
import android.content.ClipData;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.webkit.ValueCallback;
import android.webkit.WebChromeClient;
import android.webkit.WebResourceError;
import android.webkit.WebResourceRequest;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import androidx.annotation.NonNull;
import androidx.fragment.app.Fragment;
import com.cmx.hydrology.databinding.FragmentHomeBinding;
import com.cmx.hydrology.utils.AndroidtoJs;
import com.cmx.hydrology.utils.MyUtils;
import com.cmx.hydrology.view.BaseLoadingDialog;
import com.lsxiao.apollo.core.Apollo;
import com.lsxiao.apollo.core.contract.ApolloBinder;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class HomeFragment extends BaseFragment {
private FragmentHomeBinding binding;
private WebView mWebView;
private ValueCallback<Uri[]> mUploadMessage;
private String mCameraPhotoPath = null;
private long size = 0;
private static final int INPUT_FILE_REQUEST_CODE = 1;
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
binding = FragmentHomeBinding.inflate(inflater, container, false);
View root = binding.getRoot();
mWebView = binding.wvHome;
setWebView(mWebView);
mWebView.loadUrl(WEB_HOME_URL);
mWebView.setWebChromeClient(new PQChromeClient());
return root;
override fun onDestroyView() {
super.onDestroyView()
binding = null
}
@Override
public void onDestroyView() {
super.onDestroyView();
binding = null;
companion object {
private const val INPUT_FILE_REQUEST_CODE = 1
}
public class PQChromeClient extends WebChromeClient {
// For Android 5.0+
public boolean onShowFileChooser(WebView view, ValueCallback<Uri[]> filePath, WebChromeClient.FileChooserParams fileChooserParams) {
// Double check that we don't have any existing callbacks
if (mUploadMessage != null) {
mUploadMessage.onReceiveValue(null);
}
mUploadMessage = filePath;
Log.e("FileCooserParams => ", filePath.toString());
Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
if (takePictureIntent.resolveActivity(getActivity().getPackageManager()) != null) {
// Create the File where the photo should go
File photoFile = null;
try {
photoFile = createImageFile();
takePictureIntent.putExtra("PhotoPath", mCameraPhotoPath);
} catch (IOException ex) {
// Error occurred while creating the File
Log.e("test", "Unable to create Image File", ex);
}
// Continue only if the File was successfully created
if (photoFile != null) {
mCameraPhotoPath = "file:" + photoFile.getAbsolutePath();
takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(photoFile));
} else {
takePictureIntent = null;
}
}
Intent contentSelectionIntent = new Intent(Intent.ACTION_GET_CONTENT);
contentSelectionIntent.addCategory(Intent.CATEGORY_OPENABLE);
contentSelectionIntent.putExtra(Intent.EXTRA_ALLOW_MULTIPLE, true);
contentSelectionIntent.setType("image/*");
Intent[] intentArray;
if (takePictureIntent != null) {
intentArray = new Intent[]{takePictureIntent};
} else {
intentArray = new Intent[2];
}
Intent chooserIntent = new Intent(Intent.ACTION_CHOOSER);
chooserIntent.putExtra(Intent.EXTRA_INTENT, contentSelectionIntent);
chooserIntent.putExtra(Intent.EXTRA_TITLE, "Image Chooser");
chooserIntent.putExtra(Intent.EXTRA_INITIAL_INTENTS, intentArray);
startActivityForResult(Intent.createChooser(chooserIntent, "Select images"), 1);
return true;
}
}
private File createImageFile() throws IOException {
// Create an image file name
String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
String imageFileName = "JPEG_" + timeStamp + "_";
File storageDir = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES);
File imageFile = File.createTempFile(imageFileName, /* prefix */
".jpg", /* suffix */
storageDir /* directory */);
return imageFile;
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode != INPUT_FILE_REQUEST_CODE || mUploadMessage == null) {
super.onActivityResult(requestCode, resultCode, data);
return;
}
try {
String file_path = mCameraPhotoPath.replace("file:", "");
File file = new File(file_path);
size = file.length();
if (data != null || mCameraPhotoPath != null) {
Integer count = 1;
ClipData images = null;
try {
images = data.getClipData();
} catch (Exception e) {
Log.e("Error!", e.getLocalizedMessage());
}
if (images == null && data != null && data.getDataString() != null) {
count = data.getDataString().length();
} else if (images != null) {
count = images.getItemCount();
}
Uri[] results = new Uri[count];
// Check that the response is a good one
if (resultCode == Activity.RESULT_OK) {
if (size != 0) {
// If there is not data, then we may have taken a photo
if (mCameraPhotoPath != null) {
results = new Uri[]{Uri.parse(mCameraPhotoPath)};
}
} else if (data.getClipData() == null) {
results = new Uri[]{Uri.parse(data.getDataString())};
} else {
for (int i = 0; i < images.getItemCount(); i++) {
results[i] = images.getItemAt(i).getUri();
}
}
}
mUploadMessage.onReceiveValue(results);
mUploadMessage = null;
}
} catch (Exception e) {
Log.e("Error!", "Error while opening image file" + e.getLocalizedMessage());
}
}
}

View File

@ -1,48 +1,27 @@
package com.cmx.hydrology.ui;
package com.cmx.hydrology.ui
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.webkit.WebView
import com.cmx.hydrology.constant.Events
import com.cmx.hydrology.databinding.FragmentMapBinding
import static com.cmx.hydrology.constant.Events.WEB_MAP_URL;
import static com.cmx.hydrology.constant.Events.WEB_SERVER_URL;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.webkit.WebResourceError;
import android.webkit.WebResourceRequest;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import androidx.annotation.NonNull;
import androidx.fragment.app.Fragment;
import com.cmx.hydrology.databinding.FragmentMapBinding;
import com.cmx.hydrology.utils.AndroidtoJs;
import com.cmx.hydrology.utils.MyUtils;
import com.cmx.hydrology.view.BaseLoadingDialog;
import com.lsxiao.apollo.core.Apollo;
import com.lsxiao.apollo.core.contract.ApolloBinder;
public class MapFragment extends BaseFragment {
private FragmentMapBinding binding;
private WebView mWebView;
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
binding = FragmentMapBinding.inflate(inflater, container, false);
View root = binding.getRoot();
mWebView = binding.wvMine;
setWebView(mWebView);
mWebView.loadUrl(WEB_MAP_URL);
return root;
class MapFragment : BaseFragment() {
private var binding: FragmentMapBinding? = null
private var mWebView: WebView? = null
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
binding = FragmentMapBinding.inflate(inflater, container, false)
val root: View = binding!!.root
mWebView = binding!!.wvMine
setWebView(mWebView!!)
mWebView!!.loadUrl(Events.WEB_MAP_URL)
return root
}
@Override
public void onDestroyView() {
super.onDestroyView();
binding = null;
override fun onDestroyView() {
super.onDestroyView()
binding = null
}
}

View File

@ -1,63 +1,26 @@
package com.cmx.hydrology.ui;
package com.cmx.hydrology.ui
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.webkit.WebView
import com.cmx.hydrology.databinding.FragmentMsgBinding
import static com.cmx.hydrology.constant.Events.SERVER_URL;
import android.app.Activity;
import android.content.ClipData;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.webkit.ValueCallback;
import android.webkit.WebChromeClient;
import android.webkit.WebResourceError;
import android.webkit.WebResourceRequest;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import androidx.annotation.NonNull;
import androidx.fragment.app.Fragment;
import com.cmx.hydrology.databinding.FragmentMsgBinding;
import com.cmx.hydrology.utils.AndroidtoJs;
import com.cmx.hydrology.utils.MyUtils;
import com.cmx.hydrology.view.BaseLoadingDialog;
import com.lsxiao.apollo.core.Apollo;
import com.lsxiao.apollo.core.contract.ApolloBinder;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class MsgFragment extends BaseFragment {
private FragmentMsgBinding binding;
private WebView mWebView;
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
binding = FragmentMsgBinding.inflate(inflater, container, false);
View root = binding.getRoot();
mWebView = binding.wvLoan;
setWebView(mWebView);
class MsgFragment : BaseFragment() {
private var binding: FragmentMsgBinding? = null
private var mWebView: WebView? = null
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
binding = FragmentMsgBinding.inflate(inflater, container, false)
val root: View = binding!!.root
mWebView = binding!!.wvLoan
setWebView(mWebView!!)
// mWebView.loadUrl(SERVER_URL + "/nigeria/?lang=English#/loans");
return root;
return root
}
@Override
public void onDestroyView() {
super.onDestroyView();
binding = null;
override fun onDestroyView() {
super.onDestroyView()
binding = null
}
}

View File

@ -1,45 +1,26 @@
package com.cmx.hydrology.ui;
package com.cmx.hydrology.ui
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.webkit.WebView
import com.cmx.hydrology.databinding.FragmentMyBinding
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.webkit.WebResourceError;
import android.webkit.WebResourceRequest;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import androidx.annotation.NonNull;
import androidx.fragment.app.Fragment;
import com.cmx.hydrology.databinding.FragmentMyBinding;
import com.cmx.hydrology.utils.AndroidtoJs;
import com.cmx.hydrology.utils.MyUtils;
import com.cmx.hydrology.view.BaseLoadingDialog;
import com.lsxiao.apollo.core.Apollo;
import com.lsxiao.apollo.core.contract.ApolloBinder;
public class MyFragment extends BaseFragment {
private FragmentMyBinding binding;
private WebView mWebView;
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
binding = FragmentMyBinding.inflate(inflater, container, false);
View root = binding.getRoot();
mWebView = binding.wvMine;
setWebView(mWebView);
class MyFragment : BaseFragment() {
private var binding: FragmentMyBinding? = null
private var mWebView: WebView? = null
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
binding = FragmentMyBinding.inflate(inflater, container, false)
val root: View = binding!!.root
mWebView = binding!!.wvMine
setWebView(mWebView!!)
// mWebView.loadUrl(SERVER_URL + "/nigeria/?lang=English#/my");
return root;
return root
}
@Override
public void onDestroyView() {
super.onDestroyView();
binding = null;
override fun onDestroyView() {
super.onDestroyView()
binding = null
}
}

View File

@ -1,78 +1,76 @@
package com.cmx.hydrology.utils;
package com.cmx.hydrology.utils
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.util.Log;
import android.webkit.JavascriptInterface;
import com.cmx.hydrology.activity.MyApplication;
import com.cmx.hydrology.constant.Events;
import com.lsxiao.apollo.core.Apollo;
public class AndroidtoJs {
private static final String TAG = "cmx_AndroidtoJs";
import android.content.pm.PackageManager
import android.util.Log
import android.webkit.JavascriptInterface
import com.cmx.hydrology.activity.MyApplication.Companion.getmInstance
import com.cmx.hydrology.constant.Events
import com.lsxiao.apollo.core.Apollo
class AndroidtoJs {
// 定义JS需要调用的方法
// 被JS调用的方法必须加入@JavascriptInterface注解
@JavascriptInterface
public String getAppToken() {
L.e("JS--", "getAppToken()");
return SpUtils.getString(MyApplication.getmInstance(), "token");
}
@JavascriptInterface
public String getAppVersion() {
L.e("JS--", "getAppVersion()");
String versionname;//版本号
try {
PackageManager pm = MyApplication.getmInstance().getApplicationContext().getPackageManager();
PackageInfo pi = pm.getPackageInfo(MyApplication.getmInstance().getApplicationContext().getPackageName(), 0);
versionname = "V" + pi.versionName;
} catch (PackageManager.NameNotFoundException e) {
versionname = "未知";
@get:JavascriptInterface
val appToken: String?
get() {
L.e("JS--", "getAppToken()")
return SpUtils.getString(getmInstance()!!, "token")
}
Log.e(TAG, "getAppVersion=" + versionname);
return versionname;
//版本号
@get:JavascriptInterface
val appVersion: String
get() {
L.e("JS--", "getAppVersion()")
val versionname: String //版本号
versionname = try {
val pm = getmInstance()!!.applicationContext.packageManager
val pi = pm.getPackageInfo(getmInstance()!!.applicationContext.packageName, 0)
"V" + pi.versionName
} catch (e: PackageManager.NameNotFoundException) {
"未知"
}
Log.e(TAG, "getAppVersion=$versionname")
return versionname
}
@JavascriptInterface
fun existApp() {
L.e("JS--", "existApp()")
Apollo.emit(Events.JS_OPEN_LOGOUT)
}
@JavascriptInterface
public void existApp() {
L.e("JS--", "existApp()");
Apollo.emit(Events.JS_OPEN_LOGOUT);
fun showTab() { //tabbar显示
L.e("JS--", "showTab()")
Apollo.emit(Events.JS_OPEN_TABBAR_SHOW)
}
@JavascriptInterface
public void showTab() {//tabbar显示
L.e("JS--", "showTab()");
Apollo.emit(Events.JS_OPEN_TABBAR_SHOW);
fun hideTab() { //tabbar隐藏
L.e("JS--", "hideTab()")
Apollo.emit(Events.JS_OPEN_TABBAR_HIDE)
}
@JavascriptInterface
public void hideTab() {//tabbar隐藏
L.e("JS--", "hideTab()");
Apollo.emit(Events.JS_OPEN_TABBAR_HIDE);
fun openWeb(url: String) { //打开一个新的web界面
L.e("JS--", "openWeb()$url")
Apollo.emit(Events.JS_OPEN_OPEN_WEB, url)
}
@JavascriptInterface
public void openWeb(String url) {//打开一个新的web界面
L.e("JS--", "openWeb()" + url);
Apollo.emit(Events.JS_OPEN_OPEN_WEB, url);
fun closeWeb() { //关闭那个新的web界面
L.e("JS--", "closeWeb()")
Apollo.emit(Events.JS_OPEN_CLOSE_WEB)
}
@JavascriptInterface
public void closeWeb() {//关闭那个新的web界面
L.e("JS--", "closeWeb()");
Apollo.emit(Events.JS_OPEN_CLOSE_WEB);
fun checkTab(mode: String?) { //关闭注册/忘记密码
L.e("JS--", "checkTab()")
Apollo.emit(Events.JS_OPEN_TAB, mode!!)
}
@JavascriptInterface
public void checkTab(String mode) {//关闭注册/忘记密码
L.e("JS--", "checkTab()");
Apollo.emit(Events.JS_OPEN_TAB, mode);
companion object {
private const val TAG = "cmx_AndroidtoJs"
}
}

View File

@ -1,92 +1,49 @@
package com.cmx.hydrology.utils;
package com.cmx.hydrology.utils
import android.content.ContentResolver;
import android.content.Context;
import android.content.Intent;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
import android.os.Build;
import android.provider.MediaStore;
import android.util.Base64;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.util.Log
import java.io.File;
import java.lang.reflect.Method;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class L {
private L() {
throw new UnsupportedOperationException("cannot be instantiated");
class L private constructor() {
init {
throw UnsupportedOperationException("cannot be instantiated")
}
public static boolean isDebug = true;
private static String TAG = "LjTestLog";
companion object {
var isDebug = true
var tAG = "LjTestLog"
fun setDebugMode(debug: Boolean) {
isDebug = debug
}
public static String getTAG() {
return TAG;
fun i(msg: String?) {
if (isDebug) Log.i(tAG, msg!!)
}
fun d(msg: String?) {
if (isDebug) Log.d(tAG, msg!!)
}
fun e(msg: String?) {
if (isDebug) Log.e(tAG, msg!!)
}
fun v(msg: String?) {
if (isDebug) Log.v(tAG, msg!!)
}
fun i(tag: String?, msg: String?) {
if (isDebug) Log.i(tag, msg!!)
}
fun d(tag: String?, msg: String?) {
if (isDebug) Log.d(tag, msg!!)
}
fun e(tag: String?, msg: String?) {
if (isDebug) Log.e(tag, msg!!)
}
fun v(tag: String?, msg: String?) {
if (isDebug) Log.v(tag, msg!!)
}
}
public static void setTAG(String TAG) {
L.TAG = TAG;
}
public static void setDebugMode(boolean debug) {
isDebug = debug;
}
public static void i(String msg) {
if (isDebug)
Log.i(TAG, msg);
}
public static void d(String msg) {
if (isDebug)
Log.d(TAG, msg);
}
public static void e(String msg) {
if (isDebug)
Log.e(TAG, msg);
}
public static void v(String msg) {
if (isDebug)
Log.v(TAG, msg);
}
public static void i(String tag, String msg) {
if (isDebug)
Log.i(tag, msg);
}
public static void d(String tag, String msg) {
if (isDebug)
Log.d(tag, msg);
}
public static void e(String tag, String msg) {
if (isDebug)
Log.e(tag, msg);
}
public static void v(String tag, String msg) {
if (isDebug)
Log.v(tag, msg);
}
}
}

View File

@ -1,180 +1,168 @@
package com.cmx.hydrology.utils;
package com.cmx.hydrology.utils
import android.app.Activity;
import android.content.ContentResolver;
import android.content.ContentValues;
import android.content.Context;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.database.Cursor;
import android.graphics.Color;
import android.net.Uri;
import android.os.Build;
import android.os.Environment;
import android.os.StatFs;
import android.provider.MediaStore;
import android.util.Log;
import android.view.View;
import android.view.WindowManager;
import android.app.Activity
import android.content.Context
import android.graphics.Color
import android.os.Build
import android.os.Environment
import android.os.StatFs
import android.util.Log
import android.view.View
import android.view.WindowManager
import java.io.BufferedReader
import java.io.File
import java.io.FileReader
import java.io.IOException
import java.nio.charset.StandardCharsets
import java.security.MessageDigest
import java.security.NoSuchAlgorithmException
import java.util.Locale
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.lang.reflect.Method;
import java.nio.charset.StandardCharsets;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Locale;
public class MyUtils {
private static final String TAG = "cmx_" + MyUtils.class.getSimpleName();
public static void setNavigationStatusColor(Activity activity, int color) {
activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
activity.getWindow().setNavigationBarColor(color);
activity.getWindow().setStatusBarColor(color);
object MyUtils {
private val TAG = "cmx_" + MyUtils::class.java.simpleName
fun setNavigationStatusColor(activity: Activity, color: Int) {
activity.window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS)
activity.window.navigationBarColor = color
activity.window.statusBarColor = color
}
public static void setFullscreen(Activity activity, boolean isShowStatusBar, boolean isShowNavigationBar) {
int uiOptions = View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY;
fun setFullscreen(activity: Activity, isShowStatusBar: Boolean, isShowNavigationBar: Boolean) {
var uiOptions =
View.SYSTEM_UI_FLAG_LAYOUT_STABLE or View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION or View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN or View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY
if (!isShowStatusBar) {
uiOptions |= View.SYSTEM_UI_FLAG_FULLSCREEN;
uiOptions = uiOptions or View.SYSTEM_UI_FLAG_FULLSCREEN
}
if (!isShowNavigationBar) {
uiOptions |= View.SYSTEM_UI_FLAG_HIDE_NAVIGATION;
uiOptions = uiOptions or View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
}
activity.getWindow().getDecorView().setSystemUiVisibility(uiOptions);
setNavigationStatusColor(activity, Color.TRANSPARENT);
activity.window.decorView.systemUiVisibility = uiOptions
setNavigationStatusColor(activity, Color.TRANSPARENT)
}
public static void setAndroidNativeLightStatusBar(Activity activity, boolean dark) {
View decor = activity.getWindow().getDecorView();
fun setAndroidNativeLightStatusBar(activity: Activity, dark: Boolean) {
val decor = activity.window.decorView
if (dark) {
decor.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
decor.systemUiVisibility =
View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN or View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR
} else {
decor.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
decor.systemUiVisibility =
View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN or View.SYSTEM_UI_FLAG_LAYOUT_STABLE
}
}
private static String getVersionName(Activity activity) throws Exception {
PackageManager packageManager = activity.getPackageManager();
@Throws(Exception::class)
private fun getVersionName(activity: Activity): String {
val packageManager = activity.packageManager
// getPackageName()是你当前类的包名0代表是获取版本信息
PackageInfo packInfo = packageManager.getPackageInfo(activity.getPackageName(), 0);
String version = packInfo.versionName;
return version;
val packInfo = packageManager.getPackageInfo(activity.packageName, 0)
return packInfo.versionName
}
public static void getDeviceInfo(Activity activity) throws Exception {
String model = android.os.Build.MODEL;
String carrier = android.os.Build.MANUFACTURER;
String version = getVersionName(activity);
String lang = getSystemLanguage();
String brand = getPhoneBrand();
String releaseVersion = getVersionRelease();
int sdkVersion = getSdkVersion();
Log.e(TAG, "model=" + model + ", carrier=" + carrier + ", version=" + version + ", lang=" + lang + ", brand=" + brand + ", releaseVersion=" + releaseVersion + ",sdk version=" + sdkVersion);
@Throws(Exception::class)
fun getDeviceInfo(activity: Activity) {
val model = Build.MODEL
val carrier = Build.MANUFACTURER
val version = getVersionName(activity)
val lang = systemLanguage
val brand = phoneBrand
val releaseVersion = versionRelease
val sdkVersion = sdkVersion
Log.e(
TAG,
"model=$model, carrier=$carrier, version=$version, lang=$lang, brand=$brand, releaseVersion=$releaseVersion,sdk version=$sdkVersion"
)
}
public static String getSystemLanguage() {
return Locale.getDefault().getLanguage();
}
val systemLanguage: String
get() = Locale.getDefault().language
val systemLanguageList: Array<Locale>
get() = Locale.getAvailableLocales()
val phoneBrand: String
get() = Build.BRAND
val versionRelease: String
get() = Build.VERSION.RELEASE
val sdkVersion: Int
get() = Build.VERSION.SDK_INT//8.0-//8.0+
public static Locale[] getSystemLanguageList() {
return Locale.getAvailableLocales();
}
public static String getPhoneBrand() {
return Build.BRAND;
}
public static String getVersionRelease() {
return Build.VERSION.RELEASE;
}
public static int getSdkVersion() {
return Build.VERSION.SDK_INT;
}
public static String getSerialNum() {
String serial = "unknown";
try {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) {//9.0+
serial = Build.getSerial();
} else if (Build.VERSION.SDK_INT > Build.VERSION_CODES.N) {//8.0+
serial = Build.SERIAL;
} else {//8.0-
Class<?> c = Class.forName("android.os.SystemProperties");
Method get = c.getMethod("get", String.class);
serial = (String) get.invoke(c, "ro.serialno");
//9.0+
val serialNum: String?
get() {
var serial: String? = "unknown"
try {
serial = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) { //9.0+
Build.getSerial()
} else if (Build.VERSION.SDK_INT > Build.VERSION_CODES.N) { //8.0+
Build.SERIAL
} else { //8.0-
val c = Class.forName("android.os.SystemProperties")
val get = c.getMethod("get", String::class.java)
get.invoke(c, "ro.serialno") as String
}
} catch (e: Exception) {
Log.e("序列号》》", e.toString())
e.printStackTrace()
}
} catch (Exception e) {
Log.e("序列号》》", e.toString());
e.printStackTrace();
Log.e("序列号》》", serial!!)
return serial
}
Log.e("序列号》》", serial);
return serial;
fun createTempImageFile(context: Context?): File? {
val destFolder = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DCIM)
destFolder.mkdirs()
val dateTimeString = System.currentTimeMillis().toString() + ""
var imageFile: File? = null
imageFile = try {
File.createTempFile("$dateTimeString-", ".jpg", destFolder)
} catch (e: IOException) {
Log.e("文件失败>>>", e.toString())
throw RuntimeException(e)
}
return imageFile
}
public static File createTempImageFile(Context context) {
File destFolder = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DCIM);
destFolder.mkdirs();
String dateTimeString = System.currentTimeMillis() + "";
File imageFile = null;
try {
imageFile = File.createTempFile(dateTimeString + "-", ".jpg", destFolder);
} catch (IOException e) {
Log.e("文件失败>>>", e.toString());
throw new RuntimeException(e);
}
return imageFile;
}
public static String getTotalRam() {
String path = "/proc/meminfo";
String ramMemorySize = null;
int totalRam = 0;
try {
FileReader fileReader = new FileReader(path);
BufferedReader br = new BufferedReader(fileReader, 4096);
ramMemorySize = br.readLine().split("\\s+")[1];
br.close();
} catch (Exception e) {
e.printStackTrace();
}
if (ramMemorySize != null) {
totalRam = (int) Math.ceil((Float.valueOf(Float.parseFloat(ramMemorySize) / (1024 * 1024)).doubleValue()));
}
return totalRam + "";
}
public static String getTotalRom() {
File dataDir = Environment.getDataDirectory();
StatFs stat = new StatFs(dataDir.getPath());
long blockSize = stat.getBlockSizeLong();
long totalBlocks = stat.getBlockCountLong();
long size = totalBlocks * blockSize;
long GB = 1024 * 1024 * 1024;
final long[] deviceRomMemoryMap = {2 * GB, 4 * GB, 8 * GB, 16 * GB, 32 * GB, 64 * GB, 128 * GB, 256 * GB, 512 * GB, 1024 * GB, 2048 * GB};
String[] displayRomSize = {"2GB", "4GB", "8GB", "16GB", "32GB", "64GB", "128GB", "256GB", "512GB", "1024GB", "2048GB"};
int i;
for (i = 0; i < deviceRomMemoryMap.length; i++) {
if (size <= deviceRomMemoryMap[i]) {
break;
val totalRam: String
get() {
val path = "/proc/meminfo"
var ramMemorySize: String? = null
var totalRam = 0
try {
val fileReader = FileReader(path)
val br = BufferedReader(fileReader, 4096)
ramMemorySize = br.readLine().split("\\s+".toRegex()).dropLastWhile { it.isEmpty() }.toTypedArray()[1]
br.close()
} catch (e: Exception) {
e.printStackTrace()
}
if (i == deviceRomMemoryMap.length) {
i--;
if (ramMemorySize != null) {
totalRam = Math.ceil(java.lang.Float.valueOf(ramMemorySize.toFloat() / (1024 * 1024)).toDouble()).toInt()
}
return totalRam.toString() + ""
}
val totalRom: String
get() {
val dataDir = Environment.getDataDirectory()
val stat = StatFs(dataDir.path)
val blockSize = stat.blockSizeLong
val totalBlocks = stat.blockCountLong
val size = totalBlocks * blockSize
val GB = (1024 * 1024 * 1024).toLong()
val deviceRomMemoryMap =
longArrayOf(2 * GB, 4 * GB, 8 * GB, 16 * GB, 32 * GB, 64 * GB, 128 * GB, 256 * GB, 512 * GB, 1024 * GB, 2048 * GB)
val displayRomSize =
arrayOf("2GB", "4GB", "8GB", "16GB", "32GB", "64GB", "128GB", "256GB", "512GB", "1024GB", "2048GB")
var i: Int
i = 0
while (i < deviceRomMemoryMap.size) {
if (size <= deviceRomMemoryMap[i]) {
break
}
if (i == deviceRomMemoryMap.size) {
i--
}
i++
}
return displayRomSize[i].replace("GB", "")
}
return displayRomSize[i].replace("GB", "");
}
/**
* sha256加密
@ -182,39 +170,36 @@ public class MyUtils {
* @param str 要加密的字符串
* @return 加密后的字符串
*/
public static String getSha256Str(String str) {
MessageDigest messageDigest;
String encodeStr = "";
fun getSha256Str(str: String): String {
val messageDigest: MessageDigest
var encodeStr = ""
try {
messageDigest = MessageDigest.getInstance("SHA-256");
messageDigest.update(str.getBytes(StandardCharsets.UTF_8));
encodeStr = byte2Hex(messageDigest.digest());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
messageDigest = MessageDigest.getInstance("SHA-256")
messageDigest.update(str.toByteArray(StandardCharsets.UTF_8))
encodeStr = byte2Hex(messageDigest.digest())
} catch (e: NoSuchAlgorithmException) {
e.printStackTrace()
}
return encodeStr;
return encodeStr
}
/**
* sha256加密 将byte转为16进制
*
* @param bytes 字节码
* @return 加密后的字符串
*/
private static String byte2Hex(byte[] bytes) {
StringBuilder stringBuilder = new StringBuilder();
String temp;
for (byte aByte : bytes) {
temp = Integer.toHexString(aByte & 0xFF);
if (temp.length() == 1) {
private fun byte2Hex(bytes: ByteArray): String {
val stringBuilder = StringBuilder()
var temp: String
for (aByte in bytes) {
temp = Integer.toHexString(aByte.toInt() and 0xFF)
if (temp.length == 1) {
//1得到一位的进行补0操作
stringBuilder.append("0");
stringBuilder.append("0")
}
stringBuilder.append(temp);
stringBuilder.append(temp)
}
return stringBuilder.toString();
return stringBuilder.toString()
}
}
}

View File

@ -1,24 +1,18 @@
package com.cmx.hydrology.utils;
package com.cmx.hydrology.utils
import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.view.WindowManager;
import android.content.Context
public class SpUtils {
private static final String SP_NAME = "SP_USER_DATA";
public static void putString(Context context, String key, String val) {
SharedPreferences sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
SharedPreferences.Editor editor = sp.edit();
editor.putString(key, val);
editor.commit();
object SpUtils {
private const val SP_NAME = "SP_USER_DATA"
fun putString(context: Context, key: String?, `val`: String?) {
val sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE)
val editor = sp.edit()
editor.putString(key, `val`)
editor.commit()
}
public static String getString(Context context, String key) {
SharedPreferences sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
return sp.getString(key, "");
fun getString(context: Context, key: String?): String? {
val sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE)
return sp.getString(key, "")
}
}
}

View File

@ -1,8 +1,8 @@
package com.cmx.hydrology.utils;
package com.cmx.hydrology.utils
public class StaticFinalData {
public static final String LOGOUT = "LOGOUT";
public static final String UPLOAD_FACE = "UPLOAD_FACE";
public static final String UPLOAD_FACE_OVER = "UPLOAD_FACE_OVER";
public static final String CHANGE_TAB = "CHANGE_TAB";
}
object StaticFinalData {
const val LOGOUT = "LOGOUT"
const val UPLOAD_FACE = "UPLOAD_FACE"
const val UPLOAD_FACE_OVER = "UPLOAD_FACE_OVER"
const val CHANGE_TAB = "CHANGE_TAB"
}