Android进阶(二十三)Android开发过程之实例讲解

Android开发过程之实例讲解

前言

     回过头来审视之前做过的Android项目,发觉自己重新开发时忽然间不知所措了,间隔了太长时间没有开发导致自己的Android技能知识急剧下降。温故而知新。

     废话少说,进入正题~

     下面主要以自己之前开发过的Android小项目为例,探讨Android开发基本流程,以及其中所涉及到的原理。

      项目名称为“我查查”,主要的实现功能是查询、添加商品评价,分享购物体验。

     主要界面如下:

 

图1 主功能界面

 

图2 查看商品信息

图3 添加新评论

 

图4 扫码操作

 

图5 查看最新分享

 

图6 添加商品信息

 

图7 用户注册

 

图8 当前用户状态

      新建一个Android项目时,在AndroidManifest.xml配置文件中可设置应用名称、应用权限以及配置四大组件,各节点配置可参考网络上其它文献。

 

      至此,应用入口确定,为WelcomeActivity,进入WelcomActivity,代码如下:

 

 
package org.wokankan; import java.util.TimerTask; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.os.Handler; import android.os.HandlerThread; import android.os.Message; import android.view.Window; public class WelcomeActivity extends Activity { protected static final int LOGINOVER = 0; protected static final String TAG = "Welcome"; private Handler handler; //因为要重写构造方法,所以不能用匿名内部类 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 设置登录无标题栏 requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.welcome); HandlerThread myThread = new HandlerThread("myHandlerThread"); myThread.start(); handler = new Handler(){ @Override public void handleMessage(Message msg) { if(msg.what == LOGINOVER){ // 页面跳转 Intent intent = new Intent(WelcomeActivity.this, MainActivity.class); startActivity(intent); WelcomeActivity.this.finish(); } } }; tt.run(); } TimerTask tt = new TimerTask() { @Override public void run() { //Log.i(TAG, Thread.currentThread().getName()); // 设置3s后跳转到MainActivity handler.sendMessageDelayed(handler.obtainMessage(LOGINOVER), 3000); } }; }

      在运行时,再次出现了令人烦恼的字符集编码问题,中文字符写入数据库时全部为问号。如下图所示。

 

      问题出在写入数据库时,写入之前中文字符正常显示,写入后变为乱码。为此需要设置数据库的编码方式。

     根据前面的问题解决方式,在mysql中直接以sql语句的形式进行测试,测试语句如下:

     insert into product(barcode,product_name,guige,changjia,xinghao,imguri,qrbarcode_uri) values("123","测试","12","中国","","","");

      执行时,果然出现了问题。错误提示如下:

 

      按照之前解决问题的思路,总结如下:

      要想实现中文字符插入数据库中时不出现乱码现象需满足如下条件:

     在连接数据库时需指定编码方式,示例如下:

      jdbc:mysql://localhost:3308/lmapp?useUnicode=true&characterEncoding=utf8

      后面的编码方式指定尤为重要。

 

参考文献

     1.http://www.cnblogs.com/pilang/archive/2011/04/20/2022932.html

     2.http://blog.csdn.net/sunhuaqiang1/article/details/51444018

      3.http://blog.csdn.net/sunhuaqiang1/article/details/51644645

美文美图

 

 

©️2020 CSDN 皮肤主题: 撸撸猫 设计师:设计师小姐姐 返回首页