From 87cd5df70918e6ba1af849c5f026d3719bfdb1ac Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期三, 09 四月 2025 09:06:29 +0800 Subject: [PATCH] Merge branch '1.5.2' into dev --- app/src/main/java/com/hdl/photovoltaic/other/HdlCommonLogic.java | 224 +++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 141 insertions(+), 83 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlCommonLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlCommonLogic.java index 1edf0e8..4720942 100644 --- a/app/src/main/java/com/hdl/photovoltaic/other/HdlCommonLogic.java +++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlCommonLogic.java @@ -1,46 +1,32 @@ package com.hdl.photovoltaic.other; -import android.app.Activity; import android.content.Context; import android.graphics.Bitmap; -import android.os.SystemClock; import android.text.SpannableStringBuilder; import android.text.TextPaint; import android.text.TextUtils; import android.text.style.ClickableSpan; import android.view.View; -import android.view.inputmethod.InputMethodManager; import android.widget.ImageView; import android.widget.TextView; import androidx.annotation.NonNull; -import com.google.gson.JsonObject; import com.google.zxing.BarcodeFormat; import com.google.zxing.EncodeHintType; import com.google.zxing.common.BitMatrix; import com.google.zxing.qrcode.QRCodeWriter; -import com.hdl.linkpm.sdk.user.HDLLinkPMUser; import com.hdl.photovoltaic.HDLApp; import com.hdl.photovoltaic.R; -import com.hdl.photovoltaic.config.ConstantManage; -import com.hdl.photovoltaic.config.UserConfigManage; -import com.hdl.photovoltaic.enums.HomepageTitleTabSwitch; import com.hdl.photovoltaic.enums.LowerTagType; import com.hdl.photovoltaic.enums.UnitType; import com.hdl.photovoltaic.utils.GlideUtils; import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus; -import com.hdl.sdk.link.core.callback.BaseCallBack; import org.greenrobot.eventbus.EventBus; -import org.json.JSONObject; -import java.io.InputStream; -import java.io.OutputStream; import java.math.BigDecimal; import java.math.RoundingMode; -import java.net.InetSocketAddress; -import java.net.Socket; import java.util.Hashtable; /** @@ -74,72 +60,47 @@ return sHdlCommonLogic; } - public static String getConvertDoubleUnit(String value) { - if (TextUtils.isEmpty(value)) { - return UnitType.noValue; - } - BigDecimal formattedValue = getBigDecimal(value); - return formattedValue.toString(); - - } - - public static String getConvertDoubleUnit(int value) { - if (value == 0) { - return UnitType.noValue; - } - BigDecimal formattedValue = getBigDecimal(value + ""); - return formattedValue.toString(); - } - /** * @param value 鍊� - * @param unit 渚嬪:UnitType.kWh - * @return 甯﹀崟浣嶅�艰繑鍥� + * @return 瀛楃涓插�艰繑鍥� */ - public static String getConvertDoubleUnit(String value, String unit) { + public static String convertDoubleValue(String value) { if (TextUtils.isEmpty(value)) { - return UnitType.noValue + unit; + return UnitType.noValue; } - if (unit.equals(UnitType.kW) || unit.equals(UnitType.kWh)) { - return divideByOneThousandAndFormat(value).toString() + unit; - } - return getBigDecimal(value).toString() + unit; - + return divideByOneThousandAndFormat(value).toString(); } - /** - * @param value 鍊� - * @param unitValue 渚嬪:UnitType.kWh - * @param isUnit true琛ㄧず鏈夊崟浣嶈繑鍥� - * @return 甯﹀崟浣嶅�艰繑鍥� + * @param value 鍊� + * @param diploidValue 鍊嶆暟 + * @return 瀛楃涓� */ - public static String getConvertDoubleUnit(String value, String unitValue, boolean isUnit) { - if (TextUtils.isEmpty(value)) { - return UnitType.noValue + (isUnit ? unitValue : ""); + public static String convertDoubleValue(String value, int diploidValue) { + try { + double doubleValue = Double.parseDouble(value); + BigDecimal bigDecimal = new BigDecimal(doubleValue); + return bigDecimal.divide(new BigDecimal(diploidValue), 2, RoundingMode.HALF_EVEN).toString(); + } catch (Exception e) { + return "0.00"; } - if (unitValue.equals(UnitType.kW)) { - return divideByOneThousandAndFormat(value).toString() + (isUnit ? unitValue : ""); - } - return getBigDecimal(value).toString() + (isUnit ? unitValue : ""); - } - /** - * @param value 鍊� - * @param unit 渚嬪:UnitType.kWh - * @return 甯﹀崟浣嶅�艰繑鍥� + * @param value 鍊� + * @param diploidValue 鍊嶆暟 + * @return 瀛楃涓� */ - public static String getConvertDoubleUnit(int value, String unit) { - if (value == 0) { - return UnitType.noValue + unit; + public static BigDecimal convertBigDecimal(String value, int diploidValue) { + try { + double doubleValue = Double.parseDouble(value); + BigDecimal bigDecimal = new BigDecimal(doubleValue); + return bigDecimal.divide(new BigDecimal(diploidValue), 2, RoundingMode.HALF_EVEN); + } catch (Exception e) { + return new BigDecimal(0); } - BigDecimal formattedValue = getBigDecimal(value + ""); - return formattedValue.toString() + unit; } - public static String convertString(Object value) { return String.valueOf(value); @@ -154,6 +115,7 @@ return BigDecimal.valueOf(doubleValue).setScale(2, RoundingMode.HALF_UP); } + /** * 闄や互涓�鍗冨拰鏍煎紡 * @@ -163,16 +125,13 @@ public static BigDecimal divideByOneThousandAndFormat(String value) { try { double doubleValue = Double.parseDouble(value); - int val = 1000; - if (doubleValue > 1000 && doubleValue < 1000 * 1000) { - val = 1000; - } else if (doubleValue > 1000 * 1000 && doubleValue < 1000 * 1000 * 1000) { - val = 1000 * 1000; - } else if (doubleValue > 1000 * 1000 * 1000) { - val = 1000 * 1000 * 1000; + int mDoubleValue = doubleValue(value); + if (mDoubleValue == 0) { + return getBigDecimal(value); + } else { + BigDecimal bigDecimal = new BigDecimal(doubleValue); + return bigDecimal.divide(new BigDecimal(mDoubleValue), 2, RoundingMode.HALF_EVEN); } - BigDecimal bigDecimal = new BigDecimal(doubleValue); - return bigDecimal.divide(new BigDecimal(val), 2, RoundingMode.HALF_EVEN); } catch (Exception e) { BigDecimal bigDecimal = new BigDecimal(0); return bigDecimal.divide(new BigDecimal(1000), 2, RoundingMode.HALF_EVEN); @@ -184,18 +143,117 @@ * * @param value 鍊� */ - public static int val(String value) { - double doubleValue = Double.parseDouble(value); - int val = 1000; - if (doubleValue > 1000 && doubleValue < 1000 * 1000) { - val = 1000; - } else if (doubleValue > 1000 * 1000 && doubleValue < 1000 * 1000 * 1000) { - val = 1000 * 1000; - } else if (doubleValue > 1000 * 1000 * 1000) { - val = 1000 * 1000 * 1000; + public static int doubleValue(String value) { + try { + double doubleValue = Double.parseDouble(value); + if (doubleValue > 1000 && doubleValue < 1000 * 1000) { + return 1000; + } else if (doubleValue > 1000 * 1000 && doubleValue < 1000 * 1000 * 1000) { + return 1000 * 1000; + } else if (doubleValue > 1000 * 1000 * 1000) { + return 1000 * 1000 * 1000; + } else { + return 0; + } + } catch (Exception e) { + return 0; } - return val; + } + + /** + * 杞崲鍗曚綅 + * + * @param value 鍊� + * @param unitType 琛ㄧず鏄崟浣嶏紙鍔熺巼锛岀數閲忥級 + */ + public static String convertUnit(String value, String unitType) { + try { + double doubleValue = Double.parseDouble(value); + if (doubleValue > 1000 && doubleValue < 1000 * 1000) { + return unitType.equals(UnitType.kW) ? UnitType.mW : UnitType.mWh; + } else if (doubleValue > 1000 * 1000 && doubleValue < 1000 * 1000 * 1000) { + return unitType.equals(UnitType.kW) ? UnitType.gW : UnitType.gWh; + } else if (doubleValue > 1000 * 1000 * 1000) { + return unitType.equals(UnitType.kW) ? UnitType.tW : UnitType.tWh; + } else { + return unitType.equals(UnitType.kW) ? UnitType.kW : UnitType.kWh; + } + } catch (Exception e) { + return unitType.equals(UnitType.kW) ? UnitType.kW : UnitType.kWh; + } + + } + + /** + * 杞崲鐢甸噺(kWh)鍗曚綅 + * + * @param value 鍊� + */ + public static String convertKWHUnit(String value) { + try { + double doubleValue = Double.parseDouble(value); + if (doubleValue > 1000 && doubleValue < 1000 * 1000) { + return UnitType.mWh; + } else if (doubleValue > 1000 * 1000 && doubleValue < 1000 * 1000 * 1000) { + return UnitType.gWh; + } else if (doubleValue > 1000 * 1000 * 1000) { + return UnitType.tWh; + } else { + return UnitType.kWh; + } + } catch (Exception e) { + return UnitType.kWh; + } + + } + + /** + * 杞崲鍔熺巼(kW)鍗曚綅 + * + * @param value 鍊� + */ + public static String convertKWUnit(String value) { + try { + double doubleValue = Double.parseDouble(value); + if (doubleValue > 1000 && doubleValue < 1000 * 1000) { + return UnitType.mW; + } else if (doubleValue > 1000 * 1000 && doubleValue < 1000 * 1000 * 1000) { + return UnitType.gW; + } else if (doubleValue > 1000 * 1000 * 1000) { + return UnitType.tW; + } else { + return UnitType.kW; + } + } catch (Exception e) { + return UnitType.kW; + } + + } + + /** + * 杞崲(kWp)鍗曚綅 + * + * @param value 鍊� + */ + public static String convertKWPUnit(String value) { + try { + double doubleValue = Double.parseDouble(value); + if (doubleValue > 1000 && doubleValue < 1000 * 1000) { + return UnitType.MWp; + } else if (doubleValue > 1000 * 1000 && doubleValue < 1000 * 1000 * 1000) { + return UnitType.GWp; + } else if (doubleValue > 1000 * 1000 * 1000) { + return UnitType.TWp; + } else { + return UnitType.kWp; + } + } catch (Exception e) { + return UnitType.kWp; + } + + } + /** * 鐢熸垚浜岀淮鐮� @@ -307,7 +365,7 @@ public void updateDrawState(@NonNull TextPaint ds) { super.updateDrawState(ds); //璁剧疆瀛椾綋棰滆壊 - ds.setColor(HDLApp.getInstance().getResources().getColor(R.color.text_E6FFFFFF, null)); + ds.setColor(HDLApp.getInstance().getResources().getColor(R.color.text_FFACACAC, null)); // 鍘绘帀涓嬪垝绾� ds.setUnderlineText(isUnderline); } -- Gitblit v1.8.0