android.os.BinderProxy cannot be cast to com解决办法

 更新时间:2016年9月20日 19:59  点击:3236
本文章来给大家介绍关于android.os.BinderProxy cannot be cast to com解决办法,希望此文章对各位有帮助呀。

Android在绑定服务的时候出现java.lang.ClassCastException:android.os.BinderProxy cannot be cast to com.

修改manifest文件里边相关服务去掉android:process=":remote"即可。

有一个注册界面,有四个可填项: 用户名,密码,确认密码,手机号码 我就是想知道,当我填完了四项内容后,点击提交按钮,我所填的内容能保存在应用中,并在再次调到登录界面时能用刚注册的信息成功登录,这是可以实现的吧?

1:代码实现切换操作
2:配置中声明另外一个acitivity

我们先看第一步,这里是触屏处理中的一段代码:

 代码如下 复制代码
public boolean onTouchEvent(MotionEvent event) {
    float pointx = event.getX();
    float pointy = event.getY();
    if (pointx > bp_x + 14 && pointx < bp_x + 14 + 117) {
        if (pointy > bp_y + 43 && pointy < bp_y + 43 + 15) {
        // 帐号
        Intent i = new Intent();// 得到一个意图的实例
        i.putExtra("count", 1);// 写出数据
        i.putExtra("himi", str_zh);
        i.setClass(MainActivity.instance, Register.class);// 设置当前activity以及将要操作的类
        MainActivity.instance.startActivity(i);// 用当前activity来启动另外一个activity
        }
    }
}

显示定义一个intent对象,Intent这个类的机制是协助交互的,详细的说明这里不多讲。

Intent中的putExtra()函数是起到两个activity之间交互交互的作用,这个方法类似 hashtable 或者hashmap中的put,第一个参数是key(索引) ,后一个参数volue(值),根据key我们可以得到对应的volue了。那么后面我也附上接受的处理。

Intent 中的setClass()函数也是传入两个参数,第一个是传入当前实例的activity对象,后面一个参数指需要打开的activity这个类!然后我们就可以利用当前activity对象来启动另外一个activity了。然后我们看下在另外一个activity是如何创建并且怎么接受数据的。

 代码如下 复制代码

package com.himi;

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;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.TextView;

/** * @author Himi **/

public class Register extends Activity {
    private Button button_ok;
    private EditText et;
    private TextView tv;
    private LinearLayout ly;
    private Register rs;
    private byte count;

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        rs = this;
        ly = new LinearLayout(this);
        button_ok = new Button(this);
        button_ok.setWidth(100);
        button_ok.setText("确定");
        button_ok.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
            if (count == 1) {
                MySurfaceView.str_zh = et.getText().toString();
            }
            else if (count == 2) {
                MySurfaceView.str_pass = et.getText().toString();
            }
            rs.finish();
        }
    });

    Intent intent = this.getIntent();
    count = (byte) intent.getIntExtra("count", 0);
    String temp_str = "";
    String temp_str2 = "";
    et = new EditText(this);
    tv = new TextView(this);
    if (count != 3) {
        temp_str = intent.getStringExtra("himi");
        if (count == 1) {
            rs.setTitle("请输入帐号!");
        }
        else {
            rs.setTitle("请输入密码!");
        }
        ly.addView(tv);
        ly.addView(et);
        ly.addView(button_ok);
        if (temp_str != null) {
            et.setText(temp_str);
        }
    }
    else {
        temp_str = intent.getStringExtra("himi_zh");
        temp_str2 = intent.getStringExtra("himi_pass");
        rs.setTitle("您输入的信息:");
        tv.setText("帐号:" + temp_str + "n" + "密码" + temp_str2);
        ly.addView(tv);
        ly.addView(button_ok);
        if (temp_str != null) {
            et.setText(temp_str);
        }
    }
    setContentView(ly);
 }
}

以上代码可以看出,新建一个activity其实只需要继承Activity以及重写onCreate()方法即可。当然创建的还需要一步很重要的步骤,我会在第二步中会详细说明,这里我们看下是如何接受之前的activity传来数据的。

 代码如下 复制代码
Intent intent = this.getIntent();
count = (byte) intent.getIntExtra("count", 0);

接受也是很简明易懂,创建一个Intent 意图对象,调用来去getIntExtra函数得到之前传来的数据,根据key。当然还有getStringExtra()等等函数都是类似,只是根据你传入的数据不同选择不同函数罢了。同学们应该注意的是getIntExtra中第二个参数是什么意思,其实就是一个对于找不到key相匹配的时候会默认return 0;

那么下面介绍第二步:在配置中声明

当创建一个activity的时候我们必须在AndroidMainFeset.xml中去声明我们创建的这个类是个Activity。

本文章来给大家介绍在安卓手机开发中的常用文件操作代码,这里一个不错的文件操作类,希望对大家有所帮助哦。
 代码如下 复制代码


package cn.youxigu.files;
 
import cn.youxigu.service.*;
import android.app.Activity;
import android.os.Bundle;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import android.view.*;
 
public class MainActivity extends Activity {
 
    EditText filename;
    EditText content;
    Button   buttonsave;
    Button   buttonopen;
    Button   buttonsaveSdCard;
    Button   buttonopenSdCard;
 
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
 
        filename = (EditText)this.findViewById(R.id.filename);
        content  = (EditText)this.findViewById(R.id.content);
        //获取本地保存按钮
        buttonsave   = (Button)this.findViewById(R.id.buttonsave);
        //获取本地打开按钮
        buttonopen   = (Button)this.findViewById(R.id.buttonsaveopen);
 
        //获取SD卡保存按钮
        buttonsaveSdCard   = (Button)this.findViewById(R.id.buttonsavesdcard);
        //获取SD卡打开按钮
        buttonopenSdCard   = (Button)this.findViewById(R.id.buttonsaveopensdcard);
 
 
        buttonsave.setOnClickListener(new SaveFileClick());
 
        buttonopen.setOnClickListener(new OpenFileClick());
 
        buttonsaveSdCard.setOnClickListener(new SaveSdCardFileClick());
 
        buttonopenSdCard.setOnClickListener(new OpenSdCardFileClick());
 
    }
 
 
    /**
     * 保存到本地的存储
     * @author xiaolu
     *
     */    
    private final class SaveFileClick implements View.OnClickListener{
 
        @Override
        public void onClick(View v) {
 
            String files    = filename.getText().toString();
            String contents = content.getText().toString();
 
            FileService file = new FileService(getApplicationContext());
            try{
                file.save(files, contents);
                Toast.makeText(getApplicationContext(), "保存成功", 1).show();
            } catch (Exception e){
                Toast.makeText(getApplicationContext(), "保存失败", 1).show();
                e.printStackTrace();
            }
 
        }
 
    }
 
 
    /**
     * 打开本地的存储
     * @author xiaolu
     *
     */
    private final class OpenFileClick implements View.OnClickListener{
 
        @Override
        public void onClick(View v) {
 
            String filenames    = filename.getText().toString();
 
            FileService file = new FileService(getApplicationContext());
 
            try{
 
                String contents = file.read(filenames);
                //填充到文本框
                content.setText(contents);
 
                Toast.makeText(getApplicationContext(), "打开成功", 1).show();
            } catch (Exception e){
                Toast.makeText(getApplicationContext(), "打开失败", 1).show();
                e.printStackTrace();
            }
 
        }
 
    }
 
 
    /**
     * 保存到SD卡的存储
     * @author xiaolu
     *
     */    
    private final class SaveSdCardFileClick implements View.OnClickListener{
 
        @Override
        public void onClick(View v) {
 
            String files    = filename.getText().toString();
            String contents = content.getText().toString();
 
            FileService file = new FileService(getApplicationContext());
            try{
                file.saveSdCard(files, contents);
                Toast.makeText(getApplicationContext(), "保存到SD卡成功", 1).show();
            } catch (Exception e){
                Toast.makeText(getApplicationContext(), "保存到SD卡失败", 1).show();
                e.printStackTrace();
            }
 
        }
 
    }
 
 
    /**
     * 打开SD卡的存储
     * @author xiaolu
     *
     */
    private final class OpenSdCardFileClick implements View.OnClickListener{
 
        @Override
        public void onClick(View v) {
 
            String filenames    = filename.getText().toString();
 
            FileService file = new FileService(getApplicationContext());
 
            try{
 
                String contents = file.readSdCard(filenames);
                //填充到文本框
                content.setText(contents);
 
                Toast.makeText(getApplicationContext(), "打开SdCard成功", 1).show();
            } catch (Exception e){
                Toast.makeText(getApplicationContext(), "打开SdCard失败", 1).show();
                e.printStackTrace();
            }
 
        }
 
    }
 
}

 


FileService文件代码:
 

 代码如下 复制代码

package cn.youxigu.service;
 
 
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
 
import android.content.Context;
import android.os.Environment;
 
public class FileService {
 
    //获取上下文
    private Context context;
 
    public FileService(Context context){
        this.context = context;
    }
 
    /**
     * 读取本地存储文件内容
     * @param filename 文件名
     * @return 文件内容
     * @throws Exception
     */
 
    public String read(String filename) throws Exception{
 
         FileInputStream InputStream = context.openFileInput(filename);
 
         //申请写入内存
         ByteArrayOutputStream  outStream = new ByteArrayOutputStream();
 
         byte[] buffer = new byte[1024];
 
         int len = 0;
         while((len = InputStream.read(buffer)) != -1){
 
             outStream.write(buffer);
         }
 
         byte[] data = outStream.toByteArray();
 
         return new String(data);
    }
 
 
 
    /**
     * 保存到本地存储
     * @param filename 文件名
     * @param content  文件内容
     * @throws Exception
     */
    public void save(String filename, String content) throws Exception{
        FileOutputStream outStream = context.openFileOutput(filename, Context.MODE_PRIVATE);
 
        outStream.write(content.getBytes());
        outStream.close();      
    }
 
 
    /**
     * 保存到SdCard存储
     * @param filename 文件名
     * @param content  文件内容
     * @throws Exception
     */
    public void saveSdCard(String filename, String content) throws Exception{
 
        //获取SD卡路径
        File sdCardDir = Environment.getExternalStorageDirectory();
 
        File saveFile = new File(sdCardDir, filename);
 
        FileOutputStream outStream = new FileOutputStream(saveFile);
 
        outStream.write(content.getBytes());
 
        outStream.close();
 
    }
 
 
    /**
     * 读取SdCard存储文件内容
     * @param filename 文件名
     * @return 文件内容
     * @throws Exception
     */
 
    public String readSdCard(String filename) throws Exception{
 
        //获取SD卡路径
         File sdCardDir = Environment.getExternalStorageDirectory();
 
         File openFile = new File(sdCardDir, filename);
 
         //用输入流对象进行读取数据
         FileInputStream InputStream = new FileInputStream(openFile);
 
         //申请写入内存
         ByteArrayOutputStream  outStream = new ByteArrayOutputStream();
 
         byte[] buffer = new byte[1024];
 
         int len = 0;
 
         while((len = InputStream.read(buffer)) != -1){
 
             outStream.write(buffer);
         }
 
 
         byte[] data = outStream.toByteArray();
 
         return new String(data);
    }
 
 
 
}

 


main.xml 文件代码:
 

 代码如下 复制代码
<?xml version=“1.0″ encoding=“utf-8″?>
<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”
    android:layout_width=“fill_parent”
    android:layout_height=“fill_parent”
    android:orientation=“vertical” >
    <TextView
        android:layout_width=“fill_parent”
        android:layout_height=“wrap_content”
       
        android:text=“@string/filenametext” />
    <EditText
        android:layout_width=“fill_parent”
        android:layout_height=“wrap_content”
        android:id=“@+id/filename”/>
   
    <EditText
        android:layout_width=“fill_parent”
        android:layout_height=“wrap_content”
           android:minLines=“3″
           android:id=“@+id/content”/>
    <Button
        android:layout_width=“wrap_content”
        android:layout_height=“wrap_content”
        android:text=“@string/buttonsave”
        android:id=“@+id/buttonsave”
        />
   
    <Button
        android:layout_width=“wrap_content”
        android:layout_height=“wrap_content”
        android:text=“@string/buttonopen”
        android:id=“@+id/buttonsaveopen”
        />
   
   
    <Button
        android:layout_width=“wrap_content”
        android:layout_height=“wrap_content”
        android:text=“@string/buttonsavesdcard”
        android:id=“@+id/buttonsavesdcard”
        />
   
    <Button
        android:layout_width=“wrap_content”
        android:layout_height=“wrap_content”
        android:text=“@string/buttonopensdcard”
        android:id=“@+id/buttonsaveopensdcard”
        />
</LinearLayout>
文章主要是介绍关于PC电脑和Android模拟器访问及模拟器之间tcp/udp通信,各位有需要了解同学可进入参考。
Android系统默认只能通过IP(10.0.2.2)单向访问PC电脑,而PC电脑不能通过IP来直接访问Android模拟器系统。要想实现PC电脑和Android模拟器系统以及Android模拟器之间相互通信必须借助端口重定向(redir)来实现。
先说说端口重定向所需要的telnet客户端安装:
windows:
安装telnet客户端。如果没有安装,可以在windows程序管理中的打开或关闭系统功能下找到telnet客户端菜单项来启用telnet客户端功能。
linux:
自行安装telnet客户端。
一、PC电脑不能直接访问Android模拟器系统的原因
Android系统为实现通信将PC电脑IP设置为10.0.2.2,自身为10.0.2.15/127.0.0.1。然而PC电脑并没有为Android模拟器系统指定IP,所以PC只能通过端口重定向来实现和Android模拟器的通信。
二、PC电脑和Android模拟器系统之间通信
1、运行模拟器
2、打开window 命令行,执行:
telnet localhost 5554
5554是模拟器的端口(位于Android模拟器窗口标题栏),执行之后会进入android console
3、在console下执行:
格式:redir add < udp/tcp >:< pc端口 >:< 模拟器端口 >
例如:redir add udp:2888:2888 
     redir add tcp:2888:2888
执行此命令之后,会把PC 2888 端口接收到的tcp/udp数据转到模拟器的2888端口。
三、多个Android模拟器系统之间通信
1、启动模拟器emulator-5554和emulator-5556
2、打开dos窗口执行telnet localhost 5554连接到模拟器5554
3、成功连接后,继续执行:redir add tcp:5000:6000将PC端口5000绑定到模拟器5554的端口6000上。
4、此时模拟器5556通过向PC电脑端口5000(即地址:10.0.2.2:5000)发送tcp/udp数据包跟模拟器5554通信。
5、同理根据步骤2、3来实现PC电脑对模拟器5556的端口转发。
添加成功后,我们可以用redir list命令来列出已经添加的映射端口,redir del可以进行删除。
相信只要理解了PC电脑和Android模拟器系统之间通信,便知道怎么实现多个模拟器之间通信。
 
  • TCP通信
进行TCP通信的时候在本机上启动两个模拟器,本机(PC)和模拟器时发现两个模拟器的IP地址都是完全一样的,所以要实现两个模拟器之间的通信,使用模拟器的IP地址是办不到的。必须进行端口映射。
    模拟器提供了一个特殊的IP,此IP的地址为10.0.2.2,此IP地址可以说等同于PC本机的IP地址127.0.0.1 。所以,通过此特殊IP地址,实现PC本机与模拟器的通信是没有问题。
首先 ,运行模拟器在命令行adb –s emulator -模拟器  forward  tcp:端口号 tcp:端口号(例如:adb –s emulator-5554 forward tcp:8080 tcp:8090)
PC-SERVER:ServerSocket server = new ServerSocket(8080);
模拟器-CLIENT:Socket socket = new Socket("10.0.2.2", 8090);
接下来是如何在两个模拟器之间进行通信:同样的先进行端口映射:adb –s emulator -模拟器  forward  tcp:端口号 tcp:端口号(先运行模拟器).代码如下:
adb –s emulator-5554 forward tcp:8080 tcp:8081
模拟器(5554)-SERVER:ServerSocket server = new ServerSocket(8080);
模拟器(5556)-CLIENT:Socket socket = new Socket("10.0.2.2", 8081);
因为模拟器5556连接的地址10.0.2.2:8080相当于本机的127.0.0.1:8080,由于进行了端口映射本机IP8080上的连接请求都映射到5554:8081上,因此模拟器5556的请求会发送到5554上.
本文章来给各位同学详细介绍关于Android布局之TableLayout-TableRow布局,各位同学有需要可进入参考。
 代码如下 复制代码

<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent">
 
 <TableRow>
 <TextView
 android:text="column1"
 android:padding="3dip" />
 <TextView
 android:text="column2"
 android:padding="3dip" />
 <TextView
 android:text="column3"
 android:padding="3dip" />
 </TableRow>
 
 <TableRow>
 <TextView
 android:text="column11"
 android:visibility="invisible"/> //cell不见了
 <TextView
 android:text="左边的invisible"
 android:gravity="right"
 android:padding="3dip" />
 <Button
 android:id="@+id/go"
 android:text="go"
 android:padding="3dip" />
 <Button
 android:text="cancel"
 android:padding="3dip" />
 </TableRow>
 
 <View //间隔线
 android:layout_height="2dip"
 android:background="#F00" />
 
 <TableRow>
 <TextView
 android:text="右边的cell empty" />
 <TextView
 android:layout_column="2"
 android:text="跳开empty cell"
 android:padding="3dip" />
 </TableRow>
 
 <TableRow>
 <TextView
 android:text="合并3个单元格"
 android:layout_span="3"
 android:gravity="center_horizontal"
 android:background="#FFC0C0C0"
 android:textColor="#f00"
 android:padding="3dip" />
 </TableRow>
</TableLayout>

TableLayout跟TableRow是一组搭配使用的布局,TableLayout置底,TableRow在TableLayout的上面,而Button、TextView等控件就在TableRow之上,另外,TableLayout之上也可以单独放控件。TableLayout是一个使用复杂的布局,最简单的用法就仅仅是拖拉控件做出个界面,但实际上,会经常在代码里使用TableLayout,例如做出表格的效果。本文主要介绍TableLayout的基本使用方法。

TableLayout经常用的属性是:

android:collapseColumns:以第0行为序,隐藏指定的列:

android:collapseColumns该属性为空时,如下图:

0

把android:collapseColumns=0,2————–》意思是把第0和第2列去掉,如下图:

1

android:shrinkColumns:以第0行为序,自动延伸指定的列填充可用部分:

当LayoutRow里面的控件还没有布满布局时,shrinkColumns不起作用,如下图:

2.1

设置了shrinkColumns=0,1,2,布局完全没有改变,因为LayoutRow里面还剩足够的空间。

当LayoutRow布满控件时,如下图:

2

设置设置了shrinkColumns=2,则结果如下图,控件自动向垂直方向填充空间:

3

android:stretchColumns:以第0行为序,尽量把指定的列填充空白部分:

4

设置stretchColumns=1,则结果如下图,第1列被尽量填充(Button02与TextView02同时向右填充,直到TextView03被压挤到最后边)。

5

Android的TableLayout + TableRow虽然使用有点复杂,但是功能很强大。。。。。。Android提供了很多布局属性,但是手机程序的界面没有PC那么花俏,所以常用的就那几项而已。。。

[!--infotagslink--]

相关文章

  • 409错误是什么 http 409错误怎么解决

    409错误是什么?http 409错误怎么解决呢?不少站长在遇到这个错误代码之后都一筹莫展,本次一聚教程网为大家带来了详细的说明,快来看看吧。 409错误是什么: HTTP 40...2017-01-22
  • PHP session_start()很慢问题分析与解决办法

    本文章来给各位同学介绍一下关于PHP session_start()很慢问题分析与解决办法,希望碰到此问题的同学可进入参考。 最近在做东西的时候发现一个问题 有一个接口挂...2016-11-25
  • http 405错误是什么 http 405错误怎么解决

    http 405错误是什么?http 405错误怎么解决?相信很多站长都在找这两个问题的答案,本次小编为大家带来了详细的教程,快来看看吧。 405错误是什么: HTTP 405错误是H...2017-01-22
  • php中json_decode()和json_encode()用法与中文不显示解决办法

    本文章介绍了关于php中json_decode()和json_encode()用法与中文不显示解决办法,有需要的朋友可以参考一下下。 php中json_decode()和json_encode() 1.json_decode(...2016-11-25
  • phpexcel导出数据身份证后四位0000解决办法

    在php中我们如果要导入excel数据我们通常会使用phpexcel插件了,但是有朋友会发与使用phpexcel导出数据出现身份证后四位是0000情况了,下面我们就来看解决办法。 最...2016-11-25
  • 401错误码代表什么 401错误解决办法

    401是HTTP状态码的一种,属于“请示错误”,表示请求可能出错,已妨碍了服务器对请求的处理。具体的401错误是指:未授权,请求要求进行身份验证。登录后,服务器可能会返回对页面...2017-01-22
  • apache网站提示503错误解决办法

    Apache status 503 的原因大致有如下几种情况 : 1、 CPU 负载过高,服务器响应不过来,返回503 2、 系统连接数超限,超过MaxVhostClients的上限,返回503 3、 单IP连接数超限,超过M...2016-01-28
  • 403错误是什么 403错误怎么解决

    403错误是HTTP状态码的一种,属于“请示错误”,表示服务器拒绝请求。如果在搜索引擎尝试抓取您网站上的有效网页时显示此状态代码,那么,这可能是您的服务器或主机拒绝搜索...2017-01-22
  • 412错误是什么 412错误怎么解决

    412错误是什么?412错误怎么解决?本次一聚教程网将为大家带来详细的介绍,帮助大家全面了解412错误的意思以及解决412错误的方法。 412错误是什么: HTTP 412错误,(Precond...2017-01-22
  • Perl CPAN::Modulelist的解决办法

    今天用CPAN安装Term::ReadLine,报了个这样的错误 Going to read /root/.cpan/sources/modules/03modlist.data.gz Can't locate object method "data" via package "C...2016-11-25
  • Android子控件超出父控件的范围显示出来方法

    下面我们来看一篇关于Android子控件超出父控件的范围显示出来方法,希望这篇文章能够帮助到各位朋友,有碰到此问题的朋友可以进来看看哦。 <RelativeLayout xmlns:an...2016-10-02
  • 407错误是什么 407错误怎么解决

    407错误是什么?407错误怎么解决?不少站长都遇到过407错误,下面小编将告诉大家如何处理407错误。 407错误是什么: HTTP 407错误是HTTP协议状态码的一种,表示需要代...2017-01-22
  • 406错误是什么 406错误怎么解决

    HTTP 406错误是HTTP协议状态码的一种,表示无法使用请求的内容特性来响应请求的网页。一般是指客户端浏览器不接受所请求页面的 MIME 类型。 而MIME类型是在把输出...2017-01-22
  • 410错误是什么 http 410错误怎么解决

    410错误是HTTP协议状态码的一种,本次一聚教程网将为大家详细介绍HTTP 410错误是什么,以及410错误的解决办法。 410错误是什么: HTTP 410错误是HTTP协议状态码的...2017-01-22
  • HTTP 400错误是什么 HTTP 400错误怎么解决

    每当遇到http错误代码为400,代表客户端发起的请求不符合服务器对请求的某些限制,或者请求本身存在一定的错误,那么HTTP 400错误怎么解决呢?请看下文介绍。 目前400错...2017-01-22
  • phpStudy访问速度慢和启动失败的解决办法

    下面给大家介绍phpstudy访问速度慢的解决办法。1、修改mysql数据库链接地址为ip地址127.0.0.1。2、使用最新版本,这个坑了我好久时间。下面一段内容是关于phpstudy启动失败的解决办法。php5.3、5.4和apache都是用vc9编...2015-11-24
  • PHP Curl出现403错误的解决办法

    自己用的小PHP应用,使用curl抓网页下来处理,为了穿墙方便,使用Privoxy作为代理,便于选择哪些网站使用proxy、哪些不用。但今天却遇到了奇怪的问题,访问google baidu这些网站居然都返回403错误,而访问其他的一些网站没事,如果...2014-05-31
  • Android开发中findViewById()函数用法与简化

    findViewById方法在android开发中是获取页面控件的值了,有没有发现我们一个页面控件多了会反复研究写findViewById呢,下面我们一起来看它的简化方法。 Android中Fin...2016-09-20
  • Android模拟器上模拟来电和短信配置

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

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