[安卓开发] Broadcast 三种广播的使用总结

时间:2019-05-12 16:59:45下载本文作者:会员上传
简介:写写帮文库小编为你整理了多篇相关的《[安卓开发] Broadcast 三种广播的使用总结》,但愿对你工作学习有帮助,当然你在写写帮文库还可以找到更多《[安卓开发] Broadcast 三种广播的使用总结》。

第一篇:[安卓开发] Broadcast 三种广播的使用总结

[安卓开发] Broadcast 三种广播的使用

总结

1、什么是安卓的Broadcast?

安卓的四大组件之一,是一种广泛应用在应用程序之间传输信息的机制。

2、什么是安卓的BroadcastReceiver?

是对发送出来的广播进行过滤接收并响应的一类组件,它就是用来接收来自系统和应用中的广播。例如系统的广播有开机广播: 系统在开机时候会发送开机广播,程序接收到之后,能进行开机自启动。网络状态改变广播: 3g变wifi、网络断开等。电量改变广播等等。。

3、Anroid为什么要这样设计?

大大减少开发工作量和开发周期

作为开发者,只需要掌握BroadcastReceiver

4、怎么理解Broadcast和BroadcastReceiver ?

Broadcast就像现实中的广播电台,他发广播信号来,然后我们用收音机来接收,然后处理,并且播放出声音,BroadcastReceiver就相当于那台收音机。

5、使用方法

发送:

把信息装入一个Intent对象(如:Action、Category),通过调相应的方法将Intent对象以广播的方式发送出去: sendBroadcast();

sendOrederBroadcast();sendStickyBroadcast();接收:

当Intent发送之后,所有已经注册receivedBroadcastReceiver会检查注册时的IntentFilter是否与发送的Intent相匹配,若匹配则就会调用BroadcastReceiver的onReceiver()方法。所以当我们定义一个BroadcastReceiver的时候,都需要实现onReceiver()方法。注意:

BroadcastReceiver需要注册

静态注册

代码动态注册

6、注意!!

BroadReceiver生命周期只有十秒左右,不能直接执行耗时操作,不然会出现ANR(应用程序无响应),也不能用子线程来做,因为每次广播来的时候都会创建一个Reveiver对象,并且调用onReceiver,执行完之后,对象会立刻被销毁,子线程也没了

要做耗时操作的话,应该通过发送Intent给Service,由Service来完成。

动态注册广播接受者的话要在Destory回调事件进行unregister

7、广播的分类

普通广播(Normal broadcast)所有监听该广播接受者都可以监听到该广播 同级别接收先后顺序是随机的(无序)级别低的后收到广播

接收器不能截断广播的继续传播,也不能处理广播 同级别动态注册高于静态注册 有序广播(Oredered broadcast)按照接收者的优先顺序来接收广播,优先级别在intent-filter中的priority中声明,-1000到1000之间,值越大优先级越高,可以终止广播的继续传播,接受者可以修改intent的内容。同级别接收顺序是随机的 级别低的后收到

能截断广播的继续传播,高级别的广播接收器接收广播后能决定时候截断。能处理广播

同级别动态注册高于静态注册

异步广播(粘滞性滞留广播)ps:已被弃用

不能处理结果给下一个接收者,无法终止广播。一直存在

可以先发送广播,再注册接收器

需要在清单文件添加android.permission.BROADCAST_STICKY权限

8、Demo

布局actibity_main三个按钮:

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:orientation=“vertical”>

android:id=“@+id/bt_one”

android:layout_width=“match_parent”

android:layout_height=“50dp”

android:text=“普通广播” />

android:id=“@+id/bt_two”

android:layout_width=“match_parent”

android:layout_height=“50dp”

android:text=“有序Ordered广播” />

android:id=“@+id/bt_three”

android:layout_width=“match_parent”

android:layout_height=“50dp”

android:text=“异步广播Sticky粘滞性滞留广播” />

MainActivity.Java

public class MainActivity extends AppCompatActivity implements View.OnClickListener{

private Button btOne;

private Button btTwo;

private Button btThree;

MyReiceiverThree myReiceiver = new MyReiceiverThree();

@Override

protected void onCreate(Bundle savedInstanceState){

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

btOne =(Button)findViewById(R.id.bt_one);

btTwo =(Button)findViewById(R.id.bt_two);

btThree =(Button)findViewById(R.id.bt_three);

btOne.setOnClickListener(this);

btTwo.setOnClickListener(this);

btThree.setOnClickListener(this);

//动态注册,在当前activity的生命周期內运行

/*IntentFilter filter= new IntentFilter(Config.BC_ONE_ACTION);

MyReiceiver myReiceiver = new MyReiceiver();

registerReceiver(myReiceiver,filter);*/

}

@Override

public void onClick(View view){

Intent intent = new Intent();

switch(view.getId()){

case R.id.bt_one:

//发送普通广播

intent.setAction(Config.BC_ONE_ACTION);

intent.putExtra(“msg”,“这是普通广播”);

sendBroadcast(intent);

break;

case R.id.bt_two:

//有序广播

intent.setAction(Config.BC_TWO_ACTION);

intent.putExtra(“msg”,“这是有序广播”);

sendOrderedBroadcast(intent,null);//其中第二个参数是设置权限,即接收器必须具有相应的权限才能正常接收到广播。

break;

case R.id.bt_three:

//异步广播

intent.setAction(Config.BC_THREE_ACTION);

intent.putExtra(“msg”,“这是异步广播”);

sendStickyBroadcast(intent);

//可以先发送 后注册

IntentFilter filter = new IntentFilter(Config.BC_THREE_ACTION);

registerReceiver(myReiceiver, filter);

break;

}

}

@Override

protected void onDestroy(){

super.onDestroy();

unregisterReceiver(myReiceiver);

} }

MyReceiver.java

public class MyReiceiver extends BroadcastReceiver {

@Override

public void onReceive(Context context, Intent intent){

//获取处理的的广播,普通广播不能获取处理

//true代表如果前面的接收器没有存放数据,则自动创建一个空的Bundle对象,false则表示如果前面的接收器如果没有存放任何数据则返回null。

Bundle bundle= getResultExtras(true);

System.out.println(“接收器1接收到处理的值:”+bundle.getString(“msg”));

System.out.println(“接收器1:”+intent.getStringExtra(“msg”));

} }

MyReceiverTwo.java

public class MyReiceiverTwo extends BroadcastReceiver {

@Override

public void onReceive(Context context, Intent intent){

//Toast.makeText(context,intent.getStringExtra(“msg”),Toast.LENGTH_SHORT).show();

System.out.println(“接收器2:”+intent.getStringExtra(“msg”));

abortBroadcast();

//截断广播,不让别的接收器继续接收,有序广播才能成功拦截

//处理广播

Bundle bundle = new Bundle();

bundle.putString(“msg”,“处理过后的广播”);

setResultExtras(bundle);//

} }

MyReceiverThree.java

public class MyReiceiverThree extends BroadcastReceiver {

@Override

public void onReceive(Context context, Intent intent){

//Toast.makeText(context,intent.getStringExtra(“msg”),Toast.LENGTH_SHORT).show();

System.out.println(“接收器3:”+intent.getStringExtra(“msg”));

} }

Config.java

public class Config {

public static final String BC_ONE_ACTION = “com.example.testbroadcasetwo.bcone”;

public static final String BC_TWO_ACTION = “com.example.testbroadcasetwo.bctwo”;

public static final String BC_THREE_ACTION = “com.example.testbroadcasetwo.bcthree”;}

Androidmanifest.xml

package=“com.example.testbroadcasetwo”>

//异步广播需要 一个权限

android:allowBackup=“true”

android:icon=“@mipmap/ic_launcher”

android:label=“@string/app_name”

android:supportsRtl=“true”

android:theme=“@style/AppTheme”>

String msg = intent.getStringExtra(“msg”);

iShowView =(MainActivity)context;

if(action.equals(Config.BC_ONE)){ //接收到普通广播

iShowView.updateText(msg);

//回调给HandleBroadcast

}

}

public void setiShowView(IShowView iShowView){

this.iShowView = iShowView;

} }

IShowView.java 回调到activity更新ui的接口

public interface IShowView {

void updateText(String msg);}

MainActivity.java

publicclassMainActivityextendsAppCompatActivityimplements View.OnClickListener,IShowView{

private Button btOne;

private TextView mTvResult;

//p层,处理数据

private HandleBroadcast handleBroadcast;

@Override

protected void onCreate(Bundle savedInstanceState){

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

handleBroadcast = new HandleBroadcast(this,this);

btOne =(Button)findViewById(R.id.bt_one);

mTvResult =(TextView)findViewById(R.id.tv_result);

btOne.setOnClickListener(this);

}

@Override

public void onClick(View view){

switch(view.getId()){

case R.id.bt_one:

handleBroadcast.sendMyBroadcast(TYPE.NORMAL);

break;

}

}

/**

* 广播接收处理完毕之后回调更新ui

* @param msg 要显示的文字

*/

@Override

public void updateText(String msg){

mTvResult.setText(msg);

} }

activity_main.xml

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:orientation=“vertical”>

android:id=“@+id/bt_one”

android:layout_width=“match_parent”

android:layout_height=“50dp”

android:text=“发送广播”

/>

android:id=“@+id/tv_result”

android:layout_width=“match_parent”

android:layout_height=“60dp”

android:text=“结果”

android:gravity=“center”

/>

第二篇:如何学习安卓开发

如何学习安卓开发?安卓开发学习已经成为IT行业的新潮流。时下,Android也以其创造力、前瞻性、延续性和实现能力成为行业首领,可是怎么学好Android呢?今天,欧柏泰克的老师告诉你如何学好Android。

熟悉Java基础知识

Android应用的开发语言用的是Java语言,并且在Android中也用到了Java核心类库的大量的类,因此,在学习Android开发之前,可以先把Java基本语法和Java SE的基础类库好好学习一下。Android应用程序开发是以Java语言为基础的,所以没有扎实的Java基础知识,只是机械的照抄别人的代码,是没有任何意义的。建议在Android课程前期的Java学习阶段中,需要用心的学好。

熟悉一门编程语言

现在大学里面和计算机相关的专业甚至理工类专业一般都会开设C语言课程,只是很多同学在大学期间并没有好好学习,如果对它掌握的不太好或者很久没用了,建议先从将其好好复习一下,将其基本的语法再好好回顾一下,最好能搭建一个环境来运行、调试它。如果没有学过,不妨也提前学习一下。大部分的高校所开设的C语言使用的教材都是用它作为教材,因此无论是购买还是借阅,都容易找到;

熟悉数据结构和算法基础知识

如果后续有志于游戏方面的开发,最好具备一定的数据结构和算法基础知识。虽然现代的高级编程语言中,其类库中已经帮我们实现了大部分的数据结构,一般情况下,我们直接使用即可。但如果能对其原理有所了解,当需要在这些数据结构和算法中间的时候,可以更加的清楚到底应该选择哪个数据结构或者算法。另外,在图形图像处理上面,线性代数的作用也非常重要,如果能掌握一点这方面的基础知识,无疑也会在后续的学习中如虎添翼。

第三篇:安卓NFC开发学习笔记

大家学习android开发建议首选android开发文档,该文档在你下载的sdk中,路径:/sdk/docs/index.html

目前NFC应用的大的框架上的理解:

我使用的API LEVEL是19,支持的API有三个:android.nfc,android.nfc.cardemulator,android.nfc.tech NFC在手机上的应用大体分为两类:读卡器和卡

android.nfc.cardemulator接口是为NFC作为卡应用提供的接口,在较低版本的API上是没有的

android.nfc.tech,android.nfc接口是为NFC作为读卡器应用提供的接口

首先说作为卡,nfc有两种实现方式,一个是使用NFC芯片作为卡,另一个是使用SIM作为卡

Figure 1.NFC card emulation with a secure element.至于从读卡器发送的指令到底是传递到NFC芯片还是SIM由NFC Controler控制,图中Secure Element是指SIM,Host-CPU指NFC芯片 android提供HostApduService用于NFC芯片,OffHostApduService用于SIM芯片,传递方向在res/xml文件中通过AID来控制

ps:Host-Based Card Emulator 简称为HCE

代码实现:

AndroidManifest.xml 中 配置service,因为作为卡实现的话,NFC功能是作为service存在的

android:permission=“android.permission.BIND_NFC_SERVICE”>

android:resource=“@xml/apduservice”/>

res/xml/apduservice.xml 中配置service响应的AID

android:requireDeviceUnlock=“false”>

android:category=“other”>

配置文件完成后编写service的处理方法:

NFCService需要继承HostApduService,如果需要与Activity通信,建议采用广播方式

也可以自己实现观察者模式,只是这样就需要持有Activity的引用,感觉不太好 NFCService.java public class NFCService extends HostApduService {

private Intent intent = new Intent(“com.example.communication.RECEIVER”);

@Override public void onCreate(){

//启动Acivity

Intent i = new Intent();

i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);//需要启动的Activity不是当前Activity的时候需要用FLAG_ACTIVITY_NEW_TASK

i.setAction(“com.apdu.nfc”);

getApplication().startActivity(i);

Toast.makeText(getApplicationContext(), “Service启动”, Toast.LENGTH_LONG).show();

} @Override public byte[] processCommandApdu(byte[] commandApdu, Bundle extras){//当注册的AID被选中后,后续指令被分发到这个处理函数中

byte[] sw = new byte[]{(byte)0x90,(byte)0x00};

byte[] response = new byte[5];

if(commandApdu[0]==(byte)0x00 &&commandApdu[1]==(byte)0xA4&& commandApdu[2]==(byte)0x04

&& commandApdu[4]==(byte)0x07&& commandApdu[5]==(byte)0xF0)

{

return sw;

}

else

{

//apdu处理逻辑

switch(commandApdu[1])

{

case(byte)0xA8:

break;

case(byte)0xAE:

break;

default:

return sw;

}

}

intent.putExtra(“command”, commandApdu);

intent.putExtra(“response”, response);

sendBroadcast(intent);//利用广播与Activity通信

return response;//SW值需要包含在response中

}

@Override public void onDeactivated(int reason){

if(reason==HostApduService.DEACTIVATION_DESELECTED)

{

Toast.makeText(getApplicationContext(), “已选择其它应用”, Toast.LENGTH_LONG).show();

}

else

{

Toast.makeText(getApplicationContext(), “连接断开”, Toast.LENGTH_LONG).show();

} }

@Override

public void onDestroy()

{

Toast.makeText(getApplicationContext(), “Service关闭”, Toast.LENGTH_LONG).show();super.onDestroy();

}

框架搭建好剩余的事情就很简单了,apdu的处理逻辑在processCommandApdu方法中实现即可

以上是Host-CPU方式的实现,SIM方式,API介绍中说该方式没有提供可供操作的API,也就是说Android不会监听SIM卡与读卡器之间的通信

所以NFCOffService 只需要实现onBind接口,这样绑定该Service的Activity可以对NFCOffService进行有限操作 public class NFCOffService extends OffHostApduService {

@Override public IBinder onBind(Intent intent){

// TODO Auto-generated method stub

return null;} } 上面没有提到的就是,如果你需要使用NFC,需要在Manifest中申请NFC权限: 现在来说说NFC芯片作为读卡器的应用场景以及实现

android.nfc.tech,android.nfc接口是为NFC作为读卡器应用提供的接口 接口定义了三种Action Tags:ACTION_NDEF_DISCOVERED,ACTION_TECH_DISCOVERED,ACTION_TAG_DISCOVERED。

当你在Manifest文件中将Activity的action-filter设置为这三个Tag中的一种或几种时,NFC响应事件会按照如图流程处理

我的理解是ACTION_NDEF_DISCOVERED 是用于两台NFC手机之间传输文件的

ACTION_TECH_DISCOVERED,ACTION_TAG_DISCOVERED才是用于NFC与卡进行通讯的 所以开发第一步是在Manifest中配置你的Action:

android:resource=“@xml/nfc_tech_filter” /> TECH_DISCOVERED还需要配置meta-data,meta-data的作用相当于补充说明或者一些配置信息 nfc_tech_filter.xml

android.nfc.tech.IsoDep

android.nfc.tech.NfcA

android.nfc.tech.NfcB

android.nfc.tech.NfcF

android.nfc.tech.NfcV

android.nfc.tech.Ndef

android.nfc.tech.NdefFormatable

android.nfc.tech.MifareClassic

android.nfc.tech.MifareUltralight

当然API中说明你可以将多个tech写在一个tech-list中,我做了尝试,这样做会引出一个问题,在程序未启动的情况下当手机刷卡时不会自动打开程序 如果想要自动打开需要按照上面这种写法,tech的个数可以根据你想要支持的卡类型进行调整

配置完成后,可以开始编写自己的Activity的java代码了

在onCreate方法中,需要获取NfcAdapter的引用,从名字可以看出这是一个适配器

NfcAdapter nfcAdapter;PendingIntent pendingIntent;@Override protected void onCreate(Bundle savedInstanceState){

super.onCreate(savedInstanceState);

setContentView(R.layout.pos_main);

dc =(Button)findViewById(R.id.button4DC);

ecc =(Button)findViewById(R.id.button4ECC);

qpboc =(Button)findViewById(R.id.button4QPBOC);

logWindow=(TextView)findViewById(R.id.communication4Financy);

nfcAdapter=NfcAdapter.getDefaultAdapter(this);

pendingIntent = PendingIntent.getActivity(this, 0, new Intent(this, getClass()).addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP), 0);

onNewIntent(getIntent());} 这里使用PendingIntent,该Intent与普通的Intent不同的是它是有一个延迟启动的功能,它启动时会回调onNewIntent函数,这样能够实现NFC与Activity的交互

pendingIntent = PendingIntent.getActivity(this, 0, new Intent(this, getClass()).addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP), 0);的含义是将Intent传递给this Activity 在onPause与onResume中需要添加代码

public void onPause(){

super.onPause();

nfcAdapter.disableForegroundDispatch(this);}

public void onResume(){

super.onResume();

nfcAdapter.enableForegroundDispatch(this, pendingIntent, FILTERS, TECHLISTS);} enableForegroundDispatch的作用是,当NFC事件发生时如果当前Activity不是注册了NFC action-filter的Activity,手机会显示注册了NFC事件的Activity供用户选择

如果当前Activity注册了NFC action 则将事件优先交由当前Activity处理。onNewIntent实现:

@Override public void onNewIntent(Intent intent){

Parcelable p = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG);

if(p==null)

{

return;

}

Tag nfcTag =(Tag)p;

final IsoDep isodep = IsoDep.get(nfcTag);// final NfcA isodep = NfcA.get(nfcTag);

final byte[] cmd = {(byte)0x00, // CLA Class

(byte)0xB4, // INS Instruction

(byte)0x04, // P1 Parameter 1

(byte)0x00, // P2 Parameter 2

(byte)0x00, // Le

};

try {

isodep.connect();

byte[] reaponse=null;

logWindow.append(“00B4040000”+'n');

try {

reaponse = isodep.getHistoricalBytes();

logWindow.append(Util.bytes2HexString(reaponse)+'n');

reaponse =isodep.transceive(cmd);

logWindow.append(Util.bytes2HexString(reaponse)+'n');

} catch(IOException e){

// TODO Auto-generated catch block

e.printStackTrace();

}

} catch(IOException e1){

// TODO Auto-generated catch block

e1.printStackTrace();

}finally{

try {

isodep.close();

} catch(IOException e){

// TODO Auto-generated catch block

e.printStackTrace();

}

} } 首先需要获取Tag,Tag是操作NFC的基础

Parcelable p = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG);

if(p==null)

{

return;

}

Tag nfcTag =(Tag)p;再将tag转换成特定的通讯协议 final IsoDep isodep = IsoDep.get(nfcTag);连接读卡器: isodep.connect();获取历史字节:

reaponse = isodep.getHistoricalBytes();响应指令:

reaponse =isodep.transceive(cmd);最后断开连接:(断开动作应该在Activity关闭或者pause的时候发生)finally{

try {

isodep.close();

} catch(IOException e){

// TODO Auto-generated catch block

e.printStackTrace();

}

} onNewIntent里面可以实现业务逻辑的处理以及UI

第四篇:安卓应用开发教程WebView总结

本文由麦可网");本地文件存放在:assets文件中

5、如果希望点击链接由自己处理,而不是新开Android的系统browser中响应该链接。给WebView添加一个事件监听对象(WebViewClient)

并重写其中的一些方法

shouldOverrideUrlLoading:对网页中超链接按钮的响应。

当按下某个连接时WebViewClient会调用这个方法,并传递参数:按下的url

onLoadResource

onPageStart

onPageFinish

onReceiveError

onReceivedHttpAuthRequest6、如果用webview点链接看了很多页以后,如果不做任何处理,点击系统“Back”键,整个浏览器会调用finish()而结束自身,如果希望浏览的网页回退而不是退出浏览器,需要在当前Activity中处理并消费掉该Back事件。

覆盖Activity类的onKeyDown(int keyCoder,KeyEvent event)方法。

public boolean onKeyDown(int keyCoder,KeyEvent event){

if(webView.canGoBack()&& keyCoder == KeyEvent.KEYCODE_BACK){

webview.goBack();//goBack()表示返回webView的上一页面

return true;

}

return false;

}

第五篇:上海瑭锦安卓开发心得

上海瑭锦安卓开发心得

对于软件开发工程师来说学习C语言是一个必经得学习之路,因为他是编程语言中得基础,如果没有C语言得编写能力,那么就谈不上是软件开发工程师,所以学好C语言是成为软件开发工程师得基础,那么我们如何了解C语言呢?首先我们要知道C语言是汇编语言中最基础得编写语言,它集成了所有汇编语言得大部分优点,能实现低级语言得众多功能。

C语言把高级语言与低级语言相结合创造出自己得汇编语言风格,塑造出自己得汇编语言工作单元,C语言得结构特点是编写代码和相关数据可以分隔化除了程序和相关得必要信息保持彼此独立得关系,这种关系可以是我们编写得程序层次化更加清晰,更加便于使用、维护和调试,它会以给用户方便得调用功能,可以多元化、多种循环、控制编写语句得控制导向,从而使我们得编写程序更加结构化、实用化。

这些都可以让C语言实现决策目得得要求,C语言得应用指针特性使得其应用范围增加,应用面变大,增加了程序得安全性。不容易被恶意程序所利用,C语言得对其处理标准化、针对于编写函数得标记、多线程得支持、从新定义新得程序安全定义有了更多得广泛得选择。它得编写灵活和紧凑编写序列使得书写程序更加自由化,它可以直接访问我们常用得物理地址,简洁得使用操作使得用户在对硬件上得要求更加简洁,它可以移植%86得公共代码在相关得编写程序上,这一特性使得其在不同环境中运行。它得表达能力使得其在各种系统和相关运行环境下可以自由得发挥它得编写和使用得能力。

下载[安卓开发] Broadcast 三种广播的使用总结word格式文档
下载[安卓开发] Broadcast 三种广播的使用总结.doc
将本文档下载到自己电脑,方便修改和收藏,请勿使用迅雷等下载。
点此处下载文档

文档为doc格式


声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:645879355@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。

相关范文推荐

    深圳安卓开发培训有没有用?

    深圳安卓开发培训有没有用 庞大的市场意味着更大的挑战、更多的人才需求与就业机会,在现行教育模式下,高校计算机网络专业毕业生技术实力与企业雇主期望存在较大落差。面对竞......

    基于安卓平台的JAVA开发培训

    基于安卓平台的JAVA开发培训 Android(安卓)系统是手机或一些平板电脑等终端的操作系统,Android系统在不久的将来即将应用在平板电脑,微波炉,电冰箱等等电器上,汇众教育安卓培训专......

    安卓系统精简总结

    [教程] 系统精简总结(集大成者,呵呵) 集大成者, 系统, 精简 本帖最后由 colinma 于 2010-10-26 10:35 编辑紧接我之前那篇(关于刷不刷机和刷机包的选择),刷机后系统精简的问题。首......

    有用的安卓总结

    一、文字的滚动显示: 二、用意图拨打电话 1:Intent intent = new Intent("android.activity.intent.action", Uri.parse("tel:" + 数字.toString))); 2:添加权限三、ListVi......

    安卓目录总结(共5篇)

    原装软件: AccountAndSyncSettings.apk.........账户与同步设置 AIMail_Android_V332a.apk.........手机邮箱 ApplicationsProvider.apk...........应用程序支持服务 BaiduS......

    安卓(Android)游戏以及手机游戏开发的详细流程

    安卓(Android)游戏以及手机游戏开发的详细流程【精华版】 >>首先说游戏设计部门 通常这是如下职位:游戏设计主负责(也有称主策划) 执行游戏设计师(称执行策划):分剧情策划,数据策划,也......

    JAVA程序员转安卓开发是不是很容易

    JAVA程序员转安卓开发是不是很容易? Android开发是以Java语言为基础的,但是Java程序员要往安卓开发方面转的话容不容易呢?粤嵌教育表示,Android 虽然使用Java 语言 作为开发工具......

    安卓程序开发程序员培训的真实经历

    安卓程序开发程序员培训的真实经历 大学毕业后,四年中的苦与乐都伴随着毕业的铃声而渐渐远去。毕业2年多之后,我辗转过2个行业,慢慢的,开始对自己的职业方向产生怀疑,看到和自己......