前言

偶然在网上看到一个免费机器人接口,所以生此想法,接口地址:http://api.qingyunke.com/,Android开发比爬虫要繁琐得多,所以本文我将细说接口的调用方法,读者可根据思路去网上找一些免费接口拿来玩,其他代码一带而过,详细源码见文末。

成品展示:

开发步骤

1)新建项目empty,必要可github托管。

2)先写页面在res->layout目录下新建两个layout xml file

activity_main作为主页面,msg_item为附在其上的消息页面。(具体代码见文末)

这里再acitvity_main采用的不是ListView而是RecyclerView。

(3)写接口调用首先封装一个RobotManager类,用于接收用户输入之后对Url进行封装。

public class RobotManager {

private static String url = "http://api.qingyunke.com/api.php?key=free&appid=0&msg=!!";

public static String getUrl(String question){

String real_url = url.replace("!!",question);//将url中的!!替换为用户输入的内容

return real_url;

}

}

其次在java->第一个包下创建一个接口GetConnection,用来接收接口返回的返回。

public interface GetConnection {

void onFinish(String response);//返回正常

void onError(Exception e);//返回错误

}

然后开始写MyConnection类,调用接口,给参,并通过GetConnection接口将网上接口返回的数据传递出去。

public class MyConnection {

public static void getResponse(final String url,final GetConnection getConnection){

new Thread(new Runnable() {

@Override

public void run() {

HttpURLConnection connection;

try{

URL Url = new URL(url);

connection = (HttpURLConnection) Url.openConnection();

connection.setRequestMethod("GET");//Get方法

connection.setConnectTimeout(2000);//延时时间

connection.setReadTimeout(3000);

connection.setDoInput(true);

InputStream in = connection.getInputStream();

BufferedReader reader = new BufferedReader(new InputStreamReader(in));

StringBuilder response = new StringBuilder();

String line;

while ((line = reader.readLine()) != null) {

response.append(line);

}

Log.e("result",response.toString());

if (getConnection != null) {

getConnection.onFinish(response.toString());

}else {

Log.e("WeiNull","WeiNull");//测试时用的,无须关心。

}

}catch(IOException io) {

if (getConnection != null) {

getConnection.onError(io);

}

}

}

}).start();

}

}

(4)写页面逻辑页面逻辑主要是将从接口得到的内容渲染到页面上。首先进行一系列初始化,绑定布局,然后监听按钮点击接收用户输入,调用MyConnection类传入url,输入内容接收接口返回内容,同时用handler动态更新页面。

public class MainActivity extends AppCompatActivity {

private List msgList = new ArrayList();

private EditText inputText;

private Button send;

private RecyclerView msgRecyclerView;

private MsgAdapter adapter;

private Handler handler = new Handler(){

@Override

public void handleMessage(@NonNull Message msg) {

switch (msg.what){

case 1:{

Bundle data = msg.getData();

String result = data.getString("result");

Msg robotMsg = new Msg(result,Msg.TYPE_RECEIVED);

msgList.add(robotMsg);

adapter.notifyItemInserted(msgList.size() - 1); // 当有新消息时,刷新ListView中的显示

msgRecyclerView.scrollToPosition(msgList.size() - 1); // 将ListView定位到最后一行

}break;

case 2:{}break;

default:break;

}

}

};

private void getInter(String content){

MyConnection.getResponse(RobotManager.getUrl(content), new GetConnection() {

@Override

public void onFinish(String response) {

ContentBean contentBean = new ContentBean();

Log.e("getResult",response);

Message msg = new Message();

Bundle data = new Bundle();

Gson gson = new Gson();

contentBean = gson.fromJson(response,ContentBean.class);//用Gson将返回内容序列化为ContentBean对象。

if(contentBean.getResult()==0){

data.putString("result",contentBean.getContent());

}else{

data.putString("result","我听不懂你在说什么呀!");

}

msg.setData(data);

msg.what = 1;

handler.sendMessage(msg);

}

@Override

public void onError(Exception e) {

e.printStackTrace();

}

});

}

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initMsgs(); // 初始化消息数据

inputText = findViewById(R.id.input_text);

send = findViewById(R.id.send);

msgRecyclerView = findViewById(R.id.msg_recycler_view);

LinearLayoutManager layoutManager = new LinearLayoutManager(this);

msgRecyclerView.setLayoutManager(layoutManager);

adapter = new MsgAdapter(msgList);

msgRecyclerView.setAdapter(adapter);

send.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

String content = inputText.getText().toString();

if (!"".equals(content)) {

Msg msg = new Msg(content, Msg.TYPE_SENT);

msgList.add(msg);

getInter(content);

Log.e("url",RobotManager.getUrl(content));

adapter.notifyItemInserted(msgList.size() - 1); // 当有新消息时,刷新ListView中的显示

msgRecyclerView.scrollToPosition(msgList.size() - 1); // 将ListView定位到最后一行

inputText.setText(""); // 清空输入框中的内容

}

}

});

}

private void initMsgs() {

Msg msg1 = new Msg("我是菲菲,快来和我聊天吧* ( ´͈ ᵕ `͈ )◞♡", Msg.TYPE_RECEIVED);

msgList.add(msg1);

}

}

由于接口返回的数据是Json格式,所以我们需要对Json进行解析,本文采用google的Gson库对其进行解析,将接口内容序列化为一个类ContentBean。解析过程见上面代码。

public class ContentBean {

/**

* result : 0

* content : [04月08日] 邯郸天气:小雨,白天 17℃,夜晚 9℃,微风,<3级转3-4级

*/

private int result;

private String content;

public int getResult() {

return result;

}

public void setResult(int result) {

this.result = result;

}

public String getContent() {

return content;

}

public void setContent(String content) {

this.content = content;

}

}

(5)其余代码Msg和MsgAdapter用于解析消息是发送方还是接收方

并展示在消息列表上Msg

public class Msg {

public static final int TYPE_RECEIVED = 0;

public static final int TYPE_SENT = 1;

private String content;

private int type;

public Msg(String content, int type) {

this.content = content;

this.type = type;

}

public String getContent() {

return content;

}

public int getType() {

return type;

}

}

MsgAdapter

public class MsgAdapter extends RecyclerView.Adapter {

private List mMsgList;

static class ViewHolder extends RecyclerView.ViewHolder {

LinearLayout leftLayout;

LinearLayout rightLayout;

TextView leftMsg;

TextView rightMsg;

public ViewHolder(View view) {

super(view);

leftLayout = (LinearLayout) view.findViewById(R.id.left_layout);

rightLayout = (LinearLayout) view.findViewById(R.id.right_layout);

leftMsg = (TextView) view.findViewById(R.id.left_msg);

rightMsg = (TextView) view.findViewById(R.id.right_msg);

}

}

public MsgAdapter(List msgList) {

mMsgList = msgList;

}

@Override

public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.msg_item, parent, false);

return new ViewHolder(view);

}

@Override

public void onBindViewHolder(ViewHolder holder, int position) {

Msg msg = mMsgList.get(position);

if (msg.getType() == Msg.TYPE_RECEIVED) {

// 如果是收到的消息,则显示左边的消息布局,将右边的消息布局隐藏

holder.leftLayout.setVisibility(View.VISIBLE);

holder.rightLayout.setVisibility(View.GONE);

holder.leftMsg.setText(msg.getContent());

} else if(msg.getType() == Msg.TYPE_SENT) {

// 如果是发出的消息,则显示右边的消息布局,将左边的消息布局隐藏

holder.rightLayout.setVisibility(View.VISIBLE);

holder.leftLayout.setVisibility(View.GONE);

holder.rightMsg.setText(msg.getContent());

}

}

@Override

public int getItemCount() {

return mMsgList.size();

}

}

尾声

以上代码可复制使用,但其中有一些图片,类库什么的需要自行导入,完整代码见geithub:点击此处直达

该项目是我早期项目,只是为了记录当初的开发流程,所以并不存在什么设计模式,代码结构也比较乱,注释也比较少,如果有任何问题,欢迎添加我的QQ询问!

总结

到此这篇关于Android studio开发一个小型对话机器人app的文章就介绍到这了,更多相关android studio 对话机器人内容请搜索编程圈以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程圈!

android语音机器人代码,Android studio开发小型对话机器人app(实例代码)相关推荐

  1. Android Studio开发环境下让App自动签名

    Android Studio开发环境下让App自动签名 前言: 分享这个的原因有两个: 第一,在开发的过程中我们会发现关于微信的分享支付或者是支付宝的支付等一些功能的时候必须是要签名包,否则会失败,每 ...

  2. java 微信自定义菜单开发_微信公众号开发之设置自定义菜单实例代码【java版】...

    本实例是为了实现在管理后台实现微信菜单的添加删除管理. 1.首先我们需要新建一个数据库表用于存放menu菜单项 可包含的字段有id.父类id.name.排序.是否显示.类型(view.click).链 ...

  3. php 工商银行公众号支付代码_php开发微信支付企业付款实例代码

    企业付款的应用场景: 公众号向已关注用户付款,比如处理退款.财务结算等,本文主要和大家分享php开发微信支付企业付款实例代码,希望能帮助到大家. 说明 1.证书需要用自己的商户里面的证书(注意:证书路 ...

  4. android 语音交互动画,Android实现客户端语音动弹界面实例代码

    首先,整体界面分三部分,最上层自定义ActionBar相信不需要我讲大家就能看出来了. 中间部分是文字动弹部分,主体就是一个设置了Padding(margin)的EditText,在EditText下 ...

  5. android功能网格布局,Visual Studio 开发安卓之布局-网格布局(GridLayout)

    GridLayout 与 TableLayout 用法非常相似,不过它的"单元格"可以跨行,没有了 Row 子元素,代码更简洁,还有据说它渲染速度比 TableLayout 快. ...

  6. android 语音播报中文,android 语音播报(通过手说tts 实现中文语音播报)

    手说TTS介绍: 手说TTS,是Android平台下的中文语音引擎,提供了中文文本到语音的转换. 使用手说TTS进行中文文本的朗读,包括中文简繁体.阿拉伯数字.英文字母及一些符号的混读.并且处理了中文 ...

  7. android 语音自动播报,Android 语音播报实现

    文章主要讲的是以前做项目时实现的来短信或来电话时语音播报的功能实现,记录下来做个总结. 1.实现语音播报的关键 -- 语音播报工具类(TtsUtil.java) 为了方便 文章主要讲的是以前做项目时实 ...

  8. android 语音搜索动画,Android自定义控件实现UC浏览器语音搜索效果

    最近项目上要实现语音搜索功能,界面样式要模仿一下UC浏览器的样式,UC浏览器中有一个控件,会随着声音大小浮动,然后寻思偷个懒,百度一下,结果也没有找到类似的,只能自己动手了. 先上图看我实现的效果: ...

  9. android 语音播放工具,Android简易的仿微信聊天的语音播放控件

    说到Android音频播放,可谓108式,方案众多,这里有一篇总结Android几种播放音频的方式的文章,传送门.本文旨在熟悉MediaPlayer的使用,遂此控件封装采用MediaPlayer实现. ...

最新文章

  1. leveldb源码分析:Open启动流程
  2. 为什么会有jsessionid,这个东东有什么用呢?
  3. Windows Phone 8初学者开发—第6部分:设置应用程序的样式
  4. SQLite使用报告
  5. python生成器函数的使用(模拟cycle函数)
  6. [小创造]“XENON”,我的JSON变种。
  7. 每日一题_JavaScript.两种方式实现网页加载后onload绑定多个函数?
  8. Python之路第二天
  9. 虚拟现实中用到的五种定位追踪技术
  10. Android 系统签名实现的三种方式
  11. 2022计算机三级数据库总结和经验(有免费题库)
  12. java 服务器程序部署环境搭建
  13. (2)香橙派+apache2与php+天猫精灵=自建平台语音支持--香橙派操作系统安装
  14. 工作之余,别忘了生活。
  15. 《共同警戒区》观后感(r10笔记第97天)
  16. 支付宝SOFA架构:降低业务系统复杂度
  17. 小众骑行路线-十里箐
  18. 如何清除计算机的u盘使用记录,如何清除U盘使用痕迹
  19. 前端学习之CSS第三天
  20. 2023最新前端面试题3(持续更新)

热门文章

  1. 百度地图的全景地图实现的过程
  2. Ubuntu 16.04下安装64位谷歌Chrome浏览器
  3. Excel基础篇(二):拼接字符串
  4. 解释一下后面的指令是什么意思:wget https://git.io/vpn -O openvpn-install.sh bash openvpn-install.sh...
  5. 深度学习之Pix2PixHD
  6. 利用python绘制五角星
  7. python多元线性回归预测法,Python-Tensorflow2.3.0-多元线性回归预测(学习笔记)
  8. echarts柱状图横向排行榜实战开发
  9. 爬虫豆瓣三部曲之音乐排行榜
  10. ios touchesBegan不触发