Android Spinner实现省市区三级联动程序代码

 更新时间:2016年9月20日 19:59  点击:1373
本文章来给各位同学介绍一个关于Android Spinner实现省市区三级联动程序代码,有兴趣的同学可进入参考。

省市区三级联动,采用的是sqlite本地数据库,需要使用SimpleCursorAdapter类来配合下拉列表Spinner实现。关于Spinner和SimpleCursorAdapter的组合请看,

Android使用SimpleCursorAdapter填充下拉列表Spinner用法

先贴上Spinner和SimpleCursorAdapter整合的代码:

 代码如下 复制代码

Cursor c = getContentResolver().query(Table.Region.CONTENT_URI, null, Table.Region.PARENT_ID+"="+parentRegionId, null, Table.Region._ID +" asc");
final String[] columns = new String[] { Table.Region.REGION_NAME };
final int[] to = new int[] { android.R.id.text1 };

SimpleCursorAdapter mAdapter = new SimpleCursorAdapter(this, android.R.layout.simple_spinner_item, c, columns, to);
mAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
view.setAdapter(mAdapter);

下面我们再来看至于省份城市地区三级联动效果

三级联动实现原理:用户选择省份后,根据省份Id加载对应的城市列表,由于Spinner默认选择第一项,即城市列表加载完后,又会加载对应的地区列表信息。

使用Spinner的OnItemSelectedListener监听器类实现三级联动:

 代码如下 复制代码

//加载省份
updateRegionInfo(spinner_province, 1);

spinner_province.setOnItemSelectedListener(new OnItemSelectedListener() {
    @Override
    public void onItemSelected(AdapterView<?> parent, View view,
            int position, long id) {
        //加载下一级(城市)
        Cursor selectedCursor = (Cursor) parent.getSelectedItem();
        updateRegionInfo(spinner_city, CursorUtil.getInt(selectedCursor, Table.Region.REGION_ID));
    }

    @Override
    public void onNothingSelected(AdapterView<?> parent) {
       
    }
});
spinner_city.setOnItemSelectedListener(new OnItemSelectedListener() {
    @Override
    public void onItemSelected(AdapterView<?> parent, View view,
            int position, long id) {
        //加载下一级(地区)
        Cursor selectedCursor = (Cursor) parent.getSelectedItem();
        updateRegionInfo(spinner_district, CursorUtil.getInt(selectedCursor, Table.Region.REGION_ID));
    }
   
    @Override
    public void onNothingSelected(AdapterView<?> parent) {
    }
});


使用SimpleCursorAdapter绑定Sqlite数据库到Spinner

 代码如下 复制代码


private void updateRegionInfo(Spinner view, int parentRegionId) {
    final ListAdapter adapter = (ListAdapter) view.getAdapter();
    if(null != adapter && adapter instanceof CursorAdapter) {
        final CursorAdapter cursorAdapter = (CursorAdapter) adapter;
        cursorAdapter.changeCursor(null);
        view.setAdapter(null);
    }
   
    Cursor c = getContentResolver().query(Table.Region.CONTENT_URI, null, Table.Region.PARENT_ID+"="+parentRegionId, null, Table.Region._ID +" asc");
    final String[] columns = new String[] { Table.Region.REGION_NAME };
    final int[] to = new int[] { android.R.id.text1 };

    SimpleCursorAdapter mAdapter = new SimpleCursorAdapter(this, android.R.layout.simple_spinner_item, c, columns, to);
    mAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
    view.setAdapter(mAdapter);
}

下面小编来给各位同学介绍一篇关于Android中Movie导入播放GIF图片文件异常IOException.reset的解决办法,希望些方法对你有帮助。

使用Movie播放GIF图片时,能正常导入assets中的gif文件,如:

 代码如下 复制代码

is=context.getResources().openRawResource(R.drawable.mygif);
movie = Movie.decodeStream(is);

然而把网络图片加载到本地后,却报以下错误:

 代码如下 复制代码

java.io.IOException
at java.io.InputStream.reset(InputStream.java:218)
at android.graphics.Movie.decodeStream(Native Method)
at android.graphics.Movie.decodeTempStream(Movie.java:74)
at android.graphics.Movie.decodeFile(Movie.java:59)

我是在Androidmanifest.xml声明了权限:

 代码如下 复制代码

<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

解决办法:

 代码如下 复制代码

InputStream is = null;
    try {
        is = new BufferedInputStream(new FileInputStream(new File(getCacheDir(), "mygif.gif")), 16 * 1024);
        is.mark(16 * 1024);
    } catch (FileNotFoundException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
movie = Movie.decodeStream(is);

今天发现android开发中有一个android:ellipsize=marquee,这个感觉像html中的marquee功能,可以实现滚动效果,于是测试了一下,结果不行呀,后来百度了一下解决办法,下面大家一起来看看。

若要让TextView里的文本滚动,必须满足以下几个因素:

1,TextView里文本宽度超过TextView的宽度
2,android:ellipsize="marquee"
3,只有在TextView获取到焦点时,才会滚动.所以加上android:focusableInTouchMode="true" android:focusable="true"
最容易忽略的是第三条.

滚动重复次数设置:

android:marqueeRepeatLimit="marquee_forever"

看一个TextView属性android:ellipsize实现跑马灯效果

Android系统中TextView实现跑马灯效果,必须具备以下几个条件:
1、android:ellipsize=”marquee”
2、TextView必须单行显示,即内容必须超出TextView大小
3、TextView要获得焦点才能滚动
XML代码:
android:ellipsize="marquee", android:singleLine="true"
Java代码:
mTVText.setText("哼唱接撒砥砺风节雷锋精神http://www.111cn.net/,很长很长很长很长很长很长的数据");
mTVText.setSingleLine(true);
mTVText.setEllipsize(TruncateAt.MARQUEE);
PS: TextView.setHorizontallyScrolling(true); //让文字可以水平滑动
TextView还可以设置跑马灯效果的滚动次数,如下:
XML代码设置:
android:marqueerepeatlimit="1"。1代表1次,-1代表无限循环。
Java代码设置:
mTVText.setMarqueeRepeatLimit(-1);

今天文章来给各位安卓开者提供两个在应用中不错的实例,在安卓一个实例手动更新模块和自动更新模块程序代码,希望此代码对各位有帮助。

这里介绍了实现原理,为了使用方便,简单封装了一个类Updater。用法很简单。好吧,为了支持多语言,其实还是有些繁琐。

用法:

strings.xml 中用到的字符定义
其他语言的自己添加,下面的实例程序中,中英文都有

 代码如下 复制代码

<string name="update">check for update</string>
<string name="help">Help?</string>
<string name="help_content">I am helper,muhaha~~~</string>
<string name="found_newversion">Found a new version</string>
<string name="need_update">need update?</string>
<string name="alertdialog_title">Software Update</string>
<string name="alertdialog_update_button">Update</string>
<string name="alertdialog_cancel_button">Not now</string>
<string name="progressdialog_title">Downloading update</string>
<string name="progressdialog_message">Please wait a moment</string>

在AndroidManifest.xml添加更新需要用到的权限

 代码如下 复制代码
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>
<uses-permission android:name="android.permission.INSTALL_PACKAGES"></uses-permission>

检查更新,如发现有新版本会弹出提示

 

 代码如下 复制代码
 private boolean checkUpdate() {
 Updater updater = new Updater("http://127.0.0.1/", this);
 if (updater.needUpdate())//found update
  updater.showNewVersionUpdate();
 else {
 
 }
 
 return true;
}

自动更新


之前帮别人定制的一个android应用需要加个自动更新的功能。在 Market 里的应用是无需操心此事的,但像我这种定制的程序就需要自己实现。

原理相当简单,检查更新的时候,通过指定的URL获取服务器端版本信息。比较版本,如果更新,访问服务器端返回的apk的URL地址,下载,安装。各种 Makert 也是通过类似的机制实现的。原理搞清楚了,代码就相当简单了。

获取apk的VesionName,即AndroidManifest.xml中定义的android:versionName

 代码如下 复制代码

public String getVesionName(Context context) {
 String versionName = null;
 try {
  versionName = context.getPackageManager().getPackageInfo("net.vpntunnel", 0).versionName;
 } catch (NameNotFoundException e) {
  Log.e(TAG, e.getMessage());
 }
 
 return versionName;
}

更新以及安装程序需要的权限,在AndroidManifest.xml中添加

 代码如下 复制代码
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>
<uses-permission android:name="android.permission.INSTALL_PACKAGES"></uses-permission>

获取apk的versionCode,即AndroidManifest.xml中定义的android:versionCode

 代码如下 复制代码

public int getVersionCode(Context context) {
 int versionCode = 0;
 try {
  versionCode = context.getPackageManager().getPackageInfo("net.vpntunnel", 0).versionCode;
 } catch (NameNotFoundException e) {
  Log.e(TAG, e.getMessage());
 }
 
 return versionCode;
}

服务器端version.JSON,包含apk路径以及版本信息

 代码如下 复制代码

{
    "ApkName":"NAME",
    "ApkFullName":"NAME_1.0.5.apk",
    "VersionName":"1.0.5",
    "VersionCode":3
}

获取远程服务器的版本信息

 代码如下 复制代码

private void getRemoteJSON(string host) throws ClientProtocolException, IOException, JSONException {
 String url = String.format("http://%s/%s", host, VER_JSON);
 StringBuilder sb = new StringBuilder();
 HttpClient client = new DefaultHttpClient();
 HttpParams httpParams = client.getParams();
 HttpConnectionParams.setConnectionTimeout(httpParams, 3000);
 HttpConnectionParams.setSoTimeout(httpParams, 5000);
 HttpResponse response = client.execute(new HttpGet(url));
 HttpEntity entity = response.getEntity();
 if (entity != null) {
  BufferedReader reader = new BufferedReader(new InputStreamReader(entity.getContent(), "UTF-8"), 8192);
 
  String line = null;
  while ((line = reader.readLine()) != null) {
   sb.append(line + "n");
  }
  reader.close();
 }
 
 JSONObject object = (JSONObject) new JSONTokener(sb.toString()).nextValue();
 this.apkFullName = object.getString("ApkFullName");
 this.versionName = object.getString("VersionName");
 this.versionCode = Integer.valueOf(object.getInt("VersionCode"));
}

发现更新的提醒窗口,通过AlertDialog实现

 代码如下 复制代码

private void shoVersionUpdate(String newVersion, final String updateURL) {
 String message = String.format("%s: %s, %s", mContext.getString(R.string.found_newversion), newVersion, mContext.getString(R.string.need_update));
 AlertDialog dialog = new AlertDialog.Builder(mContext).setTitle(mContext.getString(R.string.alertdialog_title)).setMessage(message)
 // update
   .setPositiveButton(mContext.getString(R.string.alertdialog_update_button), new DialogInterface.OnClickListener() {
    @Override
    public void onClick(DialogInterface dialog, int which) {
     pBar = new ProgressDialog(mContext);
     pBar.setTitle(mContext.getString(R.string.progressdialog_title));
     pBar.setMessage(mContext.getString(R.string.progressdialog_message));
     pBar.setProgressStyle(ProgressDialog.STYLE_SPINNER);
     dialog.dismiss();
     downFile(updateURL);
    }
    // cancel
   }).setNegativeButton(mContext.getString(R.string.alertdialog_cancel_button), new DialogInterface.OnClickListener() {
    public void onClick(DialogInterface dialog, int whichButton) {
     dialog.dismiss();
    }
   }).create();
 dialog.show();
}

下载新版的apk文件,存放地址可以放到SD卡中。通过Environment.getExternalStorageDirectory()获取SD卡中的路径

 代码如下 复制代码

private void downFile(final String url) {
 pBar.show();
 new Thread() {
  public void run() {
   HttpClient client = new DefaultHttpClient();
   HttpGet get = new HttpGet(url);
   HttpResponse response;
   try {
    response = client.execute(get);
    HttpEntity entity = response.getEntity();
    long length = entity.getContentLength();
    InputStream is = entity.getContent();
    FileOutputStream fileOutputStream = null;
    if (is != null) {
     File f = new File(UPDATE_DIR);
     if (!f.exists()) {
      f.mkdirs();
     }
     fileOutputStream = new FileOutputStream(new File(UPDATE_DIR, updateFileName));
 
     byte[] buf = new byte[1024];
     int ch = -1;
     int count = 0;
     while ((ch = is.read(buf)) != -1) {
      fileOutputStream.write(buf, 0, ch);
      count += ch;
      Log.d(TAG, String.valueOf(count));
      if (length > 0) {
      }
     }
    }
    fileOutputStream.flush();
    if (fileOutputStream != null) {
     fileOutputStream.close();
    }
 
    handler.post(new Runnable() {
     public void run() {
      pBar.cancel();
      installUpdate();
     }
    });
   } catch (Exception e) {
    pBar.cancel();
    Log.e(TAG, e.getMessage());
   }
  }
 
 }.start();
}

安装更新

 代码如下 复制代码
private void installUpdate() {
 Intent intent = new Intent(Intent.ACTION_VIEW);
 intent.setDataAndType(Uri.fromFile(new File(UPDATE_DIR, updateFileName)), "application/vnd.android.package-archive");
 mContext.startActivity(intent);
}

至此更新需要函数就完成了,根据自己的业务逻辑组合一下,更新功能就搞定了。也可以稍微封装下,写成一个通用类,下次就可以直接用了。

今天我来介绍在android手机开发中我们利用Service播放音乐实例,这里需要有一个xml文档列表来存储音乐的地址,然后通过下面的程序读取音乐文件进行播放了。

Android Service 的使用:

我们可以创建一个Android程序,在src目录下创建一个Activity,一个继承自Service类的服务类;同时在资源文件夹res目录下创建一个raw的文件夹存放音频文件,如把music.mp3音乐文件放在该目录下。该程序的主界面如下:

xml布局

 代码如下 复制代码

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    <TextView 
       android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:text="Welcome to Andy's blog!"
       android:textSize="16sp"/>  
    <TextView 
       android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:text="音乐播放服务"/>
    <Button
       android:id="@+id/startMusic"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="开启音乐播放服务"/>
    <Button
       android:id="@+id/stopMusic"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="停止音乐播放服务"/>
   <Button
      android:id="@+id/bindMusic"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="绑定音乐播放服务"/>
   <Button
      android:id="@+id/unbindMusic"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="解除 ——绑定音乐播放服务"/>
</LinearLayout>

java代码

 代码如下 复制代码

MusicService.java

package com.zeph.android.service;

import android.app.Service;
import android.content.Intent;
import android.media.MediaPlayer;
import android.os.IBinder;

public class MusicService extends Service {
 private MediaPlayer mMediaPlayer;

 @Override
 public IBinder onBind(Intent arg0) {
  return null;
 }

 @Override
 public void onCreate() {
  super.onCreate();
  mMediaPlayer = MediaPlayer.create(this, R.raw.music01);
 }

 @Override
 public void onDestroy() {
  super.onDestroy();
  mMediaPlayer.stop();
  mMediaPlayer.release();
 }

 @Override
 public void onStart(Intent intent, int startId) {
  super.onStart(intent, startId);
  int operate = intent.getIntExtra("operate", 3);
  switch (operate) {
  case 0:
   if (!mMediaPlayer.isPlaying()) {
    mMediaPlayer.start();
   }
   break;
  case 1:
   if (mMediaPlayer.isPlaying()) {
    mMediaPlayer.pause();
   }
   break;
  case 2:
   if (mMediaPlayer.isPlaying()) {
    mMediaPlayer.stop();
    mMediaPlayer = MediaPlayer.create(this, R.raw.music01);
   }
   break;
  default:
   break;
  }
 }
}
ServiceTestActivity.java

package com.zeph.android.service;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class ServiceTestActivity extends Activity {
 private Button playButton;
 private Button pauseButton;
 private Button stopButton;
 private Button stopService;

 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  playButton = (Button) findViewById(R.id.playButton);
  pauseButton = (Button) findViewById(R.id.pauseButton);
  stopButton = (Button) findViewById(R.id.stopButton);
  stopService = (Button) findViewById(R.id.stopService);

  playButton.setOnClickListener(new ButtonOnClickListener());
  pauseButton.setOnClickListener(new ButtonOnClickListener());
  stopButton.setOnClickListener(new ButtonOnClickListener());
  stopService.setOnClickListener(new ButtonOnClickListener());
 }

 public class ButtonOnClickListener implements OnClickListener {

  @Override
  public void onClick(View view) {
   Intent intent = new Intent();
   intent.setClass(getApplicationContext(), MusicService.class);
   if (view == playButton) {
    intent.putExtra("operate", 0);
    startService(intent);
   } else if (view == pauseButton) {
    intent.putExtra("operate", 1);
    startService(intent);
   } else if (view == stopButton) {
    intent.putExtra("operate", 2);
    startService(intent);
   } else if (view == stopService) {
    stopService(intent);
   }
  }
 }
}

服务还需要在AndroidManifest.xml注册后才能使用:

 代码如下 复制代码

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.pocketdigi.service"
      android:versionCode="1"
      android:versionName="1.0">
    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".main"
                  android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    <service android:enabled="true" android:name=".Music" />
    </application>
</manifest>

[!--infotagslink--]

相关文章

  • Android子控件超出父控件的范围显示出来方法

    下面我们来看一篇关于Android子控件超出父控件的范围显示出来方法,希望这篇文章能够帮助到各位朋友,有碰到此问题的朋友可以进来看看哦。 <RelativeLayout xmlns:an...2016-10-02
  • 不打开网页直接查看网站的源代码

      有一种方法,可以不打开网站而直接查看到这个网站的源代码..   这样可以有效地防止误入恶意网站...   在浏览器地址栏输入:   view-source:http://...2016-09-20
  • php 调用goolge地图代码

    <?php require('path.inc.php'); header('content-Type: text/html; charset=utf-8'); $borough_id = intval($_GET['id']); if(!$borough_id){ echo ' ...2016-11-25
  • JS基于Mootools实现的个性菜单效果代码

    本文实例讲述了JS基于Mootools实现的个性菜单效果代码。分享给大家供大家参考,具体如下:这里演示基于Mootools做的带动画的垂直型菜单,是一个初学者写的,用来学习Mootools的使用有帮助,下载时请注意要将外部引用的mootools...2015-10-23
  • JS+CSS实现分类动态选择及移动功能效果代码

    本文实例讲述了JS+CSS实现分类动态选择及移动功能效果代码。分享给大家供大家参考,具体如下:这是一个类似选项卡功能的选择插件,与普通的TAb区别是加入了动画效果,多用于商品类网站,用作商品分类功能,不过其它网站也可以用,...2015-10-21
  • JS实现自定义简单网页软键盘效果代码

    本文实例讲述了JS实现自定义简单网页软键盘效果。分享给大家供大家参考,具体如下:这是一款自定义的简单点的网页软键盘,没有使用任何控件,仅是为了练习JavaScript编写水平,安全性方面没有过多考虑,有顾虑的可以不用,目的是学...2015-11-08
  • php 取除连续空格与换行代码

    php 取除连续空格与换行代码,这些我们都用到str_replace与正则函数 第一种: $content=str_replace("n","",$content); echo $content; 第二种: $content=preg_replac...2016-11-25
  • php简单用户登陆程序代码

    php简单用户登陆程序代码 这些教程很对初学者来讲是很有用的哦,这款就下面这一点点代码了哦。 <center> <p>&nbsp;</p> <p>&nbsp;</p> <form name="form1...2016-11-25
  • Android开发中findViewById()函数用法与简化

    findViewById方法在android开发中是获取页面控件的值了,有没有发现我们一个页面控件多了会反复研究写findViewById呢,下面我们一起来看它的简化方法。 Android中Fin...2016-09-20
  • PHP实现清除wordpress里恶意代码

    公司一些wordpress网站由于下载的插件存在恶意代码,导致整个服务器所有网站PHP文件都存在恶意代码,就写了个简单的脚本清除。恶意代码示例...2015-10-23
  • Android模拟器上模拟来电和短信配置

    如果我们的项目需要做来电及短信的功能,那么我们就得在Android模拟器开发这些功能,本来就来告诉我们如何在Android模拟器上模拟来电及来短信的功能。 在Android模拟...2016-09-20
  • 夜神android模拟器设置代理的方法

    夜神android模拟器如何设置代理呢?对于这个问题其实操作起来是非常的简单,下面小编来为各位详细介绍夜神android模拟器设置代理的方法,希望例子能够帮助到各位。 app...2016-09-20
  • android自定义动态设置Button样式【很常用】

    为了增强android应用的用户体验,我们可以在一些Button按钮上自定义动态的设置一些样式,比如交互时改变字体、颜色、背景图等。 今天来看一个通过重写Button来动态实...2016-09-20
  • js识别uc浏览器的代码

    其实挺简单的就是if(navigator.userAgent.indexOf('UCBrowser') > -1) {alert("uc浏览器");}else{//不是uc浏览器执行的操作}如果想测试某个浏览器的特征可以通过如下方法获取JS获取浏览器信息 浏览器代码名称:navigator...2015-11-08
  • JS实现双击屏幕滚动效果代码

    本文实例讲述了JS实现双击屏幕滚动效果代码。分享给大家供大家参考,具体如下:这里演示双击滚屏效果代码的实现方法,不知道有觉得有用处的没,现在网上还有很多还在用这个特效的呢,代码分享给大家吧。运行效果截图如下:在线演...2015-10-30
  • Android WebView加载html5页面实例教程

    如果我们要在Android应用APP中加载html5页面,我们可以使用WebView,本文我们分享两个WebView加载html5页面实例应用。 实例一:WebView加载html5实现炫酷引导页面大多...2016-09-20
  • JS日期加减,日期运算代码

    一、日期减去天数等于第二个日期function cc(dd,dadd){//可以加上错误处理var a = new Date(dd)a = a.valueOf()a = a - dadd * 24 * 60 * 60 * 1000a = new Date(a)alert(a.getFullYear() + "年" + (a.getMonth() +...2015-11-08
  • 深入理解Android中View和ViewGroup

    深入理解Android中View和ViewGroup从组成架构上看,似乎ViewGroup在View之上,View需要继承ViewGroup,但实际上不是这样的。View是基类,ViewGroup是它的子类。本教程我们深...2016-09-20
  • PHP开发微信支付的代码分享

    微信支付,即便交了保证金,你还是处理测试阶段,不能正式发布。必须到你通过程序测试提交订单、发货通知等数据到微信的系统中,才能申请发布。然后,因为在微信中是通过JS方式调用API,必须在微信后台设置支付授权目录,而且要到...2014-05-31