Activity 样式的妙用

这个是第一版的登录页面设计图,拿到设计后开开心心写程序,很快上线了。
![Uploading 2_861250.jpg . . .]](http://upload-images.jianshu.io/upload_images/1187237-ff2766567b2f298c.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
但是老板不满意,于是设计师又设计了第二版。

Activity 样式的妙用_第1张图片
2.jpg

旧版的登录页是个原生的Activity,现在不就变成了个dialog嘛。我是老司机了,就这个dialog样式我起码能用5种不同的方式来实现,小case。

Dialog

于是又开开心心写程序,先修改好布局。PopupWindow的实现方式直接pass,原因不说了,不就一Dialog嘛,那我就写个登录的Dialog呗,哪里需要哪里show().

public class LoginDialog extends Dialog{

 public LoginDialog(Context context) {
  super(context);
  // TODO Auto-generated constructor stub
 }
}

于是噼里啪啦开始写,但是Google推荐使用DialogFragment,老司机是不是也应该走走新路了,于是撤了,改用DialogFragment。

DialogFragment

public class LoginDialog extends DialogFragment{

@Override  
    public View onCreateView(LayoutInflater inflater, ViewGroup container,  
            Bundle savedInstanceState)  
    {  
        View view = inflater.inflate(R.layout.login_layout, container);  
        return view;  
    }  
}

写啊写,把以前Activity里的逻辑挪到Fragment里,工作量也不很大。很快搞定,运行看看效果还可以,试试功能,Facebook怎么登录失败了,微信也失败了,小米还是失败,各种失败。但是我也没做什么改动啊。DialogFragment引起了一些问题,主要是context各种为null,onActivityResult()各种拿不到回调等bug,Fragment就这点不好,坑太多。现在摆在面前的有两条路,第一去修这些bug,第二寻求新的实现方式。要不再换回Dialog?但是Dialog也不是个省油灯,要是能有个Activity就好了,就什么Bug都没有了。对,我就是需要个Activity嘛。

我就是想要个Activity嘛

我就是想要个activity嘛?那你干嘛不早说嘛?什么样的activity满足需求呢,透明的呗。对,我要个透明的Activity,中间有个对话框,那不就是Dialog样式的Activity嘛。修改AndroidManifest文件中Activity的样式即可。



然后登陆页的Activity还是那个Activity,一行代码没修改,只修改了下布局和Activity style,就完成了这次“重大”改版。效果如下。

Activity 样式的妙用_第2张图片
7.pic_hd.jpg

如果弹出框只是作为显示或者警告等提示用,那么就无所谓哪种方式了,都可以。但如果弹出框里有很多操作,相对来说还是Dialog样式的Activity会更好控制些,毕竟Activity才是最可靠的容器。所以选择远比努力重要,一套合理的实现方案可以事半功倍,而一套不合理的实现方案可能让你深陷bug泥潭,无法自拔。

你可能感兴趣的:(Activity 样式的妙用)