Android手机安全卫视之启动界面

本项目是笔者的一个小型练手项目,将会对项目分点详述,工程也push在Github,欢迎star

一、启动界面设计分析

启动界面比较简单,主要有一张背景图,一个TextView以及一个progressBar

这里写图片描述


二、代码组织

1.可以通过requestWindowFeature(Window.FEATURE_NO_TITLE)消除Title,也可以通过属性设置应用的主题
 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_splash);
        initUI();
        initData();
        initAnimation();
    }
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
        <item name="windowNoTitle">true</item>
    </style>
2.SplashActivity布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/launcher_bg"
    android:id="@+id/rl_root"
    >
    <TextView
        android:id="@+id/tv_version_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:shadowDx="1"
        android:shadowDy="1"
        android:shadowColor="#f00"
        android:shadowRadius="1"
        android:textSize="16sp"
        android:text="版本名称"/>
    <ProgressBar
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:layout_below="@+id/tv_version_name"/>
</RelativeLayout>
3.初始化UI
/**
     * 初始化界面
     */
    private void initUI() {
        rl_root = (RelativeLayout) findViewById(R.id.rl_root);
        tv_version_name = (TextView) findViewById(R.id.tv_version_name);
    }
4.初始化数据过程中,主要是对前面和版本号有关的TextView进行文本内容更新,同时,对应用的版本进行检查。
/**
     * 初始化数据
     */
    private void initData() {
        tv_version_name.setText("版本名称:" + getVersionName());
        mLocalVersionCode = getVersionCode();
        if (SpUtil.getBoolean(this, ConstantValue.OPEN_UPDATE, false)) {
            checkVersion();
        } else {
            mHandle.sendEmptyMessageDelayed(ENTER_HOME, 4000);
        }
    }
(1)对app进行版本检查,是一个耗时操作,所以我们需要开启子线程,并且通知主线程反馈信息。
 private Handler mHandle = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            switch (msg.what) {
                case UPDATE_VERSION:
                    Toast.makeText(SplashActivity.this, 
                    "需要更新", Toast.LENGTH_SHORT).show();
                    break;
                case ENTER_HOME:
                    enterHome();
                    break;
                case URL_ERROR:
                    "连接错误", Toast.LENGTH_SHORT).show();
                    break;
                case IO_ERROR:
                    Toast.makeText(SplashActivity.this, 
                    "读取异常", Toast.LENGTH_SHORT).show();
                    break;
                case JSON_ERROR:
                    "字符串转换异常", Toast.LENGTH_SHORT).show();
                    break;
            }
        }
    };
(2)在联网版本检查中,需要开启多线程,通过获取manifests中的版本号和版本名,与网上获取的版本号版本名进行比较,再决定是否要更新,规定时间为4s。
/**
     * 获取应用版本名
     *
     * @return 版本号
     */
    private String getVersionName() {

        //创建当前Acitivity包管理对象
        PackageManager pm = getPackageManager();
        try {

            //获取包管理信息的内容
            PackageInfo packageInfo = pm.getPackageInfo(getPackageName(), 0);
            return packageInfo.versionName;
        } catch (PackageManager.NameNotFoundException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 获取版本号
     *
     * @return 版本号,0为异常
     */
    private int getVersionCode() {
        PackageManager pm = getPackageManager();
        try {
            PackageInfo packageInfo = pm.getPackageInfo(getPackageName(), 0);
            return packageInfo.versionCode;
        } catch (PackageManager.NameNotFoundException e) {
            e.printStackTrace();
        }
        return 0;
    }

    private void checkVersion() {
        new Thread() {
            @Override
            public void run() {

                //消息获取
                Message msg = Message.obtain();

                //记录开始的时间
                long startTime = System.currentTimeMillis();
                try {

                    //封装url
                    URL url = new URL("");

                    //开启一个连接
                    HttpsURLConnection connection = (HttpsURLConnection) url.openConnection();

                    connection.setConnectTimeout(2000);
                    connection.setReadTimeout(2000);

                    if (connection.getResponseCode() == 200) {

                        //将数据转换成Json串进行解析
                        InputStream in = connection.getInputStream();
                        String json = StreamUtil.streamToString(in);
                        JSONObject jsonObject = new JSONObject(json);

                        //获取Json对象内容
                        String versionName = jsonObject.getString("versionName");
                        String versionCode = jsonObject.getString("versionCode");
                        mVersionDes = jsonObject.getString("versionDes");
                        mDownUrl = jsonObject.getString("downloadUrl");

                        if (mLocalVersionCode < Integer.parseInt(versionCode)) {
                            msg.what = UPDATE_VERSION;
                        } else {
                            msg.what = ENTER_HOME;
                        }
                    }
                } catch (MalformedURLException e) {
                    e.printStackTrace();
                    msg.what = URL_ERROR;
                } catch (IOException e) {
                    e.printStackTrace();
                    msg.what = IO_ERROR;
                } catch (JSONException e) {
                    e.printStackTrace();
                    msg.what = JSON_ERROR;
                } finally {
                    long endTime = System.currentTimeMillis();
                    if (endTime - startTime < 4000) {
                        try {
                            Thread.sleep(4000 - (endTime - startTime));
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                    }
                    msg.what = ENTER_HOME;
                    mHandle.sendMessage(msg);
                }
            }
        }.start();
    }
5.进入主界面
/**
     * 进入主界面
     */
    private void enterHome() {
        Intent intent = new Intent(this, MainActivity.class);
        startActivity(intent);
        finish();
    }
6.流与字符串的转换
/**
 * 流转换成字符串
 * Created by Sean on 2017/1/21.
 */

public class StreamUtil {

    public static String streamToString(InputStream in) {

        //将读取的内容存储在缓存中,然后再一次性装换成字符串
        ByteArrayOutputStream bos = new ByteArrayOutputStream();

        //读流操作
        byte[] buffer = new byte[1024];
        //记录读取内容的变量
        int temp = -1;
        try {
            while ((temp = in.read(buffer)) != -1) {
                bos.write(buffer, 0, temp);
                return bos.toString();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }
}
7.启动动画,由透明慢慢显示到实色
 private void initAnimation() {
        AlphaAnimation animation = new AlphaAnimation(0, 1);
        animation.setDuration(3000);
        rl_root.setAnimation(animation);
    }

三、效果图以及Github链接

这里写图片描述

https://github.com/codingma/security_guards

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android手机安全卫士是一款应用程序,旨在保护用户的手机安全并提供方便的管理功能。随着智能手机的普及和移动互联网的快速发展,手机安全问题日益受到关注。安全卫士通过防止外来骚扰和方便内部管理来实现其主要功能。对于外部来讲,它可以屏蔽黑名单号码的电话和短信。对于内部来说,用户可以通过安全卫士软件方便地监控和管理手机,例如一键关闭后台应用、流量监控等功能。这样,用户可以获得一个清净安全手机使用体验。安全卫士的开发基于SQLite数据库,SQLite是一种流行的嵌入式数据库,它具有简洁的SQL界面、低内存占用和快速的特点。因此,在Android系统中,所有应用程序都可以使用SQLite数据库来创建和管理数据。安全卫士还涉及到三个主要的软件对象,即用户、开发人员和数据库。用户使用安全卫士进行手机保护和使用,开发人员负责更新和维护系统,数据库负责存储黑名单数据以及通讯录、电话号码归属地等相关信息。通过这些功能和对象,安卓手机安全卫士提供了一套全面的系统,以保护用户手机安全和提供便捷的管理功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [基于J2EE技术和MVC框架的Android手机安全卫士APP设计与实现](https://blog.csdn.net/chuiqi9947/article/details/100672186)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值