Android studio开发小型对话机器人app(实例代码)

前言

偶然在网上看到一个免费机器人接口,所以生此想法,接口地址: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<Msg> msgList = new ArrayList<Msg>();

 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<MsgAdapter.ViewHolder> {

 private List<Msg> 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<Msg> 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 对话机器人内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Android绘制机器人小实例

    本文实例通过前面学过的Paint.Canvas等2D绘画技术来实现在手机屏幕上绘制Android机器人. 具体代码实现和效果: 用来显示自定义的绘图类的布局文件 res/layout/main.xml: <?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xml

  • 安卓(Android)聊天机器人实现代码分享

    今天看到一个ios写的图灵机器人,直接去官网(http://www.tuling123.com/openapi/)看了下API接入,太简单了,就一个get请求~于是乎,写了一个Android版本的机器人,没什么技术含量,但是挺好玩的~刚好昨晚看了自己喜欢的秦时明月,嘿嘿,小貔貅,就是我的机器人宠物啦~ 这是一个安卓智能聊天机器人的源码,采用了仿微信的风格设计,调用的是图灵机器人的API,能够实现智能聊天.讲故事.讲笑话.查天气.查公交等丰富的功能. 先给大家展示效果图: 下面是代码片段,想要源码

  • Android studio开发小型对话机器人app(实例代码)

    前言 偶然在网上看到一个免费机器人接口,所以生此想法,接口地址:http://api.qingyunke.com/,Android开发比爬虫要繁琐得多,所以本文我将细说接口的调用方法,读者可根据思路去网上找一些免费接口拿来玩,其他代码一带而过,详细源码见文末. 成品展示: 开发步骤 1)新建项目empty,必要可github托管. 2)先写页面在res->layout目录下新建两个layout xml file activity_main作为主页面,msg_item为附在其上的消息页面.(具体代

  • Android 删除指定包名的App实例代码

    废话不多说了,直接给大家贴代码了,具体代码如下所示: /** * check and delete the old package app if it exists. */ private void checkOldPackage() { String packageName = "xxx.xxx.xxx.xxx"; if (isAvilible(this, packageName)) { Intent uninstall_intent = new Intent(); uninstal

  • android studio实现简单考试应用程序实例代码详解

    一.问题 1.如图所示,设计一个包含四种题型的简单考试应用程序(具体考试题目可以选用以下设计,也可以自己另外确定),项目名称:zuoye06_666 :(666,改成自己的实际编号). 2.布局管理器任选(约束布局相对容易实现). 3."提交"按钮的Text通过字符串资源赋值,不要直接输入"提交"两个字. 4.每题按25分计算,编写相应的程序,答题完成后单击"提交"按钮,在"总得分:"右边文本框中显示实际得分:同时,显示一个T

  • Android Studio开发实现简单计算器功能

    本文实例为大家分享了Android Studio开发实现简单计算器的具体代码,供大家参考,具体内容如下 代码: activity_3.xml <?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android&qu

  • Android Studio开发环境搭建教程详解

    对于移动端这块,笔者之前一直都是进行iOS开发的,也从来没用过Java.但是因为进入了Google Android全国大学生移动互联网创新挑战赛(进入官网)的总决赛(笔者"西部计算机教育提升计划"的项目被直接推荐进入决赛),这个比赛要求一定要提交apk程序,所以我不得不赶紧学习一下Android开发了. 下面就对自己学习的过程做一个记录. 一.安装Android Studio 笔者用的计算机配置如下: Mac下安装Android Studio应该更简单一些,只需要下载一个Android

  • android开发仿ios的UIScrollView实例代码

    今天重新装了编译器,结果崩无极限,真是日了狗了了.刚刚才知道问题在哪边. 好了,说正事,对于ios开发我没接触,不是很了解,百度了半天,差不多就是UIScrollView的把.如果不对,请指证.具体什么效果呢,我刚才拿朋友的iphone手机看了下,iphone的设置界面,第一个列表往下拉可以继续滚,上拉同理.不过android好像没有自带的这种情况. 我把这种效果称为滚无极限的scollview. 下面就来上源码: 首先,最最最重要的就是判断当前视图是否为空,你空视图滚不滚好像没啥区别,除了an

  • 使用android studio开发工具编译GBK转换三方库iconv的方法

    网上大多教程和资源并没有从头到尾告诉怎么编译过程,这边文章教你一个对ndk编译懂的不多,又需要使用三方库,怎么办,硬着头皮搞,又无从下手,网上一堆资料,有价值的不多,到处是偏分的.本篇提供真实能运行,带的资源经过测试的.过程如下: 编译ICONV 1.1 解压缩 1.解压缩:  tar -xvf  ./libiconv-1.14.tar.gz  -C libiconv-1.14 2.配置:./configure --host=arm-linux-gnueabihf CC=/home/work/r

  • Android 实现自定义圆形listview功能的实例代码

    最近遇到一个需求需要圆形listview作为悬浮窗,费了九牛二虎之力终于开发出来了,特别有成就感,下面分享下案例,项目原因,只能分享一部分供大家参考 1.有图有真相 下面就来讲解下代码: 1.自定义listview import android.content.Context; import android.content.res.TypedArray; import android.graphics.Bitmap; import android.graphics.BitmapFactory;

  • Android 中隐藏虚拟按键的方法实例代码

    下面通过一段代码给大家讲解android 隐藏虚拟按键的方法,废话不多说了,大家多多看看代码和注释吧,具体代码如下所示: /** * 隐藏虚拟按键,并且全屏 */ protected void hideBottomUIMenu() { //隐藏虚拟按键,并且全屏 if (Build.VERSION.SDK_INT > 11 && Build.VERSION.SDK_INT < 19) { // lower api View v = this.getWindow().getDec

  • Android 使用Fragment模仿微信界面的实例代码

    什么是Fragment 自从Android 3.0中引入fragments 的概念,根据词海的翻译可以译为:碎片.片段.其目的是为了解决不同屏幕分辩率的动态和灵活UI设计.大屏幕如平板小屏幕如手机,平板电脑的设计使得其有更多的空间来放更多的UI组件,而多出来的空间存放UI使其会产生更多的交互,从而诞生了fragments . fragments 的设计不需要你来亲自管理view hierarchy 的复杂变化,通过将Activity 的布局分散到frament 中,可以在运行时修改activit

随机推荐