JavaAndroid开发部分API
JavaAndroid开发中的部分系统API
- 四大组件,都需要在清单文件中配置
- Activity: 用来提供一个能让用户操作并与之交互的界面
- onCreate(): 自动调用的方法, 在其中加载布局显示
- setContentView(int layoutId): 加载布局
- View findViewById(int id): 根据id找到对应的视图对象
- startActivity(Intent intent): 一般启动Activity
- startActivityForResult(int reqCode, Intent intent): 带回调启动Activity
- reqCode: 请求码
- onActivityResult(int reqCode, int resultCode, Intent data): 回调方法(使用startActivityForResult方法启动的Activity关闭时自动调用),需重写
- reqCode: 请求码
- resultCode: 返回码
- setResult(int resultCode, Intent data): 当使用startActivityForResult方法启动的activity时,设置要返回的结果
- finish(): 结束当前Activity
- getIntent(): 得到启动Activity的意图
- startService(Intent): 开启服务
- bindService(...): 绑定服务,可以调用服务中的方法
- getContentResolver(): 获取的类可以使用uri对其他应用内容提供者进行操作
- uri的协议为content
- 路径:
- getFileDir(): 获取文件保存目录
- getCacheDir(): 获取缓存目录
- openFileOutput(String, int): 拿到File目录文件的输出流
- openFileInput(String, int): 拿到File目录文件的输入流
- runOnUiThread(Runnable): 可在子线程中调用,完成更新ui操作
- 生命周期方法: onCreate(),onStart(),onResume(),onPause(),onRestart(),onStop(),onDestory()
- BroadcastReceiver: 广播接收者,可监听手机的状态
- onReceive(Context, Intent): 当接收到事件时调用,监听的事件在清单文件中配置
- Intent.getAction(): 获取事件类型
- onReceive(Context, Intent): 当接收到事件时调用,监听的事件在清单文件中配置
- Service: 服务
- onBind(): 当绑定服务时调用,使用返回的对象可以调用服务中的对象
- onCreate(): 第一次创建服务时调用
- onStartCommand(..): 每次start服务时调用
- onDestroy(): 停止服务时调用
- ContentProvider:内容提供者,可以让其他应用访问自己的数据库
- UriMatcher:匹配uri的类
- new UriMatcher(UriMatcher.NO_MATCH): 创建
- UriMatcher.addURI(String authorities, String path, int): 添加匹配路径,在数据库操作方法中使用UriMatcher.match(uri)方法进行返回码判断路径
- authorities: 清单文件中的authorities属性
- path: 请求路径
- int: 请求码
- UriMatcher:匹配uri的类
- Activity: 用来提供一个能让用户操作并与之交互的界面
- R: 应用的资源类
- R.drawable: 包含所有图片资源标识的内部类
- R.layout: 包含所有布局资源标识的内部类
- R.id: 包含所有视图id标识的内部类
- R.string: 包含所有字符串标识的内部类
- Intent: Activity, Service和BroadcastReceiver这三个应用组件之间进行通信的信使
- Intent(Context context, Class clazz): 明确指定的目标组件的意图,当操作当前自己应用的组件时使用
- Intent(String action): 没有明确指定目标组件的意图,当操作其它应用的组件时使用
- action: 为Activity配置中的<intent-filter>标签中<action>标签的android:name属性
- Intent.ACTION_DIAL: 进入电话拨打界面的意图
- Intent.ACTION_SENDTO: 进入短信编辑界面的意图
- Intent.ACTION_CALL: 拨打电话的意图
- action: 为Activity配置中的<intent-filter>标签中<action>标签的android:name属性
- putExtra(String name, Xxx value): 保存额外数据
- Xxx getXxxExtra(String name): 获取额外数据
- setData(Uri data): 设置有特定格式的uri数据
- View: 所有视图的根基类
- setonClickListener(OnClickListener listener): 给视图设置点击监听
- setOnLongClickListener(OnLongListener listener): 设置长按监听
- void setVisibility(int visibility): 设置试图的可见性
- visibility:
- View.VISIBLE: 可见
- View.INVISIBLE: 不可见,但占用屏幕空间
- View.GONE: 不可见,也不占用屏幕空间
- visibility:
- static View inflate(Context context, int resource, ViewGroup root): 动态加载布局文件
- 动态加载布局文件的其他两种方法
- LayoutInflater.from(Context).inflate(int, ViewGroup);
- LayoutInflater inflater = getSystemService(LAYOUT_INFLATER_SERVICE); inflater.inflater(int, ViewGroup);
- 动态加载布局文件的其他两种方法
- Toast: 用来显示短时间提示文本的类
- static Toast makeText(Context context, CharSequence text, int duration) : 创建一个toast对象
- context: 可以传入Activity类
- text: 显示的文本
- duration: 持续的时间(LENGTH_SHORT或LENGTH_LONG)
- show(): 显示提示
- static Toast makeText(Context context, CharSequence text, int duration) : 创建一个toast对象
- AlertDialog: 显示在屏幕上的小对话框
- show(): 显示
- AlertDialog.Builder: AlertDialog内部类,用来创建AlertDialog
- create(): 创建AlertDialog对象
- show(): 创建alertDialog对象,同时将其显示出来
- setTitle(CharSequence): 设置标题
- setMessage(CharSequence): 设置内容
- setPositiveButton(String, OnClickListener): 设置正面按钮
- setNegativeButton(String, OnClickListener): 设置负面按钮
- dismiss(): 移除dialog
- setView(View): 设置dialog中的布局
- setSingleChoiceItems(CharSequence[], int, OnClickListener): 设置单选列表
- setMultiChoiceItems(...): 设置多选列表
- ProgressDialog: 进度框
- show(Context, CharSequence, CharSequence): 像是dialog
- setProgressStyle(int style): 设置样式
- style: 样式,默认圆形进度
- ProgressDialog.STYLE_HORIZONTAL: 水平进度条样式
- style: 样式,默认圆形进度
- dismiss(): 移除dialog
- SmsManager: 发送短信的工具类
- static SmsManager getDefault() : 得到当前对象
- sendTextMessage(String destinationAddress, String scAddress, String text, PendingIntent sentIntent, PendingIntent deliveryIntent): 发送短信
- destinationAddress:电话号码
- scAddress:服务中心的地址,一般填null
- text:信息内容
- sentIntent
- deliveryIntent
- SharedPreferences: 用于保存数据的类
- Activity.getSharedPreferences(String, int): 拿到SharedPreferences
- Editor edit(): 拿到编辑器
- Editor:
- putXxx(...): 向编辑器中放数据
- Editor:
- getXxx(...): 取出数据
- commit(): 提交数据,保存数据
- OptionMenu: 底部菜单
- 在activity中重写onCreateOptionsMenu方法,即可定义底部菜单
- 向menu中添加menultem的方式
- 调用menu.add(...)方法
- 加载menu文件
- getMenulnflater().inflate(R.menu.main_option, menu);
- 重写onOptionsItemSelected方法,进行相应
- ContextMenu: 上下文菜单
- setOnCreateContextMenuListener(listener):为某个视图添加创建ContextMenu的监听(需要长按触发)
- onCreateContextMenu(menu, view, menuInfo):定义上下文菜单
- 向menu中添加menultem的方式,同上
- onContextItemSelected(MenuItem item)当选择某个菜单项的回调方法
- XmlSerializer: 写xml文件类,使用Xml类拿到
- setOutput(OutputStream, String): 指定输出流及编码
- startDocument(String, Boolean): 写xml文件的开头
- endDocument(): 写xml文件的结尾
- startTag(String, String): 写节点
- endTag(String, String): 结束节点
- text(String): 写标签体
- XmlPullParser: 读xml文件,使用Xml类拿到
- setInput(InputStream, String): 指定输入流及编码
- getEventType(): 拿到当前事件类型
- START_TAG;开始标签
- TEXT: 文本内容
- END_TAG: 结束标签
- END_DOCUMENT: 文件结尾
- next(): 向后移动,并返回移动后的事件类型
- getName(): 拿到当前的开始标签或结束标签的名字
- getAttributeValue(int): 拿到属性值
- nextText(): 当前为开始标签时,拿到标签体内容
- Xml:xml文件有关的工具类
- newSerializer(): 新建一个XmlSerializer类
- newPullParser(): 新建一个XmlPullParser类
- SQLiteOpenHelper:使用数据库使用的类,抽象类,需自己实现,数据库以db为后缀
- SQLiteOpenHelper(Context, String, CursorFactory, int): 构造器,参数(上下文对象,数据库名称,null,版本)
- onCreate(SQLiteDatabase): 需重写,当数据库创建时调用(创建表)
- onUpgrade(SQLiteDatabase, int, int):需重写,当数据库版本升级时调用
- getWritableDatabase(): 拿到SQLiteDatabase对象
- getReadableDatabase(): 拿到SQLiteDatabase对象,当磁盘满了,返回只读的
- SQLiteDatabase: 对数据库进行操作的类
- execSQL(String, [Object[]]): 执行sql语句,sql语句有占位符时使用obj数组
- rawQuery(String, String[]): 使用sql语句查询,返回Cursor结果集
- insert(String, String, ContentValues): 向数据库添加纪录(表名,null,map)
- delete(String, String, String[]): 删除数据(表名,条件,占位符)
- update(String, ContentValues, String, String[]): 更新数据(表名,map,条件,占位符)
- query(...): 查询数据库,返回Cursor对象
- close(): 关闭数据库
- beginTransaction(): 开启事务
- endTransaction(): 关闭事务
- setTransactionSuccessful(): 设置事务成功,即提交事务
- Cursor: 数据库查询的结果集
- getCount(): 返回结果数
- getColunCount(): 返回结果列数
- getColumnNames(): 返回列名的数组
- getXxx(int): 拿到当前行的对应列的值(0开始)
- moveToFirst(): 移动到第一个结果
- moveToLast(): 移动到最后一个
- moveToNext(): 移动到下一个
- close(): 关闭
- ArrayAdapter: ListAdapter子类,向ListView中添加项,只能添加一个组件
- SimpleAdapter: ListAdapter子类,向ListView中添加项,可以添加多个组件,耗内存
- SimpleAdapter(Context, List<Map<String, ?>>, int, String[], int[]): 参数(上下文对象,需要显示的数据List,布局文件标识,map的key的数组,布局文件中子View的id数组)
- BaseAdapter: ListAdapter子类,向ListView中添加项,
- 抽象类,需自己实现,ArrayAdapter和SimpleAdapter均是其实现类
- getCount(): 返回集合数据的数量
- getItem(int): 返回指定下标对应的数据对象
- getView(int, View, ViewGroup): 返回指定下标item的View对象
- HttpURLConnection: 使用Http协议发送和接收数据
- 使用URL类创建
- setConnectTimeout(int): 设置链接的超时时间
- setRequestMethod(String): 设置请求类型
- setRequestProperty(String, String): 设置请求头信息
- Post提交时需要设置"Content-Type"和Content-Length"头信息
- setDoOupput(boolean): 设置允许输出操作,在post请求时使用
- getOupputStream(): 拿到输出流,在post请求时写入请求体
- getResponseCode(): 获取响应码
- getInputStream(): 获取服务器响应信息的输入流
- HttpClient: 安卓提供的联网类
- 实现类: DefaultHttpClient...
- execute(HttpUriRequest): 执行url请求,返回HttpResponse对象
- HttpUriRequest
- 实现类: HttpGet, HttpPost...
- HttpResponse:
- getStatusLine().getStatusCode(): 获取响应码
- getEntity().getContent(): 获取相应流
- HttpUriRequest
- URL:
- URL(String): 使用指定路径创建URL对象
- openConnection(): 打开链接,得到URLConnection对象
- Handler: 可以执行更新ui操作的线程
- 在分线程中调用handler.sendMessage(Message),进行更新ui操作
- handleMessage(Message): 需重写,当sendMessage()调用时执行此方法
- postDelayed(Runnable, int): 在指定时间后执行操作
JavaAndroid开发部分API的更多相关文章
- ASP.NET Core Web API 开发-RESTful API实现
ASP.NET Core Web API 开发-RESTful API实现 REST 介绍: 符合REST设计风格的Web API称为RESTful API. 具象状态传输(英文:Representa ...
- flask开发restful api系列(8)-再谈项目结构
上一章,我们讲到,怎么用蓝图建造一个好的项目,今天我们继续深入.上一章中,我们所有的接口都写在view.py中,如果几十个,还稍微好管理一点,假如上百个,上千个,怎么找?所有接口堆在一起就显得杂乱无章 ...
- flask开发restful api
flask开发restful api 如果有几个原因可以让你爱上flask这个极其灵活的库,我想蓝图绝对应该算上一个,部署蓝图以后,你会发现整个程序结构非常清晰,模块之间相互不影响.蓝图对restfu ...
- 使用Jax-rs 开发RESTfull API 入门
使用Jax-rs 开发RESTfull API 入门 本文使用 Jersey 2开发RESTfull API.Jersey 2 是 JAX-RS 接口的参考实现 使用到的工具 Eclipse Neon ...
- Spring Boot入门(四):开发Web Api接口常用注解总结
本系列博客记录自己学习Spring Boot的历程,如帮助到你,不胜荣幸,如有错误,欢迎指正! 在程序员的日常工作中,Web开发应该是占比很重的一部分,至少我工作以来,开发的系统基本都是Web端访问的 ...
- 基于VS Code创建Spring Boot项目开发REST API(一)
公司从.NET转向Java不仅仅是简单的代码变成Java,趁此机会对原有的架构和代码重构,融入新的概念和技术.目前通过前后端分离,将后端更多的微服务化.从.NET转向Java我们更多的是用Java开发 ...
- 描述怎样通过flask+redis+sqlalchemy等工具,开发restful api
flask开发restful api系列(8)-再谈项目结构 摘要: 进一步介绍flask的项目结构,使整个项目结构一目了然.阅读全文 posted @ 2016-06-06 13:54 月儿弯弯02 ...
- springmvc/springboot开发restful API
非rest的url写法: 查询 GET /user/query?name=tom 详情 GET /user/getinfo? 创建 POST /user/create?name=tom 修改 POST ...
- 使用egg.js开发后端API接口系统
什么是Egg.js Egg.js 为企业级框架和应用而生,我们希望由 Egg.js 孕育出更多上层框架,帮助开发团队和开发人员降低开发和维护成本.详细的了解可以参考Egg.js的官网:https:// ...
随机推荐
- Ubuntu18.04搭建nodejs环境
首先安装sudo apt install curl 然后安装命令(当前最新版本是0.33.2,最新版本可以在https://github.com/creationix/nvm查看): curl -o- ...
- C++ Opencv Mat类型使用的几个注意事项及自写函数实现Laplace图像锐化
为了提升自己对Opencv中Mat数据类型的熟悉和掌握程度,自己尝试着写了一下Laplace图像锐化函数,一路坎坷,踩坑不断.现将代码分享如下: #include <opencv2/opencv ...
- 如何把web.xml中的context-param、Servlet、Listener和Filter定义添加到SpringBoot中
把传统的web项目迁移到SpringBoot中,少不了web.xml中的context-param.Servlet.Filter和Listener等定义的迁移. 对于Servlet.Filter和Li ...
- PHP的会话控制
页面数据的作用域: 当前页共享数据:变量.常量 两个页面间传递数据:get,post 跟踪用户的多页面数据共享(会话):session.cookie 全局数据共享:文件.数据库.memcached C ...
- [原创]K8Cscan插件之多种方式系统版本探测
[原创]K8 Cscan 大型内网渗透自定义扫描器 https://www.cnblogs.com/k8gege/p/10519321.html Cscan简介:何为自定义扫描器?其实也是插件化,但C ...
- Redis(1)---五种数据结构
五种数据结构 一.全局key操作 --删 flushdb --清空当前选择的数据库 del mykey mykey2 --删除了两个 Keys --改 --将当前数据库中的 mysetkey 键移入到 ...
- IDEA远程仓库版本回滚
访问我的博客 使用 git 进行项目的版本控制时,肯定会遇到回滚版本的情况,回滚有两种,一种是本地仓库回滚,另外一种是远程仓库回滚.以下详细讲解两种回滚方式,本文主要讲解远程回滚,以及常见使用误区. ...
- 获取完全一样的数据库,包括表与表之间的外键关系,check,default表结构脚本
今天公司给了一个任务,某一个项目由于数据过大,造成Sql Server 2012 的运行占用很大内存,于是要把之前的不常用的数据分开.要求写个脚本,要求: 1.能获取原来数据库中的表结构,主键一致.表 ...
- 【原创】驱动加载之CreateService
SC_HANDLE WINAPI CreateService( _In_ SC_HANDLE hSCManager, _In_ LPCTSTR lpServiceName, _In_opt_ LPCT ...
- Docker 构建映像
.用docker commit构建映像 .docker run -i -t centos /bin/bash //启动一个容器,启动后默认进入该窗口的bash进程 .yum install -y ep ...