android开发我的新浪微博客户端-登录页面功能篇

2024-06-18 01:58

本文主要是介绍android开发我的新浪微博客户端-登录页面功能篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文地址: http://www.cnblogs.com/hll2008/archive/2011/01/17/1935396.html


 

     上一篇中完成了如上图的UI部分的实现,现在继续来讲功能的实现,用户登录操作主要就是账号列表显示和选择账号登录两个功能其他的都是些简单的辅助功能,首先是点击id为iconSelectBtn的ImageButton时显示用户选择窗口,这个时候去数据库中获取账号记录然后在选择窗口中以列表方式显示出来,通过上一篇已经知道Id为list的ListView控件来显示账号列表,首先是从数据库中获取所有的账户记录然后设置默认选中的用户账号代码如下:

复制代码
代码
private   void  initUser(){
        
// 获取账号列表
        dbHelper = new  DataHelper( this );
        userList 
=  dbHelper.GetUserList( false );
        
if (userList.isEmpty())
        {
            Intent intent 
=   new  Intent();
            intent.setClass(LoginActivity.
this , AuthorizeActivity. class );
            startActivity(intent);
        }
        
else
        {
            SharedPreferences preferences 
=  getSharedPreferences(Select_Name, Activity.MODE_PRIVATE);
            String str
=  preferences.getString( " name " "" );
            UserInfo user
= null ;
            
if (str != "" )
            {
                user
= GetUserByName(str);
            }
            
if (user == null )
            {
                user
= userList.get( 0 );
            }
            icon.setImageDrawable(user.getUserIcon());
            iconSelect.setText(user.getUserName());
        }
    }
复制代码

       这个initUser() 初始账号的方法在LoginActivity的onCreate中调用,主要完成两件事情,第一件获取通过userList = dbHelper.GetUserList(false);获取所有的账户记录,关于DataHelper前面已经有说过了,如果获取的用户记录为空那么就跳转到用户授权功能页面让用户添加账号,如果不为空那么通过SharedPreferences去读取用户上一次选择的账号名称,如果没有或者数据库里账号记录不包括这个账户名称那么默认显示记录的第一个账号和头像,如果有那么显示这个账户的名称和头像。关于SharedPreferences,是android提供给开发者用来存储一些简单的数据用的,非常方便类似于网站的Cookie,在这里我就是用这个来保存上一次用户选择的是哪个账号,非常实用。

     接下类首先为Id为list的ListView控件准备数据Adapter,这个Adapter非常简单就是普通的adapter继承BaseAdapter即可,代码如下:代码

复制代码
public   class  UserAdapater  extends  BaseAdapter{

        @Override
        
public   int  getCount() {
            
return  userList.size();
        }

        @Override
        
public  Object getItem( int  position) {
            
return  userList.get(position);
        }

        @Override
        
public   long  getItemId( int  position) {
            
return  position;
        }

        @Override
        
public  View getView( int  position, View convertView, ViewGroup parent) {
            convertView 
=  LayoutInflater.from(getApplicationContext()).inflate(R.layout.item_user,  null );

            ImageView iv 
=  (ImageView) convertView.findViewById(R.id.iconImg);
            TextView tv 
=  (TextView) convertView.findViewById(R.id.showName);
            UserInfo user 
=  userList.get(position);
            
try  {
                
// 设置图片显示
                iv.setImageDrawable(user.getUserIcon());
                
// 设置信息
                tv.setText(user.getUserName());

                
            } 
catch  (Exception e) {
                e.printStackTrace();
            }
            
return  convertView;
        }
复制代码

 

接下就是为这个ListView设定数据源Adapter,在账号选择窗口显示的时候进行设置,添加到id为iconSelectBtn的ImageButton的OnClickListener中代码如下:代码

复制代码
ImageButton iconSelectBtn = (ImageButton)findViewById(R.id.iconSelectBtn);
iconSelectBtn.setOnClickListener(
new  OnClickListener(){
            @Override
            
public   void  onClick(View v) {
                ......
                dialog.show();
                
                UserAdapater adapater 
=   new  UserAdapater();
                ListView listview
= (ListView)diaView.findViewById(R.id.list);
                listview.setVerticalScrollBarEnabled(
false ); //  ListView去掉下拉条
                listview.setAdapter(adapater);
                listview.setOnItemClickListener(
new  OnItemClickListener(){
                    @Override
                    
public   void  onItemClick(AdapterView <?>  arg0, View view, int  arg2,  long  arg3) {
                        TextView tv
= (TextView)view.findViewById(R.id.showName);
                        iconSelect.setText(tv.getText());
                        ImageView iv
= (ImageView)view.findViewById(R.id.iconImg);
                        icon.setImageDrawable(iv.getDrawable());
                        dialog.dismiss();
                    }
                    
                });
            }
            
        });
复制代码

通过上面代码完成了账号选择的功能,接下来给id为login的ImageButton添加OnClickListener,使得点击后以当前选择账号进入微博首页,代码如下:

复制代码
代码
@Override
    
public   void  onCreate(Bundle savedInstanceState) {
        
super .onCreate(savedInstanceState);
        setContentView(R.layout.login);
        ......
        ImageButton login
= (ImageButton)findViewById(R.id.login);
        login.setOnClickListener(
new  OnClickListener(){
            @Override
            
public   void  onClick(View v) {
                GoHome();
            }
            
        });
}

// 进入用户首页
private   void  GoHome(){
        
if (userList != null )
        {
            String name
= iconSelect.getText().toString();
            UserInfo u
= GetUserByName(name);
            
if (u != null )
            {
                ConfigHelper.nowUser
= u; // 获取当前选择的用户并且保存
            }
        }
        
if (ConfigHelper.nowUser != null )
        {
                        
// 进入用户首页
            Intent intent  =   new  Intent();
                    intent.setClass(LoginActivity.
this , HomeActivity. class );
                    startActivity(intent);
        }
    }
复制代码

 

在上面的GoHome方法中ConfigHelper.nowUser是类型为UserInfo的static类型用来保存当前登录账号的信息,替代web中session使用。

最后添加如下方法,用来当这个登录LoginActivity结束的时候保存当前选择的账户名称到SharedPreferences中,以便帮用户记住登录账号的功能,就是前面的initUser() 初始账号的方法中会获取保存在SharedPreferences中的账户名称,代码如下:

复制代码
代码
@Override
    
protected   void  onStop() {
        
// 获得SharedPreferences对象
        SharedPreferences MyPreferences  =  getSharedPreferences(Select_Name, Activity.MODE_PRIVATE);
        
// 获得SharedPreferences.Editor对象
        SharedPreferences.Editor editor  =  MyPreferences.edit();
        
// 保存组件中的值
        editor.putString( " name " , iconSelect.getText().toString());
        editor.commit();
        
super .onStop();
    }
复制代码

 

至此登录页面功能篇结束,请继续关注下一篇。 

这篇关于android开发我的新浪微博客户端-登录页面功能篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1070984

相关文章

JAVA读取MongoDB中的二进制图片并显示在页面上

1:Jsp页面: <td><img src="${ctx}/mongoImg/show"></td> 2:xml配置: <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001

JavaScript全屏,监听页面是否全屏

在JavaScript中,直接监听浏览器是否进入全屏模式并不直接支持,因为全屏API主要是关于请求和退出全屏模式的,而没有直接的监听器可以告知页面何时进入或退出全屏模式。但是,你可以通过在你的代码中跟踪全屏状态的改变来模拟这个功能。 以下是一个基本的示例,展示了如何使用全屏API来请求全屏模式,并在请求成功或失败时更新一个状态变量: javascriptlet isInFullscreen =

Eclipse+ADT与Android Studio开发的区别

下文的EA指Eclipse+ADT,AS就是指Android Studio。 就编写界面布局来说AS可以边开发边预览(所见即所得,以及多个屏幕预览),这个优势比较大。AS运行时占的内存比EA的要小。AS创建项目时要创建gradle项目框架,so,创建项目时AS比较慢。android studio基于gradle构建项目,你无法同时集中管理和维护多个项目的源码,而eclipse ADT可以同时打开

android 免费短信验证功能

没有太复杂的使用的话,功能实现比较简单粗暴。 在www.mob.com网站中可以申请使用免费短信验证功能。 步骤: 1.注册登录。 2.选择“短信验证码SDK” 3.下载对应的sdk包,我这是选studio的。 4.从头像那进入后台并创建短信验证应用,获取到key跟secret 5.根据技术文档操作(initSDK方法写在setContentView上面) 6.关键:在有用到的Mo

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

Android我的二维码扫描功能发展史(完整)

最近在研究下二维码扫描功能,跟据从网上查阅的资料到自己勉强已实现扫描功能来一一介绍我的二维码扫描功能实现的发展历程: 首页通过网络搜索发现做android二维码扫描功能看去都是基于google的ZXing项目开发。 2、搜索怎么使用ZXing实现自己的二维码扫描:从网上下载ZXing-2.2.zip以及core-2.2-source.jar文件,分别解压两个文件。然后把.jar解压出来的整个c

android 带与不带logo的二维码生成

该代码基于ZXing项目,这个网上能下载得到。 定义的控件以及属性: public static final int SCAN_CODE = 1;private ImageView iv;private EditText et;private Button qr_btn,add_logo;private Bitmap logo,bitmap,bmp; //logo图标private st

Android多线程下载见解

通过for循环开启N个线程,这是多线程,但每次循环都new一个线程肯定很耗内存的。那可以改用线程池来。 就以我个人对多线程下载的理解是开启一个线程后: 1.通过HttpUrlConnection对象获取要下载文件的总长度 2.通过RandomAccessFile流对象在本地创建一个跟远程文件长度一样大小的空文件。 3.通过文件总长度/线程个数=得到每个线程大概要下载的量(线程块大小)。

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在

vue+elementui分页输入框回车与页面中@keyup.enter事件冲突解决

解决这个问题的思路只要判断事件源是哪个就好。el分页的回车触发事件是在按下时,抬起并不会再触发。而keyup.enter事件是在抬起时触发。 so,找不到分页的回车事件那就拿keyup.enter事件搞事情。只要判断这个抬起事件的$event中的锚点样式判断不等于分页特有的样式就可以了 @keyup.enter="allKeyup($event)" //页面上的//js中allKeyup(e