android计算器简单实现代码

本文实例为大家分享了android计算器的具体实现代码,供大家参考,具体内容如下

java代码:

package com.itheima74.simplecalculator4;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;

import com.iflytek.cloud.InitListener;
import com.iflytek.cloud.SpeechConstant;
import com.iflytek.cloud.SpeechError;
import com.iflytek.cloud.SpeechSynthesizer;
import com.iflytek.cloud.SpeechUtility;
import com.iflytek.cloud.SynthesizerListener;
import com.iflytek.cloud.util.ResourceUtil;

import java.util.ArrayList;

/**
 * 简易计算器(第三版)
 * 功能介绍:
 * 1.支持连续计算
 * 2.支持离线语音
 * 3.科大讯飞在线(离线)语音合成SDK使用步骤:
 * a.下载SDK,注册APPID
 * b.拷贝libs目录下Msc.jar至工程libs目录,右键:add as library
 * c.创建assets目录,拷贝tts文件夹下3个离线发音人资源
 * d.创建jniLibs目录,拷贝armeabi文件夹,x86文件(视具体手机机型而定)
 * e.初始化SDK
 * f.初始化在线或离线语音
 * g.开始合成(朗读文字)
 */
public class MainActivity extends AppCompatActivity implements View.OnClickListener {

  private TextView tv;// 显示控件
  private ArrayList<String> mList;// 存储用户输入集合
  private double mResult;// 计算结果,当除数为0时,无法计算结果,默认为初始值0
  private boolean mFlag = true;// 控制在线语音功能是否开启的变量,默认开启

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    initSDK();
    initView();
    initList();
  }

  /**
   * 2.初始化离线语音
   *
   * @param flag 离线语音开启或关闭开关
   * @param msg 要朗读的文字
   */
  private void initLocalHeCheng(boolean flag, String msg) {
    if (flag) {
      //1.创建SpeechSynthesizer对象,第二个参数:本地合成传InitListener
      SpeechSynthesizer mTts = SpeechSynthesizer.createSynthesizer(this, new InitListener() {
        @Override
        public void onInit(int code) {

        }
      });
      //2.合成参数设置
      //设置引擎类型为本地
      mTts.setParameter(SpeechConstant.ENGINE_TYPE, SpeechConstant.TYPE_LOCAL);
      //设置本地发音人
      mTts.setParameter(SpeechConstant.VOICE_NAME, "xiaoyan");
      //加载本地合成资源,resPath为本地合成资源路径
      mTts.setParameter(ResourceUtil.TTS_RES_PATH, getResourcePath());
      // 设置语速
      mTts.setParameter(SpeechConstant.SPEED, "60");
      // 设置音调
      mTts.setParameter(SpeechConstant.PITCH, "50");
      // 设置音量
      mTts.setParameter(SpeechConstant.VOLUME, "100");
      // 设置播放器音频流类型
      mTts.setParameter(SpeechConstant.STREAM_TYPE, "3");
      //设置合成音频保存位置(可自定义保存位置),保存在“./sdcard/iflytek.pcm”
      //保存在SD卡需要在AndroidManifest.xml添加写SD卡权限
      //如果不需要保存合成音频,注释该行代码
      //mTts.setParameter(SpeechConstant.TTS_AUDIO_PATH, "./sdcard/iflytek.pcm");
      //3.开始合成
      mTts.startSpeaking(msg, mSynListener);
    }
  }

  // 获取发音人资源路径
  private String getResourcePath() {
    StringBuffer tempBuffer = new StringBuffer();
    // 合成通用资源
    tempBuffer.append(ResourceUtil.generateResourcePath(this, ResourceUtil.RESOURCE_TYPE.assets, "tts/common.jet"));
    tempBuffer.append(";");
    // 发音人资源
    tempBuffer.append(ResourceUtil.generateResourcePath(this, ResourceUtil.RESOURCE_TYPE.assets, "tts/xiaoyan.jet"));
    return tempBuffer.toString();
  }

  /**
   * 1.初始化SDK
   */
  private void initSDK() {
    SpeechUtility.createUtility(this, SpeechConstant.APPID + "=58ba4628");
  }

  // 创建一个选项菜单
  @Override
  public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
  }

  // 处理选项菜单的点击事件
  @Override
  public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
      case R.id.exit:
        this.finish();
        break;
      case R.id.open_local_voice:
        mFlag = true;
        break;
      case R.id.close_local_voice:
        mFlag = false;
        break;
    }
    return super.onOptionsItemSelected(item);
  }

  /**
   * 2.在线语音合成,朗读
   *
   * @param flag 控制方法的执行,true:执行,false:不执行
   * @param msg 需要朗读的文字
   */
  /*private void initYuYinHeCheng(boolean flag, String msg) {
    if (flag) {
      //1.创建SpeechSynthesizer对象, 第二个参数:本地合成时传InitListener
      SpeechSynthesizer mTts = SpeechSynthesizer.createSynthesizer(this, null);
      //2.合成参数设置,详见《科大讯飞MSC API手册(Android)》SpeechSynthesizer 类
      mTts.setParameter(SpeechConstant.VOICE_NAME, mVoiceName);//设置发音人
      mTts.setParameter(SpeechConstant.SPEED, "50");//设置语速
      mTts.setParameter(SpeechConstant.VOLUME, "80");//设置音量,范围0~100
      mTts.setParameter(SpeechConstant.ENGINE_TYPE, SpeechConstant.TYPE_CLOUD); //设置云端
      //设置合成音频保存位置(可自定义保存位置),保存在“./sdcard/iflytek.pcm”
      //保存在SD卡需要在AndroidManifest.xml添加写SD卡权限
      //如果不需要保存合成音频,注释该行代码
      //mTts.setParameter(SpeechConstant.TTS_AUDIO_PATH, "./sdcard/iflytek.pcm");
      //3.开始合成
      mTts.startSpeaking(msg, mSynListener);
    }

  }*/

  // 合成监听器
  private SynthesizerListener mSynListener = new SynthesizerListener() {
    //开始播放
    @Override
    public void onSpeakBegin() {

    }

    //缓冲进度回调
    //percent为缓冲进度0~100,beginPos为缓冲音频在文本中开始位置,endPos表示缓冲音频在文本中结束位置,
    //info为附加信息。
    @Override
    public void onBufferProgress(int i, int i1, int i2, String s) {

    }

    // 暂停播放
    @Override
    public void onSpeakPaused() {

    }

    //恢复播放回调接口
    @Override
    public void onSpeakResumed() {

    }

    //播放进度回调
    //percent为播放进度0~100,beginPos为播放音频在文本中开始位置,endPos表示播放音频在文本中结束位置.
    @Override
    public void onSpeakProgress(int i, int i1, int i2) {

    }

    //会话结束回调接口,没有错误时,error为null
    @Override
    public void onCompleted(SpeechError speechError) {

    }

    //会话事件回调接口
    @Override
    public void onEvent(int i, int i1, int i2, Bundle bundle) {

    }
  };

  /**
   * 当集合中元素等于3项则开始计算
   */
  private void calculate() {
    double number1 = Double.parseDouble(mList.get(0));
    if (mList.size() == 3) {
      double number2 = Double.parseDouble(mList.get(2));
      switch (mList.get(1)) {
        case "+":
          mResult = number1 + number2;
          break;
        case "-":
          mResult = number1 - number2;
          break;
        case "*":
          mResult = number1 * number2;
          break;
        case "/":
          if (number2 == 0) {
            Toast.makeText(this, "除数不能为0", Toast.LENGTH_SHORT).show();
          } else {
            mResult = number1 / number2;
          }
          break;
      }
      // 集合清空
      mList.clear();
      mList.add(String.valueOf(mResult));
    } else {// 解决5=0的情况,5+=的情况
      mResult = number1;
    }
  }

  /**
   * 初始化集合
   */
  private void initList() {
    mList = new ArrayList<>();
  }

  /**
   * 初始化控件,设置点击事件
   */
  private void initView() {
    tv = (TextView) findViewById(R.id.tv);
    findViewById(R.id.bt_0).setOnClickListener(this);
    findViewById(R.id.bt_1).setOnClickListener(this);
    findViewById(R.id.bt_2).setOnClickListener(this);
    findViewById(R.id.bt_3).setOnClickListener(this);
    findViewById(R.id.bt_4).setOnClickListener(this);
    findViewById(R.id.bt_5).setOnClickListener(this);
    findViewById(R.id.bt_6).setOnClickListener(this);
    findViewById(R.id.bt_7).setOnClickListener(this);
    findViewById(R.id.bt_8).setOnClickListener(this);
    findViewById(R.id.bt_9).setOnClickListener(this);
    findViewById(R.id.bt_add).setOnClickListener(this);
    findViewById(R.id.bt_sub).setOnClickListener(this);
    findViewById(R.id.bt_mul).setOnClickListener(this);
    findViewById(R.id.bt_div).setOnClickListener(this);
    findViewById(R.id.bt_dot).setOnClickListener(this);
    findViewById(R.id.bt_equal).setOnClickListener(this);
    findViewById(R.id.bt_clear).setOnClickListener(this);
  }

  // 设置按钮的点击事件
  @Override
  public void onClick(View view) {
    // 每次按钮被点击,都获取文本框内容
    String number = tv.getText().toString();

    switch (view.getId()) {
      case R.id.bt_0:
        if (!number.equals("0")) {// 前面不为0,才能追加0
          tv.append("0");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_1:
        if (number.equals("0")) {
          tv.setText("1");
        } else {
          tv.append("1");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_2:
        if (number.equals("0")) {
          tv.setText("2");
        } else {
          tv.append("2");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_3:
        if (number.equals("0")) {
          tv.setText("3");
        } else {
          tv.append("3");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_4:
        if (number.equals("0")) {
          tv.setText("4");
        } else {
          tv.append("4");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_5:
        if (number.equals("0")) {
          tv.setText("5");
        } else {
          tv.append("5");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_6:
        if (number.equals("0")) {
          tv.setText("6");
        } else {
          tv.append("6");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_7:
        if (number.equals("0")) {
          tv.setText("7");
        } else {
          tv.append("7");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_8:
        if (number.equals("0")) {
          tv.setText("8");
        } else {
          tv.append("8");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_9:
        if (number.equals("0")) {
          tv.setText("9");
        } else {
          tv.append("9");
        }
        initLocalHeCheng(mFlag, tv.getText().toString());
        break;
      case R.id.bt_add:
        // 语音朗读
        initLocalHeCheng(mFlag, "加");
        // 1.将当前屏幕上的数字保存到mList
        mList.add(number);
        // 2.判断是否满足3项并计算
        this.calculate();
        // 3.将"+"保存到mList
        mList.add("+");
        // 4.tv置0
        tv.setText("0");
        break;
      case R.id.bt_sub:
        // 语音朗读
        initLocalHeCheng(mFlag, "减");
        // 1.获取前屏幕上的数字保存到mList
        mList.add(number);
        // 2.判断是否满足3项并计算
        this.calculate();
        // 3.将"-"保存到mList
        mList.add("-");
        // 4.tv置0
        tv.setText("0");
        break;
      case R.id.bt_mul:
        // 语音朗读
        initLocalHeCheng(mFlag, "乘");
        // 1.获取前屏幕上的数字保存到mList
        mList.add(number);
        // 2.判断是否满足3项并计算
        this.calculate();
        // 3.将"*"保存到mList
        mList.add("*");
        // 4.tv置0
        tv.setText("0");
        break;
      case R.id.bt_div:
        // 语音朗读
        initLocalHeCheng(mFlag, "除");
        // 1.获取前屏幕上的数字保存到mList
        mList.add(number);
        // 2.判断是否满足3项并计算
        this.calculate();
        // 3.将"/"保存到mList
        mList.add("/");
        // 4.tv置0
        tv.setText("0");
        break;
      case R.id.bt_dot:
        // 1..53这种形式可以吗?xml默认显示0,clear时默认归0,则可解决这个问题
        // 2.0.53.5,显然,前面如有有了.,则不能再出现.
        if (!number.contains(".")) {// 前面不包含.才添加
          tv.append(".");
        }
        break;
      case R.id.bt_equal:
        // 1.获取前屏幕上的数字保存到mList
        mList.add(number);
        // 2.判断是否满足3项并计算
        this.calculate();
        // 3.tv显示结果
        tv.setText(String.valueOf(mResult));
        // 4.朗读结果
        initLocalHeCheng(mFlag, "等于" + tv.getText().toString());
        // 5.清空集合
        mList.clear();
        break;
      case R.id.bt_clear:
        // 语音朗读
        initLocalHeCheng(mFlag, "清除");

        tv.setText("0");
        mResult = 0;
        mList.clear();
        break;
    }
  }

}

xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:id="@+id/activity_main"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical"
  tools:context=".MainActivity">

  <TextView
    android:id="@+id/tv"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="2"
    android:background="#000"
    android:gravity="center_vertical|end"
    android:maxLines="1"
    android:text="@string/text"
    android:textColor="#fff"
    android:textSize="50sp" />

  <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:orientation="horizontal">

    <Button
      android:id="@+id/bt_7"
      style="@style/Button_Style"
      android:text="@string/_7" />

    <Button
      android:id="@+id/bt_8"
      style="@style/Button_Style"
      android:text="@string/_8" />

    <Button
      android:id="@+id/bt_9"
      style="@style/Button_Style"
      android:text="@string/_9" />

    <Button
      android:id="@+id/bt_div"
      style="@style/Button_Style"
      android:text="@string/div" />
  </LinearLayout>

  <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:orientation="horizontal">

    <Button
      android:id="@+id/bt_4"
      style="@style/Button_Style"
      android:text="@string/_4" />

    <Button
      android:id="@+id/bt_5"
      style="@style/Button_Style"
      android:text="@string/_5" />

    <Button
      android:id="@+id/bt_6"
      style="@style/Button_Style"
      android:text="@string/_6" />

    <Button
      android:id="@+id/bt_mul"
      style="@style/Button_Style"
      android:text="@string/mul" />
  </LinearLayout>

  <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:orientation="horizontal">

    <Button
      android:id="@+id/bt_1"
      style="@style/Button_Style"
      android:text="@string/_1" />

    <Button
      android:id="@+id/bt_2"
      style="@style/Button_Style"
      android:text="@string/_2" />

    <Button
      android:id="@+id/bt_3"
      style="@style/Button_Style"
      android:text="@string/_3" />

    <Button
      android:id="@+id/bt_sub"
      style="@style/Button_Style"
      android:text="@string/sub" />
  </LinearLayout>

  <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:orientation="horizontal">

    <Button
      android:id="@+id/bt_0"
      style="@style/Button_Style"
      android:text="@string/_0" />

    <Button
      android:id="@+id/bt_dot"
      style="@style/Button_Style"
      android:text="@string/dot" />

    <Button
      android:id="@+id/bt_equal"
      style="@style/Button_Style"
      android:text="@string/equal" />

    <Button
      android:id="@+id/bt_add"
      style="@style/Button_Style"
      android:text="@string/add" />
  </LinearLayout>

  <Button
    android:id="@+id/bt_clear"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:text="@string/clear"
    android:textAllCaps="false"
    android:textSize="25sp" />

</LinearLayout>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android计算器简单逻辑实现实例分享

    引言: 我的android计算器的实现方式是:按钮输入一次,就处理一次. 但是如果你学过数据结构(栈),就可以使用表达式解析(前缀,后缀)处理. 而这个方式已经很成熟了,但是时间有限,只完成了这个简单的计算器. 至于,这个Android的布局已经在我博客中发布了,不再讲述. 复制代码 代码如下: package com.example.androidlessontwo; import android.os.Bundle;import android.app.Activity;import and

  • 从零开始学android实现计算器功能示例分享(计算器源码)

    下面是效果展示: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="match

  • 简单实现Android计算器功能

    自己写的安卓的计算器: 注:这个是在mac中开发的,如果要在windows的eclipse中运行可能会出现路径问题,解决办法从windows中已有的安卓工程根目录下复制一下classpath文件,然后复制粘贴覆盖掉这个工程根目录里面的路径文件,再导入工程应该就可以打开了.  安卓计算器Android <wbr>calculator 工程下载链接:https://github.com/jiangxh1992/Android-Calculator 代码: package com.example.c

  • android计时器,时间计算器的实现方法

    需求:默认为"00:00:00",点击开始按钮时清零后开始计时,出现如10:28:34.点击停止的时候停止计时.问题:使用Calendar DateFormat的方法,不设置时区获取到的小时是本地时区的(东八区的就是8),设置成GMT标准时区获取到的时间是12小时(12:00:00),设置24小时制无效.在开始时间加减各种小时都无效,而且计时只能到12小时就自动跳上去了,始终无法出现默认状态00:00:00开始计时的效果.尝试各种时间设置方法无效后只能自己写一个根据秒数转换时间格式字符

  • Android计算器编写代码

    其实这个安卓计算机,所有的后台思想与<C#计算器编写代码>是一模一样的.Win窗体程序移植到安卓,从C#到Java其实很简单的,因为两者的基本语法都很相像,唯一的难点是安卓的xml布局部分,不像C#窗体能够直接拖.  还是如下图一个能够完成基本四则运算的计算器: 先在res\values\strings.xml设置按钮相应的字体,以免布局文件警告满天飞: <?xml version="1.0" encoding="utf-8"?> <r

  • Android中使用GridLayout网格布局来制作简单的计算器App

    关于GridLayout 在android4.0版本之前,如果想要达到网格布局的效果,首先可以考虑使用最常见的LinearLayout布局,但是这样的排布会产生如下几点问题: 1.不能同时在X,Y轴方向上进行控件的对齐. 2.当多层布局嵌套时会有性能问题. 3.不能稳定地支持一些支持自由编辑布局的工具. 其次考虑使用表格布局TabelLayout,这种方式会把包含的元素以行和列的形式进行排列,每行为一个TableRow对象,也可以是一个View对象,而在TableRow中还可以继续添加其他的控件

  • Android实战教程第一篇之最简单的计算器

    从今天开始,本专栏持续更新Android简易实战类博客文章.和以往专栏不同,此专栏只有实例.每个实例尽量按照知识点对应相应一章节的内容去写,循序渐进.有些实例可能会与另一个专栏有重复的文章. 开始本专栏的第一个简易案例: 首先设置两个布局文件,一个布局文件进行输入数据,获取加法运算:另一个布局文件进行显示最终结果.Activity1启动Activity2,并传递计算结果值给Activity2. main.xml: <?xml version="1.0" encoding=&quo

  • android计算器代码示例分享

    复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?><EditText    android:id="@+id/editText1"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:ems="10&quo

  • android计算器简单实现代码

    本文实例为大家分享了android计算器的具体实现代码,供大家参考,具体内容如下 java代码: package com.itheima74.simplecalculator4; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.Menu; import android.view.MenuItem; import android.view.View; imp

  • Android开发简单计算器实现代码

    计算器项目,要求实现加.减.乘.除.求倒数.求平方根等简单运算. 真机调试结果如下图: 布局文件:main_activity.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_pare

  • android实现简单计算器功能

    本文实例为大家分享了android实现简单计算器的具体代码,供大家参考,具体内容如下 // 日期:2014/9/26 // 首先,人们的输入习惯为中缀表达式.为了便于计算,程序会将中缀表达式会转换为后缀表达式 //////////////////////////////////////////////////////////////////////////////////////// // 目前软件还存在 // 1.输入运算数和运算符不匹配时,崩溃的现象.(如:只输入一个操作数) // 2.一个

  • Android实现简单加法计算器

    本文实例为大家分享了Android实现简单加法计算器的具体代码,供大家参考,具体内容如下 package com.example.calculator; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.view.View; import android.widget.Button; import android.widget.EditText; impo

  • Android实现简单计算器

    本文实例为大家分享了Android实现简单计算器的具体代码,供大家参考,具体内容如下 功能 1.加减乘除四则运算 2.归0 3.回退 4.即时运算 配置 在build.gradle(app) 中加入下面的代码 buildFeatures { viewBinding = true } 加入位置如下所示 compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSIO

  • Android 多种简单的弹出框样式设置代码

    简介 这是一个基于AlertDialog和Dialog这两个类封装的多种弹出框样式,其中提供各种简单样式的弹出框使用说明.同时也可自定义弹出框. 项目地址:http://www.github.com/jjdxmashl/jjdxm_dialogui 特性 1.使用链式开发代码简洁明了 2.所有的弹出框样式都在DialogUIUtils这个类中完成,方便查阅方法 3.可以自定义弹出框字体样式 4.简单的类似加载框的样式可以支持两种主题更改默认白色和灰色 截图 demo下载 demo apk下载 D

  • Android毛玻璃背景效果简单实现代码

    思路: 1.使用findViewByid获得需要设置毛玻璃的控件. 2.调用 setBlurBackground(Bitmap bmp)方法(下面会给出),参数为Bitmap类型,给控件设置毛玻璃背景! 3.已完成, 方法: /** * 设置毛玻璃背景 * 背景图片 Bitmap */ private void setBlurBackground(Bitmap bmp) { final Bitmap blurBmp = BlurUtil.fastblur(ParentCircleInfoActi

  • android 应用内部悬浮可拖动按钮简单实现代码

    本文介绍了android 应用内部悬浮可拖动按钮简单实现代码,分享给大家,具体如下: 可以悬浮在activity上面,在加载fragment时悬浮按钮不会消失 实现方式很简单,因为是在应用内部拖动的,只需要通过Activity获取WindowManager,然后将要拖动的view设置上去就行 设置代码: WindowManager wm = (WindowManager) activity.getSystemService(Context.WINDOW_SERVICE); DisplayMetr

随机推荐