2018-08-03 11:22:31 qq_36679384 阅读数 500
  • Android 四大组件之广播 Broadcast

    你的应用可以使用它对外部事件进行过滤只对感兴趣的外部事件(如当电话呼入时,或者数据网络可用时)进行接收并做出响应。广播接收器没有用户界面。然而,它们可以启动一个activity或serice 来响应它们收到的信息,或者用NotificationManager 来通知用户。通知可以用很多种方式来吸引用户的注意力──闪动背灯、震动、播放声音等。一般来说是在状态栏上放一个持久的图标,用户可以打开它并获取消息。

    124 人正在学习 去看看 Frank Lee

关于android启动页启动模式与singleTask

经测试,android 启动页只要启动模式是singleTask,不管你后面进了多少个页面,后面是什么启动模式,就算你把启动页finish掉,按home键退出app,再次进入

android都会重新打开启动页,如果启动页已存在,会走onNewIntent onStart onResume ,不存在则走onCreate onStart onResume,又因为启动页启动模式是singleTask,所以会把同一个栈内的其他acitivity都关掉.

2016-07-18 00:53:12 Preston_zpx 阅读数 730
  • Android 四大组件之广播 Broadcast

    你的应用可以使用它对外部事件进行过滤只对感兴趣的外部事件(如当电话呼入时,或者数据网络可用时)进行接收并做出响应。广播接收器没有用户界面。然而,它们可以启动一个activity或serice 来响应它们收到的信息,或者用NotificationManager 来通知用户。通知可以用很多种方式来吸引用户的注意力──闪动背灯、震动、播放声音等。一般来说是在状态栏上放一个持久的图标,用户可以打开它并获取消息。

    124 人正在学习 去看看 Frank Lee

Android制作引导页和启动页

在手机上打开软件时,如果是第一次使用或者更新后首次使用,会有一个引导页,主要是来说明软件的功能和某些特性;如果不是上述情况,有些软件会有一个启动页,比如打开UC浏览器,会出现有只松鼠的启动页。今天我们就来实现这两个功能。


处理逻辑:判断是否首次打开
1. 首次打开:跳转至引导页面
2. 非首次打开,让启动页面显示若干秒后跳转至主页面


逻辑很简单吧哈哈,逻辑清楚后实现就很容易了~

启动页面:
SplashActivity.java:
-实现跳转逻辑

public class SplashActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //在加载布局文件前判断是否是首次打开
        SharedPreferences appInfo=getSharedPreferences("appInfo",MODE_WORLD_READABLE);
        boolean isFirst=appInfo.getBoolean("isFirst",true);
        if(isFirst){
            SharedPreferences.Editor editor=appInfo.edit();
            editor.putBoolean("isFirst",false);
            editor.commit();
            //首次打开则跳转至引导页面GuideActivity
            Intent intent=new Intent(this,GuideActivity.class);
            startActivity(intent);
            finish();
        }else{
        //非首次打开,让启动页面SplashActivity显示2秒后启动主页面
            setContentView(R.layout.activity_splash);
            Handler handler=new Handler();
            handler.postDelayed(new Runnable(){
                @Override
                public void run(){
                    Intent intent=new Intent(SplashActivity.this,MainActivity.class);
                    startActivity(intent);
                    finish();
                }
            },2000);
        }
    }
}

activity_splash.xml:
-重点在于设置背景图片

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:background="@drawable/android_mirror"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_marginBottom="150dp"
    android:layout_marginLeft="25dp"
    android:layout_marginRight="25dp"
    android:layout_marginTop="150dp"
    tools:context="com.zpreston.homework7_15.SplashActivity">

</RelativeLayout>

引导页面:
GuideActivity.java:
-ViewPager的使用

public class GuideActivity extends Activity implements View.OnClickListener, ViewPager.OnPageChangeListener {
    //ViewPager用来显示每张图片
    private ViewPagerAdapter viewPagerAdapter;
    private ViewPager viewPager;
    private ArrayList<View> views = new ArrayList<View>();
    //引导页显示的图片资源id
    private static final int[] images = {R.drawable.android_mirror, R.drawable.firefox_mirror,
            R.drawable.games_mirror, R.drawable.google_mirror};
    private ImageView[] dots;
    private int currentIndex;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_guide);
        Button start=(Button)findViewById(R.id.start);
        start.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View view){
                startUse();
            }
        });
        //为引导页动态添加布局,每个布局包含一个ImageView
        LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,
                LinearLayout.LayoutParams.WRAP_CONTENT);
        for (int i = 0; i < images.length; i++) {
            ImageView imageView = new ImageView(this);
            imageView.setLayoutParams(params);
            imageView.setImageResource(images[i]);
            views.add(imageView);
        }
        viewPager = (ViewPager) findViewById(R.id.viewPager);
        viewPagerAdapter = new ViewPagerAdapter(views);
        viewPager.setAdapter(viewPagerAdapter);
        viewPager.setOnPageChangeListener(this);
        //底部小圆点的初始化
        initDots();
    }
    //开始使用,进入主页面
    private void startUse(){
        Intent intent=new Intent(GuideActivity.this,MainActivity.class);
        startActivity(intent);
        finish();
    }
    //设置底部小圆点的点击事件以及Tag标志
    private void initDots() {
        LinearLayout linearLayout = (LinearLayout) findViewById(R.id.dotsView);
        dots=new ImageView[images.length];
        for(int i=0;i<images.length;i++){
            dots[i]=(ImageView)linearLayout.getChildAt(i);
            dots[i].setEnabled(true);
            dots[i].setOnClickListener(this);
            dots[i].setTag(i);
        }
        currentIndex=0;
        dots[currentIndex].setEnabled(false);
    }
    //设置当前选中的视图
    private void setCurrentView(int position){
        if(position<0 || position>=images.length){
            return;
        }else{
            viewPager.setCurrentItem(position);
        }
    }
    //设置当前选中的小圆点
    private void setCurrentDot(int position){
        if(position<0 || position>images.length-1 || currentIndex==position){
            return;
        }else{
            dots[position].setEnabled(false);
            dots[currentIndex].setEnabled(true);
            currentIndex=position;
        }
    }
    //获取被点击页的Tag,设置当前选中的视图以及当前选中的小圆点
    @Override
    public void onClick(View view) {
        int position=(Integer)view.getTag();
        setCurrentView(position);
        setCurrentDot(position);
    }

    @Override
    public void onPageScrollStateChanged(int arg0) {

    }

    @Override
    public void onPageScrolled(int arg0, float arg1, int arg2) {

    }
    //选中页的处理操作,设置选中的小圆点
    @Override
    public void onPageSelected(int arg0) {
        setCurrentDot(arg0);
    }
}

ViewPagerAdapter.java:
-ViewPager的适配器

public class ViewPagerAdapter extends PagerAdapter {
    private List<View> views;

    public ViewPagerAdapter(List<View> views){
        this.views=views;
    }

    @Override
    public void destroyItem(View arg0,int arg1,Object arg2){
        ((ViewPager)arg0).removeView(views.get(arg1));
    }

    @Override
    public void finishUpdate(View arg0) {

    }

    @Override
    public int getCount(){
        if(views!=null){
            return views.size();
        }
        else return 0;
    }

    @Override
    public Object instantiateItem(View arg0,int arg1){
        ((ViewPager)arg0).addView(views.get(arg1),0);
        return views.get(arg1);
    }
    @Override
    public boolean isViewFromObject(View arg0, Object arg1){
        return (arg0==arg1);
    }

    @Override
    public Parcelable saveState(){
        return null;
    }

    @Override
    public void startUpdate(View arg0){

    }

}

activity_guide.xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.zpreston.homework7_15.GuideActivity">

    <android.support.v4.view.ViewPager
        android:id="@+id/viewPager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/dotsView"
        android:layout_alignParentBottom="true"
        android:layout_marginBottom="50dp"
        android:orientation="horizontal"
        android:gravity="center_horizontal">

        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/dots_shape"
            android:clickable="true"
            android:layout_margin="5dp"/>
        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/dots_shape"
            android:clickable="true"
            android:layout_margin="5dp"/>
        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/dots_shape"
            android:clickable="true"
            android:layout_margin="5dp"/>
        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/dots_shape"
            android:clickable="true"
            android:layout_margin="5dp"/>

    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center_horizontal"
        android:layout_alignParentBottom="true"
        android:layout_marginTop="25dp">
        <Button
            android:id="@+id/start"
            android:layout_width="150dp"
            android:layout_height="40dp"
            android:background="@color/colorPowerBlue"
            android:textColor="#FFFFFF"
            android:textSize="25sp"
            android:text="开始体验"/>
    </LinearLayout>

</RelativeLayout>
2019-04-09 16:31:10 zhf6751134 阅读数 188
  • Android 四大组件之广播 Broadcast

    你的应用可以使用它对外部事件进行过滤只对感兴趣的外部事件(如当电话呼入时,或者数据网络可用时)进行接收并做出响应。广播接收器没有用户界面。然而,它们可以启动一个activity或serice 来响应它们收到的信息,或者用NotificationManager 来通知用户。通知可以用很多种方式来吸引用户的注意力──闪动背灯、震动、播放声音等。一般来说是在状态栏上放一个持久的图标,用户可以打开它并获取消息。

    124 人正在学习 去看看 Frank Lee

Android启动页设置启动模式为 singleTask

经测试,Android 启动页只要启动模式是singleTask,不管你后面进了多少个页面,后面是什么启动模式,就算你把启动页finish掉,按home键退出app,再次进入.

android都会重新打开启动页,
如果启动页已存在,会走onNewIntent onStart onResume ,
不存在则走onCreate onStart onResume,
又因为启动页启动模式是singleTask,
所以会把同一个栈内的其他acitivity都关掉.

2017-09-19 11:13:39 gxp1182893781 阅读数 6779
  • Android 四大组件之广播 Broadcast

    你的应用可以使用它对外部事件进行过滤只对感兴趣的外部事件(如当电话呼入时,或者数据网络可用时)进行接收并做出响应。广播接收器没有用户界面。然而,它们可以启动一个activity或serice 来响应它们收到的信息,或者用NotificationManager 来通知用户。通知可以用很多种方式来吸引用户的注意力──闪动背灯、震动、播放声音等。一般来说是在状态栏上放一个持久的图标,用户可以打开它并获取消息。

    124 人正在学习 去看看 Frank Lee

由于Linux的开源,市面上出现了很多定制的Android系统,这写系统有的将Android原生系统改的面目全非,很多方法不能同时在所有机型上适用,这是问题的一大难点。


项目中遇见了一个问题,我用JPush SDK推送消息,但是如果服务被关闭,将无法及时接收消息。这样也就没有起到应有的效果。所以我想让我的app接收系统广播,每次接收到Intent.ACTION_TIME_TICK这个广播我就去检查服务是否被关闭。可是这样就要面对另外一个问题:当用户使用第三方清理软件清理系统后,我的app就被标记为了stopped状态,无法再接收到系统广播,解决方法我倒是有一个,那就是让用户把我的app添加进自启动白名单里面,这样手机就能够接收系统广播了。当然你也可以把app安装进系统目录,这样就能像系统app一样接收系统广播了,但是我们不是流氓软件,所以我们没打算这样做。


这就需要我们拉起系统自启动设置页面,下面给出代码:

public class OpenAutoStartUtil {
    /**
     * Get Mobile Type
     *
     * @return
     */
    private static String getMobileType() {
        return Build.MANUFACTURER;
    }

    /**
     * GoTo Open Self Setting Layout
     * Compatible Mainstream Models 兼容市面主流机型
     *
     * @param context
     */
    public static void jumpStartInterface(Context context) {
        Intent intent = new Intent();
        try {
            intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            Log.e("HLQ_Struggle", "******************当前手机型号为:" + getMobileType());
            ComponentName componentName = null;
            if (getMobileType().equals("Xiaomi")) { // 红米Note4测试通过
                componentName = new ComponentName("com.miui.securitycenter",
                        "com.miui.permcenter.autostart.AutoStartManagementActivity");
            } else if (getMobileType().equals("Letv")) { // 乐视2测试通过
                intent.setAction("com.letv.android.permissionautoboot");
            } else if (getMobileType().equals("samsung")) { // 三星Note5测试通过
                componentName = new ComponentName("com.samsung.android.sm_cn",
                        "com.samsung.android.sm.ui.ram.AutoRunActivity");
            } else if (getMobileType().equals("HUAWEI")) { // 华为测试通过
                componentName = new ComponentName("com.huawei.systemmanager",
                        "com.huawei.systemmanager.optimize.process.ProtectActivity");
            } else if (getMobileType().equals("vivo")) { // VIVO测试通过
                componentName = ComponentName.unflattenFromString("com.iqoo.secure" +
                        "/.safeguard.PurviewTabActivity");
            } else if (getMobileType().equals("Meizu")) { //万恶的魅族
                // 通过测试,发现魅族是真恶心,也是够了,之前版本还能查看到关于设置自启动这一界面,
                // 系统更新之后,完全找不到了,心里默默Fuck                // 针对魅族,我们只能通过魅族内置手机管家去设置自启动,
                // 所以我在这里直接跳转到魅族内置手机管家界面,具体结果请看图
                componentName = ComponentName.unflattenFromString("com.meizu.safe" +
                        "/.permission.PermissionMainActivity");
            } else if (getMobileType().equals("OPPO")) { // OPPO R8205测试通过
                componentName = ComponentName.unflattenFromString("com.oppo.safe" +
                        "/.permission.startup.StartupAppListActivity");
                Intent intentOppo = new Intent();
                intentOppo.setClassName("com.oppo.safe/.permission.startup",
                        "StartupAppListActivity");
                if (context.getPackageManager().resolveActivity(intentOppo, 0) == null) {
                    componentName = ComponentName.unflattenFromString("com.coloros.safecenter" +
                            "/.startupapp.StartupAppListActivity");
                }

            } else if (getMobileType().equals("ulong")) { // 360手机 未测试
                componentName = new ComponentName("com.yulong.android.coolsafe",
                        ".ui.activity.autorun.AutoRunListActivity");
            } else {             
                // 以上只是市面上主流机型,由于公司你懂的,所以很不容易才凑齐以上设备
                // 针对于其他设备,我们只能调整当前系统app查看详情界面
                // 在此根据用户手机当前版本跳转系统设置界面
                if (Build.VERSION.SDK_INT >= 9) {
                    intent.setAction("android.settings.APPLICATION_DETAILS_SETTINGS");
                    intent.setData(Uri.fromParts("package", context.getPackageName(), null));
                } else if (Build.VERSION.SDK_INT <= 8) {
                    intent.setAction(Intent.ACTION_VIEW);
                    intent.setClassName("com.android.settings",
                            "com.android.settings.InstalledAppDetails");
                    intent.putExtra("com.android.settings.ApplicationPkgName",
                            context.getPackageName());
                }
            }
            intent.setComponent(componentName);
            context.startActivity(intent);
        } catch (Exception e) {//抛出异常就直接打开设置页面
            intent = new Intent(Settings.ACTION_SETTINGS);
            context.startActivity(intent);
        }
    }
}

这样的方法我们可以适配市面上大部分手机了。

本来我是想过用代码将自己的app设置为开机自启动,但是从网络上找了很多方法,最后还是没有成功,希望有这方面经验的大神不吝赐教,拜谢!


想到我们打开软件的时候就应该判断我们的app是否已经被允许自启动了,我又遇见了一个难题,至今未能解决。怎么样才能像手机安全卫士一样获取到有哪些应用被允许自启动了呢?网上有人说看是否有开机启动权限,不可行,因为有权限也不能保证开机启动,因为用户如果禁止了,你的权限就不起作用了。还有看到一个大神的方法,记得好像是获取自启动的状态,但是不管用户允许了自启动还是禁止了,其状态都是0(默认),这方法也不可行。有哪位大神知道的话,还请告知,拜谢!




2018-06-13 11:59:33 csdnzouqi 阅读数 3872
  • Android 四大组件之广播 Broadcast

    你的应用可以使用它对外部事件进行过滤只对感兴趣的外部事件(如当电话呼入时,或者数据网络可用时)进行接收并做出响应。广播接收器没有用户界面。然而,它们可以启动一个activity或serice 来响应它们收到的信息,或者用NotificationManager 来通知用户。通知可以用很多种方式来吸引用户的注意力──闪动背灯、震动、播放声音等。一般来说是在状态栏上放一个持久的图标,用户可以打开它并获取消息。

    124 人正在学习 去看看 Frank Lee

背景

只要是一个app,每次打开的时候会显示启动页面,然后再进入主界面。下面看几个app的启动页展示:

这里写图片描述

这里写图片描述

这里写图片描述


我的思路

  • 启动页面肯定是要打开就显示的,然后用一个Activity展示。界面可以是一张设计好的图片,然后在xml布局文件中展示,充满全屏。当然也可以不用图片,可以自己设计包含简单显示控件(比如文本控件、图片控件等)的布局。
  • 在onCreate方法中调用handler的sendEmptyMessageDelayed方法,发送延迟消息,自己设置启动页面展示的时间长短,一般是3000ms,然后从启动页面跳转其他页面。

代码实现

package com.example.administrator.firststeppro.activity;

import android.app.ActionBar;
import android.app.Activity;
import android.content.Intent;
import android.graphics.Color;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;

import com.example.administrator.firststeppro.R;

/**
 * 启动页面
 */
public class SplashActivity extends Activity {

    private static final int WHAT_DELAY = 0x11;// 启动页的延时跳转
    private static final int DELAY_TIME = 3000;// 延时时间

    // 创建Handler对象,处理接收的消息
    private Handler handler = new Handler(){
        @Override
        public void handleMessage(Message msg) {
            switch (msg.what){
                case WHAT_DELAY:// 延时3秒跳转
                    goHome();
                    break;
            }
        }
    };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_splash);
        // 调用handler的sendEmptyMessageDelayed方法
        handler.sendEmptyMessageDelayed(WHAT_DELAY, DELAY_TIME);
    }

    /**
     * 跳转到主页面
     */
    private void goHome() {
        startActivity(new Intent(SplashActivity.this, MainActivity.class));
        finish();// 销毁当前活动界面
    }
}
  • 做一下简单的说明。handler.sendEmptyMessageDelayed(WHAT_DELAY,
    DELAY_TIME);
    方法中第一个参数类型是int,表示是什么消息;第二个参数的类型是long,表示消息发送延迟时间。

我的启动页展示

这里写图片描述


A little bit of progress every day!Come on!

Android 启动页优化

阅读数 270

Android_启动页

阅读数 96

没有更多推荐了,返回首页