Android中Dialog与DialogFragment的对比

最近学习对话框时发现有两种类型的可供使用,一种是Dialog,另一种则是Android 3.0 引入的基于Fragment的DialogFragment。

从代码的编写角度看,Dialog使用起来要更为简单,但是Google则是推荐尽量使用DialogFragment(对于Android 3.0以下的版本,可以结合使用support包中提供的DialogFragment以及FragmentActivity)。今天试着用这两种方式来创建对话框,发现DialogFragment果然有一个非常好的特性(在手机配置变化,导致Activity需要重新创建时,例如旋屏,基于DialogFragment的对话框将会由FragmentManager自动重建,然而基于Dialog实现的对话框则没有这样的能力)。

下面是两段实例代码:

他们使用的界面都一样:(dialog.xml)

01 <?xml version="1.0" encoding="utf-8"?>
02 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
03     android:layout_width="match_parent"
04     android:layout_height="match_parent"
05     android:orientation="vertical" >
06  
07     <ImageView
08         android:layout_width="wrap_content"
09         android:layout_height="wrap_content"
10         android:src="@drawable/ic_launcher" />
11  
12 </LinearLayout>

1.基于Dialog实现的对话框

01 public class MainActivity extends Activity {
02     private Button clk;
03     private Dialog dialog;
04     @Override
05     protected void onCreate(Bundle savedInstanceState) {
06         super.onCreate(savedInstanceState);
07         setContentView(R.layout.activity_main);
08          
09         clk = (Button) findViewById(R.id.clk);
10         dialog = new Dialog(this);
11         dialog.setContentView(R.layout.dialog);
12         clk.setOnClickListener(new OnClickListener() {
13              
14             @Override
15             public void onClick(View v) {
16                 dialog.show();
17             }
18         });
19     }
20 }



当我们点击按钮时,会弹出对话框(内容为android logo),当我们旋转屏幕后,Activity重新创建,整个Activity的界面没有问题,而对话框消失了。

除此之外,其实还有一个问题,就是在logcat中会看到异常信息:Android..leaked .. window,这是因为在Activity结束之前,Android要求所有的Dialog必须要关闭。我们旋屏后,Activity会被重建,而上面的代码逻辑并没有考虑到对话框的状态以及是否已关闭。

于是将上述代码修改为:

01 public class MainActivity extends Activity {
02     private Button clk;
03     private Dialog dialog;
04     @Override
05     protected void onCreate(Bundle savedInstanceState) {
06         super.onCreate(savedInstanceState);
07         setContentView(R.layout.activity_main);
08          
09         clk = (Button) findViewById(R.id.clk);
10         dialog = new Dialog(this);
11         dialog.setContentView(R.layout.dialog);
12         clk.setOnClickListener(new OnClickListener() {
13              
14             @Override
15             public void onClick(View v) {
16                 dialog.show();
17             }
18         });
19  
20         //用户恢复对话框的状态
21         if(savedInstanceState != null && savedInstanceState.getBoolean("dialog_show"))
22             clk.performClick();
23     }
24  
25     /**
26      * 用于保存对话框的状态以便恢复
27      */
28     @Override
29     protected void onSaveInstanceState(Bundle outState) {
30         super.onSaveInstanceState(outState);
31         if(dialog != null && dialog.isShowing())
32             outState.putBoolean("dialog_show"true);
33         else
34             outState.putBoolean("dialog_show"false);
35     }
36  
37     /**
38      * 在Activity销毁之前,确保对话框以关闭
39      */
40     @Override
41     protected void onDestroy() {
42         super.onDestroy();
43         if(dialog != null && dialog.isShowing())
44             dialog.dismiss();
45     }
46 }



2. 基于DialogFragment的对话框

与上面的对话框使用同样的界面布局,此处仅仅展现一个简单对话框,因此只重写了onCreateView方法

1 public class MyDialogFragment extends DialogFragment {
2     @Override
3     public View onCreateView(LayoutInflater inflater, ViewGroup container,
4             Bundle savedInstanceState) {
5         View v = inflater.inflate(R.layout.dialog, container, false);
6         return v;
7     }
8 }



01 public class MainActivity extends FragmentActivity {
02     private Button clk;
03     @Override
04     protected void onCreate(Bundle savedInstanceState) {
05         super.onCreate(savedInstanceState);
06         setContentView(R.layout.activity_main);
07          
08         clk = (Button) findViewById(R.id.clk);
09         clk.setOnClickListener(new OnClickListener() {
10              
11             @Override
12             public void onClick(View v) {
13                 MyDialogFragment mdf = new MyDialogFragment();
14                 FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
15                 ft.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_FADE);
16                 mdf.show(ft, "df");
17             }
18         });
19     }
20 }



这两段代码可以实现第一种方式的同样功能,此处我们并没有去关心对话框的重建,以及Activity销毁前对话框是否已关闭,这一切都是由FragmentManager来管理。

其实DialogFragment还拥有fragment的优点,即可以在一个Activity内部实现回退(因为FragmentManager会管理一个回退栈)

转自:http://my.oschina.net/fengheju/blog/179218

<think>好的,我现在要解决用户关于荣耀7x手机的BL锁状态和解锁方法的问题。首先,我需要回忆一下之前提供的引用内容,看看是否有相关信息。根据引用[1],荣耀7x(BND-TL10移动版)在BL解锁后,系统升级到最新版会重新上锁,所以需要在fastboot模式下重新解锁,使用命令fastboot oem unlock <解锁码>。而引用[2]提到华为荣耀5X的解锁步骤,需要先获取解锁码,然后在fastboot模式下解锁。虽然型号不同,但流程可能类似。 接下来,我需要确认荣耀7x的BL锁状态。根据引用[1],系统升级后可能会重新上锁,这说明默认情况下BL可能是锁定的。用户可能需要先检查当前状态,可以通过进入fastboot模式查看是否显示“PHONE Locked”类似信息。 解锁步骤方面,用户需要先申请解锁码。华为和荣耀手机通常需要在官网提交申请,可能需要设备信息如IMEI、产品型号等。然后进入fastboot模式,连接电脑,使用ADB工具执行解锁命令。但需要注意,解锁后升级系统可能导致重新上锁,需要再次解锁。 此外,用户可能需要第三方资源,如TWRP recoveryLineageOS GSI,但需要确保解锁后才能刷入。同时,解锁会清除数据,需提前备份。还要注意不同型号可能有差异,确认具体型号如BND-TL10是否正确。 最后,生成相关问题时要围绕BL解锁后的操作、风险、重新上锁后的处理,以及具体型号的注意事项。确保回答结构清晰,步骤详细,并引用提供的资料支持。</think>### 荣耀7x Bootloader锁状态及解锁方法 #### 1. **Bootloader锁状态** - 荣耀7x(型号如BND-TL10)默认情况下**Bootloader是锁定的**,这是华为/荣耀设备的常见安全策略。 - **系统升级影响**:若设备已解锁BL,但后续通过官方系统升级(如EMUI更新),**Bootloader可能会被重新上锁**[^1]。此时需要重新执行解锁流程。 --- #### 2. **解锁步骤** **步骤1:获取解锁码** - 访问华为官方解锁码申请页面(需注册华为开发者账号)。 - 提交设备信息:IMEI(拨号盘输入`*#06#`获取)、产品型号(设置-关于手机中查看)等。 **步骤2:启用开发者选项** - 进入手机设置-关于手机,连续点击“版本号”7次,激活开发者选项。 - 在开发者选项中启用“OEM解锁”和“USB调试”。 **步骤3:进入Fastboot模式** - 手机关机后,按住**音量下键 + 电源键**进入Fastboot模式(屏幕显示“Fastboot”“Phone Locked”)。 **步骤4:执行解锁命令** - 连接电脑,确保已安装ADB和Fastboot驱动。 - 在命令提示符终端输入: ```bash fastboot oem unlock <你的解锁码> ``` - 成功后会提示“Unlock Bootloader Success”,设备将自动重启并清除所有数据(**需提前备份**)。 --- #### 3. **注意事项** - **重新上锁风险**:官方系统升级后可能重新锁定BL,需重复上述步骤解锁[^1]。 - **第三方资源兼容性**:刷入LineageOS等GSI系统时,需确认适配型号(如BND-TL10)并严格遵循教程。 - **驱动问题**:若Fastboot模式下电脑无法识别设备,需检查驱动程序(如华为HiSuite第三方工具)[^2]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值