liuyuqi-dellpc 4 years ago
commit
6c27b3cae5
58 changed files with 1150 additions and 0 deletions
  1. 6 0
      .gitignore
  2. 5 0
      README.md
  3. 1 0
      app/.gitignore
  4. 34 0
      app/build.gradle
  5. BIN
      app/libs/Msc.jar
  6. 17 0
      app/proguard-rules.pro
  7. 26 0
      app/src/androidTest/java/com/zqx/kedaxunfei/ExampleInstrumentedTest.java
  8. 29 0
      app/src/main/AndroidManifest.xml
  9. 19 0
      app/src/main/java/com/zqx/kedaxunfei/App.java
  10. 127 0
      app/src/main/java/com/zqx/kedaxunfei/activity/MainActivity.java
  11. 55 0
      app/src/main/java/com/zqx/kedaxunfei/adapter/MyBaseAdapter.java
  12. 49 0
      app/src/main/java/com/zqx/kedaxunfei/adapter/SpeakerAdapter.java
  13. 58 0
      app/src/main/java/com/zqx/kedaxunfei/bean/Speaker.java
  14. 9 0
      app/src/main/java/com/zqx/kedaxunfei/constants/Keys.java
  15. 56 0
      app/src/main/java/com/zqx/kedaxunfei/utils/SpUtil.java
  16. 28 0
      app/src/main/java/com/zqx/kedaxunfei/view/BottomDialog.java
  17. BIN
      app/src/main/jniLibs/arm64-v8a/libmsc.so
  18. BIN
      app/src/main/jniLibs/armeabi-v7a/libmsc.so
  19. BIN
      app/src/main/jniLibs/armeabi/libmsc.so
  20. BIN
      app/src/main/jniLibs/x86_64/libmsc.so
  21. 8 0
      app/src/main/res/anim/dialog_bottom_exit.xml
  22. 8 0
      app/src/main/res/anim/dialog_bottom_in.xml
  23. 6 0
      app/src/main/res/anim/dialog_top_exit.xml
  24. 7 0
      app/src/main/res/anim/dialog_top_in.xml
  25. 5 0
      app/src/main/res/drawable/selector_btn.xml
  26. 5 0
      app/src/main/res/drawable/selector_currspker.xml
  27. 7 0
      app/src/main/res/drawable/shadow.xml
  28. 10 0
      app/src/main/res/drawable/shape_bg.xml
  29. 10 0
      app/src/main/res/drawable/shape_seekbar_thumb.xml
  30. 112 0
      app/src/main/res/layout/activity_main.xml
  31. 35 0
      app/src/main/res/layout/dialog_speaker.xml
  32. 21 0
      app/src/main/res/layout/item_speaker.xml
  33. 25 0
      app/src/main/res/layout/view_bg_main.xml
  34. BIN
      app/src/main/res/mipmap-mdpi/dengziqi.webp
  35. BIN
      app/src/main/res/mipmap-mdpi/henry.webp
  36. BIN
      app/src/main/res/mipmap-mdpi/laosun.webp
  37. BIN
      app/src/main/res/mipmap-mdpi/tanglaoya.webp
  38. BIN
      app/src/main/res/mipmap-mdpi/xiaokun.webp
  39. BIN
      app/src/main/res/mipmap-mdpi/xiaomei.webp
  40. BIN
      app/src/main/res/mipmap-mdpi/xiaoqian.webp
  41. BIN
      app/src/main/res/mipmap-mdpi/xiaoqiang.webp
  42. BIN
      app/src/main/res/mipmap-mdpi/xiaorong.webp
  43. BIN
      app/src/main/res/mipmap-mdpi/xiaowanzi.webp
  44. BIN
      app/src/main/res/mipmap-mdpi/xiaoxin.webp
  45. BIN
      app/src/main/res/mipmap-mdpi/xiaoyan.webp
  46. BIN
      app/src/main/res/mipmap-xxhdpi/ic_launcher.png
  47. 6 0
      app/src/main/res/values-w820dp/dimens.xml
  48. 9 0
      app/src/main/res/values/colors.xml
  49. 5 0
      app/src/main/res/values/dimens.xml
  50. 3 0
      app/src/main/res/values/strings.xml
  51. 24 0
      app/src/main/res/values/style_dialog.xml
  52. 11 0
      app/src/main/res/values/styles.xml
  53. 17 0
      app/src/test/java/com/zqx/kedaxunfei/ExampleUnitTest.java
  54. 23 0
      build.gradle
  55. 17 0
      gradle.properties
  56. 172 0
      gradlew
  57. 84 0
      gradlew.bat
  58. 1 0
      settings.gradle

+ 6 - 0
.gitignore

@@ -0,0 +1,6 @@
+.gradle/
+.idea/
+build/
+gradle/
+local.properties
+*.iml

+ 5 - 0
README.md

@@ -0,0 +1,5 @@
+借助科大讯飞sdk 的文字转语音小应用
+<p/>
+APK下载链接: <a>https://github.com/ZhangQixiangChina/XunfeiVoice/raw/master/XunfeiVoice.apk<a/>
+<p/>
+<img src="pics/screenshort.png" width = "300" height = "534"/>

+ 1 - 0
app/.gitignore

@@ -0,0 +1 @@
+/build

+ 34 - 0
app/build.gradle

@@ -0,0 +1,34 @@
+apply plugin: 'com.android.application'
+
+android {
+    compileSdkVersion 25
+    buildToolsVersion '26.0.2'
+    defaultConfig {
+        applicationId "com.zqx.kedaxunfei"
+        minSdkVersion 19
+        targetSdkVersion 25
+        versionCode 1
+        versionName "1.0"
+        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
+    }
+    buildTypes {
+        release {
+            minifyEnabled false
+            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
+        }
+    }
+}
+
+dependencies {
+    compile fileTree(include: ['*.jar'], dir: 'libs')
+    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
+        exclude group: 'com.android.support', module: 'support-annotations'
+    })
+    compile 'com.android.support:appcompat-v7:25.1.0'
+    testCompile 'junit:junit:4.12'
+    compile 'com.jakewharton:butterknife:8.4.0'
+    annotationProcessor 'com.jakewharton:butterknife-compiler:8.4.0'
+    compile files('libs/Msc.jar')
+    compile 'com.android.support:cardview-v7:25.1.0'
+    compile 'homhomlin.lib:sldinglayout:0.9.0'
+}

BIN
app/libs/Msc.jar


+ 17 - 0
app/proguard-rules.pro

@@ -0,0 +1,17 @@
+# Add project specific ProGuard rules here.
+# By default, the flags in this file are appended to flags specified
+# in B:\01_software\AndroidSDK/tools/proguard/proguard-android.txt
+# You can edit the include path and order by changing the proguardFiles
+# directive in build.gradle.
+#
+# For more details, see
+#   http://developer.android.com/guide/developing/tools/proguard.html
+
+# Add any project specific keep options here:
+
+# If your project uses WebView with JS, uncomment the following
+# and specify the fully qualified class name to the JavaScript interface
+# class:
+#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
+#   public *;
+#}

+ 26 - 0
app/src/androidTest/java/com/zqx/kedaxunfei/ExampleInstrumentedTest.java

@@ -0,0 +1,26 @@
+package com.zqx.kedaxunfei;
+
+import android.content.Context;
+import android.support.test.InstrumentationRegistry;
+import android.support.test.runner.AndroidJUnit4;
+
+import org.junit.Test;
+import org.junit.runner.RunWith;
+
+import static org.junit.Assert.*;
+
+/**
+ * Instrumentation test, which will execute on an Android device.
+ *
+ * @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
+ */
+@RunWith(AndroidJUnit4.class)
+public class ExampleInstrumentedTest {
+    @Test
+    public void useAppContext() throws Exception {
+        // Context of the app under test.
+        Context appContext = InstrumentationRegistry.getTargetContext();
+
+        assertEquals("com.zqx.kedaxunfei", appContext.getPackageName());
+    }
+}

+ 29 - 0
app/src/main/AndroidManifest.xml

@@ -0,0 +1,29 @@
+<?xml version="1.0" encoding="utf-8"?>
+<manifest xmlns:android="http://schemas.android.com/apk/res/android"
+    package="com.zqx.kedaxunfei">
+    <uses-permission android:name="android.permission.RECORD_AUDIO" />
+    <uses-permission android:name="android.permission.INTERNET" />
+    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
+    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
+    <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
+    <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
+    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
+    <uses-permission android:name="android.permission.READ_CONTACTS"/>
+    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
+    <application
+        android:name="App"
+        android:allowBackup="true"
+        android:icon="@mipmap/ic_launcher"
+        android:label="@string/app_name"
+        android:supportsRtl="true"
+        android:theme="@style/AppTheme">
+        <activity android:name=".activity.MainActivity">
+            <intent-filter>
+                <action android:name="android.intent.action.MAIN" />
+
+                <category android:name="android.intent.category.LAUNCHER" />
+            </intent-filter>
+        </activity>
+    </application>
+
+</manifest>

+ 19 - 0
app/src/main/java/com/zqx/kedaxunfei/App.java

@@ -0,0 +1,19 @@
+package com.zqx.kedaxunfei;
+
+import android.app.Application;
+
+import com.iflytek.cloud.SpeechUtility;
+
+/**
+ * Created by ZhangQixiang on 2017/1/6.
+ */
+public class App extends Application {
+
+    private static final String APPID = "appid=586d1a59";
+    @Override
+    public void onCreate() {
+        super.onCreate();
+        SpeechUtility.createUtility(this, APPID);
+
+    }
+}

+ 127 - 0
app/src/main/java/com/zqx/kedaxunfei/activity/MainActivity.java

@@ -0,0 +1,127 @@
+package com.zqx.kedaxunfei.activity;
+
+import android.app.Dialog;
+import android.os.Bundle;
+import android.support.v7.app.AppCompatActivity;
+import android.view.View;
+import android.widget.AdapterView;
+import android.widget.EditText;
+import android.widget.ImageView;
+import android.widget.ListView;
+import android.widget.SeekBar;
+import android.widget.TextView;
+
+import com.iflytek.cloud.SpeechConstant;
+import com.iflytek.cloud.SpeechSynthesizer;
+import com.zqx.kedaxunfei.R;
+import com.zqx.kedaxunfei.adapter.SpeakerAdapter;
+import com.zqx.kedaxunfei.bean.Speaker;
+import com.zqx.kedaxunfei.constants.Keys;
+import com.zqx.kedaxunfei.utils.SpUtil;
+import com.zqx.kedaxunfei.view.BottomDialog;
+
+import java.util.List;
+
+import butterknife.BindView;
+import butterknife.ButterKnife;
+
+public class MainActivity extends AppCompatActivity {
+
+    @BindView(R.id.et)
+    EditText mEt;
+    @BindView(R.id.iv_curspk_icon)
+    ImageView mIvCurspkIcon;
+    @BindView(R.id.tv_curspk_desc)
+    TextView mTvCurspkDesc;
+    @BindView(R.id.seekBar)
+    SeekBar mSeekBar;
+
+    private Dialog mDialog;
+    private SpeakerAdapter mSpeakerAdapter;
+    private SpeechSynthesizer mTts;
+    private int curSpkPos;
+    private List<Speaker> mSpeakers ;
+    private Speaker mLastSpk;
+
+    @Override
+    protected void onCreate(Bundle savedInstanceState) {
+        super.onCreate(savedInstanceState);
+        setContentView(R.layout.activity_main);
+        ButterKnife.bind(this);
+        initSpeechParams();//初始化发音系统参数
+        mSpeakers = Speaker.getAllSpeakers();//得到发音人模型的集合
+        initLast();//初始化上一次退出时的EditText内容和上次选择的发音人数据
+        initDialogLv();//初始化发音人选择对话框
+
+    }
+
+    private void initLast() {
+        String lastText = SpUtil.getString(this, Keys.LAST_TEXT, "");
+        mEt.setText(lastText);
+
+        int lastPos = SpUtil.getInt(this, Keys.LAST_SPK_POS, 0);//默认为0位发音人
+        mLastSpk = mSpeakers.get(lastPos);
+        mIvCurspkIcon.setImageResource(mLastSpk.iconId);
+        mTvCurspkDesc.setText(mLastSpk.desc);
+        setVoice(mLastSpk.voice);
+    }
+
+
+    private void initSpeechParams() {
+        mTts = SpeechSynthesizer.createSynthesizer(this, null);
+        mTts.setParameter(SpeechConstant.VOICE_NAME, "xiaoyan");//设置发音人
+        mTts.setParameter(SpeechConstant.SPEED, "50");//设置语速
+        mTts.setParameter(SpeechConstant.VOLUME, "80");//设置音量,范围0~100
+        mTts.setParameter(SpeechConstant.ENGINE_TYPE, SpeechConstant.TYPE_CLOUD); //设置云端
+    }
+
+    private void setSpeed(int num) {
+        mTts.setParameter(SpeechConstant.SPEED, "" + num);//设置语速
+    }
+
+    private void initDialogLv() {
+        View viewDialog = View.inflate(this, R.layout.dialog_speaker, null);
+        ListView lvSpeaker = (ListView) viewDialog.findViewById(R.id.lv_speaker);
+        mSpeakerAdapter = new SpeakerAdapter(mSpeakers);
+        lvSpeaker.setAdapter(mSpeakerAdapter);
+        lvSpeaker.setOnItemClickListener(new AdapterView.OnItemClickListener() {
+            @Override
+            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
+                Speaker item = mSpeakerAdapter.getItem(position);
+                setVoice(item.voice);
+                mTvCurspkDesc.setText(item.desc);
+                mIvCurspkIcon.setImageResource(item.iconId);
+                curSpkPos = position;
+                mDialog.dismiss();
+            }
+        });
+
+        mDialog = new BottomDialog(this);
+        mDialog.setContentView(viewDialog);
+        mDialog.setCanceledOnTouchOutside(true);
+
+    }
+
+    private void setVoice(String voice) {
+        mTts.setParameter(SpeechConstant.VOICE_NAME, voice);
+    }
+
+    public void onSpeakClick(View view) {
+        String text = mEt.getText().toString().trim();
+        int progress = mSeekBar.getProgress();
+        setSpeed(progress);
+        mTts.startSpeaking(text, null);
+    }
+
+    public void onSpkerSwitchClick(View view) {
+        mDialog.show();
+    }
+
+    @Override
+    protected void onPause() {
+        super.onPause();
+        SpUtil.saveInt(this, Keys.LAST_SPK_POS, curSpkPos);
+        String lastText = mEt.getText().toString().trim();
+        SpUtil.saveString(this, Keys.LAST_TEXT, lastText);
+    }
+}

+ 55 - 0
app/src/main/java/com/zqx/kedaxunfei/adapter/MyBaseAdapter.java

@@ -0,0 +1,55 @@
+package com.zqx.kedaxunfei.adapter;
+
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.BaseAdapter;
+
+import java.util.List;
+
+/**
+ * Created by ZhangQixiang on 2017/1/6.
+ */
+public abstract class MyBaseAdapter<T>extends BaseAdapter{
+
+    private List<T> mDatas;
+
+    public MyBaseAdapter(List<T> datas){
+
+        mDatas = datas;
+    }
+
+    @Override
+    public int getCount() {
+        return mDatas.size();
+    }
+
+    @Override
+    public T getItem(int position) {
+        return mDatas.get(position);
+    }
+
+    @Override
+    public long getItemId(int position) {
+        return position;
+    }
+
+    @Override
+    public View getView(int position, View convertView, ViewGroup parent) {
+        Object vh;
+        if (convertView == null) {
+            convertView = View.inflate(parent.getContext(), getLayoutRes(), null);
+             vh = getViewHolder(convertView);
+            convertView.setTag(vh);
+        }else {
+            vh = convertView.getTag();
+        }
+        setData(position,convertView,parent,vh);
+        return convertView;
+    }
+
+    protected abstract void setData(int position, View convertView, ViewGroup parent, Object vh);
+
+    protected abstract Object getViewHolder(View convertView);
+
+    public abstract int getLayoutRes();
+}

+ 49 - 0
app/src/main/java/com/zqx/kedaxunfei/adapter/SpeakerAdapter.java

@@ -0,0 +1,49 @@
+package com.zqx.kedaxunfei.adapter;
+
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.ImageView;
+import android.widget.TextView;
+
+import com.zqx.kedaxunfei.R;
+import com.zqx.kedaxunfei.bean.Speaker;
+
+import java.util.List;
+
+/**
+ * Created by ZhangQixiang on 2017/1/6.
+ */
+public class SpeakerAdapter extends MyBaseAdapter<Speaker> {
+
+    public SpeakerAdapter(List<Speaker> datas) {
+        super(datas);
+    }
+
+    @Override
+    protected void setData(int position, View convertView, ViewGroup parent, Object viewHolder) {
+        ViewHolder vh = (ViewHolder) viewHolder;
+        Speaker item = getItem(position);
+        vh.iv.setImageResource(item.iconId);
+        vh.tv.setText(item.desc);
+    }
+
+    @Override
+    protected Object getViewHolder(View convertView) {
+        return new ViewHolder(convertView);
+    }
+
+    private static  class ViewHolder{
+        ImageView iv;
+        TextView tv;
+
+        ViewHolder(View view) {
+            iv = (ImageView) view.findViewById(R.id.iv_speaker_icon);;
+            tv = (TextView) view.findViewById(R.id.tv_speaker_desc);
+        }
+    }
+
+    @Override
+    public int getLayoutRes() {
+        return R.layout.item_speaker;
+    }
+}

+ 58 - 0
app/src/main/java/com/zqx/kedaxunfei/bean/Speaker.java

@@ -0,0 +1,58 @@
+package com.zqx.kedaxunfei.bean;
+
+import com.zqx.kedaxunfei.R;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+
+/**
+ * Created by Zhang Qixiang on 2017/12/1.
+ */
+
+public enum Speaker {
+
+    xiaoyan(R.mipmap.xiaoyan, "小燕 青年女声", "xiaoyan"),
+    laosun(R.mipmap.laosun, "老孙 中年男声", "vils"),
+    tanglaoya(R.mipmap.tanglaoya, "唐老鸭 卡通人物", "aisduck"),
+    xiaoxin(R.mipmap.xiaoxin, "小新 卡通人物", "xiaoxin"),
+    xiaowanzi(R.mipmap.xiaowanzi, "小丸子 卡通人物", "xiaowanzi"),
+    xiaomei(R.mipmap.xiaomei, "粤语 小梅 青年女声", "xiaomei"),
+    dengziqi(R.mipmap.dengziqi, "台普 小玲 青年女声", "aisxlin"),
+    xiaoqian(R.mipmap.xiaoqian, "东北 小倩 青年女声", "xiaoqian"),
+    xiaorong(R.mipmap.xiaorong, "四川 小蓉 青年女声", "aisxrong"),
+    xiaokun(R.mipmap.xiaokun, "河南 小坤 青年男声", "xiaokun"),
+    xiaoqiang(R.mipmap.xiaoqiang, "湖南 小强 青年男声", "aisxqiang"),
+    henry(R.mipmap.henry, "美式英语 亨利 青年男声", "henry");
+
+
+    public int iconId;
+    public String desc;
+    public String voice;
+
+    Speaker(int iconId, String desc, String stringParam) {
+        this.iconId = iconId;
+        this.desc = desc;
+        this.voice = stringParam;
+    }
+
+    public static List<Speaker> getAllSpeakers() {
+        return new ArrayList<>(
+                Arrays.asList(
+                        xiaoyan,
+                        laosun,
+                        tanglaoya,
+                        xiaoxin,
+                        xiaowanzi,
+                        xiaomei,
+                        dengziqi,
+                        xiaoqian,
+                        xiaorong,
+                        xiaokun,
+                        xiaoqiang,
+                        henry
+                )
+        );
+    }
+
+}

+ 9 - 0
app/src/main/java/com/zqx/kedaxunfei/constants/Keys.java

@@ -0,0 +1,9 @@
+package com.zqx.kedaxunfei.constants;
+
+/**
+ * Created by ZhangQixiang on 2017/1/6.
+ */
+public class Keys {
+public static final String LAST_SPK_POS  = "lastSpkPos";
+    public static final String LAST_TEXT = "lastText";
+}

+ 56 - 0
app/src/main/java/com/zqx/kedaxunfei/utils/SpUtil.java

@@ -0,0 +1,56 @@
+package com.zqx.kedaxunfei.utils;
+
+import android.content.Context;
+import android.content.SharedPreferences;
+
+public class SpUtil {
+
+	private static final String SP_NAME = "config";
+	private static SharedPreferences sp;
+
+	public static void saveBoolean(Context context, String key, boolean value) {
+		if (sp == null) {
+			sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
+		}
+		sp.edit().putBoolean(key, value).apply();
+	}
+
+	public static boolean getBoolean(Context context, String key,
+			boolean defValue) {
+		if (sp == null) {
+			sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
+		}
+		return sp.getBoolean(key, defValue);
+	}
+
+	public static void saveInt(Context context, String key, int value) {
+		if (sp == null) {
+			sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
+		}
+		sp.edit().putInt(key, value).apply();
+
+	}
+
+	public static int getInt(Context context, String key, int defValue) {
+		if (sp == null) {
+			sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
+		}
+		return sp.getInt(key, defValue);
+	}
+
+	public static String getString(Context context, String key, String defValue) {
+		if (sp == null) {
+			sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
+		}
+		return sp.getString(key,defValue);
+	}
+	public static void saveString(Context context, String key, String value) {
+		if (sp == null) {
+			sp = context.getSharedPreferences(SP_NAME, Context.MODE_PRIVATE);
+		}
+		sp.edit().putString(key, value).apply();
+
+	}
+
+
+}

+ 28 - 0
app/src/main/java/com/zqx/kedaxunfei/view/BottomDialog.java

@@ -0,0 +1,28 @@
+package com.zqx.kedaxunfei.view;
+
+import android.app.Dialog;
+import android.content.Context;
+import android.view.Gravity;
+import android.view.Window;
+import android.view.WindowManager;
+
+import com.zqx.kedaxunfei.R;
+
+/**
+ * Created by ZhangQixiang on 2017/1/5.
+ */
+public class BottomDialog extends Dialog {
+
+    public BottomDialog(Context context) {
+        super(context, R.style.dialog_bottom_style);
+        Window window = getWindow();
+        if (window != null) {
+            WindowManager.LayoutParams attributes = window.getAttributes();
+            attributes.height = WindowManager.LayoutParams.WRAP_CONTENT;
+            attributes.gravity = Gravity.BOTTOM;
+            window.setAttributes(attributes);
+        }
+    }
+
+
+}

BIN
app/src/main/jniLibs/arm64-v8a/libmsc.so


BIN
app/src/main/jniLibs/armeabi-v7a/libmsc.so


BIN
app/src/main/jniLibs/armeabi/libmsc.so


BIN
app/src/main/jniLibs/x86_64/libmsc.so


+ 8 - 0
app/src/main/res/anim/dialog_bottom_exit.xml

@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="utf-8"?>
+<set xmlns:android="http://schemas.android.com/apk/res/android">
+    <translate
+        android:duration="250"
+        android:fromYDelta="0%"
+        android:interpolator="@android:anim/accelerate_interpolator"
+        android:toYDelta="100%" />
+</set>

+ 8 - 0
app/src/main/res/anim/dialog_bottom_in.xml

@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="utf-8"?>
+<set xmlns:android="http://schemas.android.com/apk/res/android">
+    <translate
+        android:duration="250"
+        android:fromYDelta="100%"
+        android:interpolator="@android:anim/decelerate_interpolator"
+        android:toYDelta="0%" />
+</set>

+ 6 - 0
app/src/main/res/anim/dialog_top_exit.xml

@@ -0,0 +1,6 @@
+<?xml version="1.0" encoding="utf-8"?>
+<translate xmlns:android="http://schemas.android.com/apk/res/android"
+    android:duration="500"
+    android:fromYDelta="0%"
+    android:interpolator="@android:anim/accelerate_interpolator"
+    android:toYDelta="-100%" />

+ 7 - 0
app/src/main/res/anim/dialog_top_in.xml

@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="utf-8"?>
+<translate xmlns:android="http://schemas.android.com/apk/res/android"
+    android:duration="500"
+    android:fromYDelta="-100%"
+    android:interpolator="@android:anim/decelerate_interpolator"
+    android:toYDelta="0%" />
+

+ 5 - 0
app/src/main/res/drawable/selector_btn.xml

@@ -0,0 +1,5 @@
+<?xml version="1.0" encoding="utf-8"?>
+<selector xmlns:android="http://schemas.android.com/apk/res/android">
+    <item android:state_pressed="true" android:drawable="@color/colorPrimaryDark" />
+    <item android:drawable="@color/colorPrimary" />
+</selector>

+ 5 - 0
app/src/main/res/drawable/selector_currspker.xml

@@ -0,0 +1,5 @@
+<?xml version="1.0" encoding="utf-8"?>
+<selector xmlns:android="http://schemas.android.com/apk/res/android">
+    <item android:state_pressed="true" android:drawable="@color/shadow_end" />
+    <item android:drawable="@android:color/transparent" />
+</selector>

+ 7 - 0
app/src/main/res/drawable/shadow.xml

@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="utf-8"?>
+<shape xmlns:android="http://schemas.android.com/apk/res/android">
+    <gradient
+        android:angle="-90"
+        android:endColor="@color/shadow_end"
+        android:startColor="@color/shadow_start" />
+</shape>

+ 10 - 0
app/src/main/res/drawable/shape_bg.xml

@@ -0,0 +1,10 @@
+<?xml version="1.0" encoding="utf-8"?>
+<shape xmlns:android="http://schemas.android.com/apk/res/android"
+    android:shape="rectangle">
+    <stroke
+        android:width="1dp"
+        android:color="@color/colorPrimary" />
+    <corners android:radius="5dp" />
+    <solid android:color="@null" />
+
+</shape>

+ 10 - 0
app/src/main/res/drawable/shape_seekbar_thumb.xml

@@ -0,0 +1,10 @@
+<?xml version="1.0" encoding="utf-8"?>
+<shape xmlns:android="http://schemas.android.com/apk/res/android"
+    android:shape="oval"
+    >
+    <solid android:color="@color/colorPrimary" />
+    <size
+        android:height="12dp"
+        android:width="12dp" />
+
+</shape>

+ 112 - 0
app/src/main/res/layout/activity_main.xml

@@ -0,0 +1,112 @@
+<?xml version="1.0" encoding="utf-8"?>
+<lib.homhomlib.design.SlidingLayout xmlns:android="http://schemas.android.com/apk/res/android"
+    xmlns:app="http://schemas.android.com/apk/res-auto"
+    android:layout_width="match_parent"
+    android:layout_height="match_parent"
+    app:background_view="@layout/view_bg_main"
+    app:sliding_mode="top"
+    app:top_max="80dp">
+
+    <!--注: 这里的clickable给true是因为SlidingLayout这个第三方控件的bug-->
+    <LinearLayout
+        android:layout_width="match_parent"
+        android:layout_height="match_parent"
+        android:background="#f4f4f4"
+        android:clickable="true"
+        android:orientation="vertical"
+        android:paddingBottom="5dp"
+        android:paddingLeft="12dp"
+        android:paddingRight="12dp"
+        android:paddingTop="12dp">
+
+        <EditText
+            android:id="@+id/et"
+            android:layout_width="match_parent"
+            android:layout_height="wrap_content"
+            android:background="@drawable/shape_bg"
+            android:gravity="top"
+            android:hint="请输入文字"
+            android:lines="8"
+            android:padding="5dp"
+            android:textSize="20sp" />
+
+        <android.support.v7.widget.CardView
+            android:layout_width="match_parent"
+            android:layout_height="wrap_content"
+            android:layout_marginLeft="1dp"
+            android:layout_marginRight="1dp"
+            android:layout_marginTop="12dp">
+
+            <LinearLayout
+                android:layout_width="match_parent"
+                android:layout_height="wrap_content"
+                android:background="@drawable/selector_currspker"
+                android:clickable="true"
+                android:gravity="center_vertical"
+                android:onClick="onSpkerSwitchClick"
+                android:orientation="horizontal"
+                android:padding="7dp">
+
+                <ImageView
+                    android:id="@+id/iv_curspk_icon"
+                    android:layout_width="40dp"
+                    android:layout_height="40dp"
+                    android:src="@mipmap/xiaoyan" />
+
+                <TextView
+                    android:id="@+id/tv_curspk_desc"
+                    android:layout_width="match_parent"
+                    android:layout_height="wrap_content"
+                    android:layout_marginLeft="5dp"
+                    android:text="小燕 青年女声"
+                    android:textSize="18sp" />
+            </LinearLayout>
+        </android.support.v7.widget.CardView>
+
+        <LinearLayout
+            android:layout_width="match_parent"
+            android:layout_height="wrap_content"
+            android:layout_marginTop="20dp"
+            android:gravity="center_vertical"
+            android:orientation="horizontal">
+
+            <TextView
+                android:layout_width="wrap_content"
+                android:layout_height="wrap_content"
+                android:text="语速:"
+                android:textSize="15sp" />
+
+            <SeekBar
+                android:progress="50"
+                android:id="@+id/seekBar"
+                android:layout_width="match_parent"
+                android:layout_height="wrap_content"
+                android:thumb="@drawable/shape_seekbar_thumb" />
+        </LinearLayout>
+
+        <Button
+            android:layout_width="match_parent"
+            android:layout_height="wrap_content"
+            android:layout_marginTop="20dp"
+            android:background="@drawable/selector_btn"
+            android:onClick="onSpeakClick"
+            android:text="点我说话"
+            android:textColor="#fff"
+            android:textSize="18sp" />
+
+
+
+        <FrameLayout
+            android:layout_width="match_parent"
+            android:layout_height="0dp"
+            android:layout_weight="1" />
+
+        <TextView
+            android:layout_width="match_parent"
+            android:layout_height="wrap_content"
+            android:gravity="center"
+            android:text="由科大讯飞提供技术支持"
+            android:textSize="13sp" />
+    </LinearLayout>
+
+</lib.homhomlib.design.SlidingLayout>

+ 35 - 0
app/src/main/res/layout/dialog_speaker.xml

@@ -0,0 +1,35 @@
+<?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="wrap_content"
+    android:orientation="vertical">
+
+    <TextView
+        android:layout_width="match_parent"
+        android:layout_height="wrap_content"
+        android:padding="5dp"
+        android:text="选择发音人"
+        android:textSize="18sp" />
+
+    <FrameLayout
+        android:layout_width="match_parent"
+        android:layout_height="wrap_content">
+
+
+        <ListView
+            android:id="@+id/lv_speaker"
+            android:layout_width="match_parent"
+            android:layout_height="350dp"
+            android:divider="@color/nineCGray"
+            android:dividerHeight="0.5dp"
+            android:orientation="vertical"
+            android:paddingLeft="5dp"
+            android:paddingRight="5dp" />
+
+        <View
+            android:layout_width="match_parent"
+            android:layout_height="4dp"
+            android:background="@drawable/shadow" />
+    </FrameLayout>
+</LinearLayout>
+

+ 21 - 0
app/src/main/res/layout/item_speaker.xml

@@ -0,0 +1,21 @@
+<?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="wrap_content"
+    android:padding="5dp"
+    android:background="@drawable/selector_currspker"
+    android:gravity="center_vertical"
+    android:orientation="horizontal">
+    <ImageView
+        android:id="@+id/iv_speaker_icon"
+        android:src= "@mipmap/xiaoyan"
+        android:layout_width="40dp"
+        android:layout_height="40dp" />
+    <TextView
+        android:id="@+id/tv_speaker_desc"
+        android:textSize="18sp"
+        android:text="小燕 青年女声"
+        android:layout_width="match_parent"
+        android:layout_height="wrap_content" />
+
+</LinearLayout>

+ 25 - 0
app/src/main/res/layout/view_bg_main.xml

@@ -0,0 +1,25 @@
+<?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_parent"
+    android:background="#282b2d"
+    android:gravity="center_horizontal"
+    android:orientation="vertical">
+
+    <TextView
+        android:layout_width="wrap_content"
+        android:layout_height="wrap_content"
+        android:layout_marginTop="5dp"
+        android:padding="5dp"
+        android:text="App由章启翔开发"
+        android:textColor="#626668"
+        android:textSize="15sp" />
+
+    <TextView
+        android:layout_width="wrap_content"
+        android:layout_height="wrap_content"
+        android:padding="5dp"
+        android:text="语音技术由科大讯飞提供"
+        android:textColor="#626668"
+        android:textSize="15sp" />
+</LinearLayout>

BIN
app/src/main/res/mipmap-mdpi/dengziqi.webp


BIN
app/src/main/res/mipmap-mdpi/henry.webp


BIN
app/src/main/res/mipmap-mdpi/laosun.webp


BIN
app/src/main/res/mipmap-mdpi/tanglaoya.webp


BIN
app/src/main/res/mipmap-mdpi/xiaokun.webp


BIN
app/src/main/res/mipmap-mdpi/xiaomei.webp


BIN
app/src/main/res/mipmap-mdpi/xiaoqian.webp


BIN
app/src/main/res/mipmap-mdpi/xiaoqiang.webp


BIN
app/src/main/res/mipmap-mdpi/xiaorong.webp


BIN
app/src/main/res/mipmap-mdpi/xiaowanzi.webp


BIN
app/src/main/res/mipmap-mdpi/xiaoxin.webp


BIN
app/src/main/res/mipmap-mdpi/xiaoyan.webp


BIN
app/src/main/res/mipmap-xxhdpi/ic_launcher.png


+ 6 - 0
app/src/main/res/values-w820dp/dimens.xml

@@ -0,0 +1,6 @@
+<resources>
+    <!-- Example customization of dimensions originally defined in res/values/dimens.xml
+         (such as screen margins) for screens with more than 820dp of available width. This
+         would include 7" and 10" devices in landscape (~960dp and ~1280dp respectively). -->
+    <dimen name="activity_horizontal_margin">64dp</dimen>
+</resources>

+ 9 - 0
app/src/main/res/values/colors.xml

@@ -0,0 +1,9 @@
+<?xml version="1.0" encoding="utf-8"?>
+<resources>
+    <color name="colorPrimary">#3F51B5</color>
+    <color name="colorPrimaryDark">#303F9F</color>
+    <color name="colorAccent">#69e93a</color>
+    <color name="nineCGray">#9c9c9c</color>
+    <color name="shadow_end">@android:color/transparent</color>
+    <color name="shadow_start">#779c9c9c</color>
+</resources>

+ 5 - 0
app/src/main/res/values/dimens.xml

@@ -0,0 +1,5 @@
+<resources>
+    <!-- Default screen margins, per the Android Design guidelines. -->
+    <dimen name="activity_horizontal_margin">16dp</dimen>
+    <dimen name="activity_vertical_margin">16dp</dimen>
+</resources>

+ 3 - 0
app/src/main/res/values/strings.xml

@@ -0,0 +1,3 @@
+<resources>
+    <string name="app_name">讯飞语音</string>
+</resources>

+ 24 - 0
app/src/main/res/values/style_dialog.xml

@@ -0,0 +1,24 @@
+<?xml version="1.0" encoding="utf-8"?>
+<resources>
+    <style name="dialog_top_style">
+        <item name="android:windowNoTitle">true</item>
+        <item name="android:windowAnimationStyle">@style/dialog_top_animation</item>
+        <item name="android:backgroundDimEnabled">true</item>
+    </style>
+
+    <style name="dialog_top_animation">
+        <item name="android:windowEnterAnimation">@anim/dialog_top_in</item>
+        <item name="android:windowExitAnimation">@anim/dialog_top_exit</item>
+    </style>
+
+    <style name="dialog_bottom_style">
+        <item name="android:windowNoTitle">true</item>
+        <item name="android:windowAnimationStyle">@style/dialog_bottom_animation</item>
+        <item name="android:backgroundDimEnabled">true</item>
+    </style>
+
+    <style name="dialog_bottom_animation">
+        <item name="android:windowEnterAnimation">@anim/dialog_bottom_in</item>
+        <item name="android:windowExitAnimation">@anim/dialog_bottom_exit</item>
+    </style>
+</resources>

+ 11 - 0
app/src/main/res/values/styles.xml

@@ -0,0 +1,11 @@
+<resources>
+
+    <!-- Base application theme. -->
+    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
+        <!-- Customize your theme here. -->
+        <item name="colorPrimary">@color/colorPrimary</item>
+        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
+        <item name="colorAccent">@color/colorAccent</item>
+    </style>
+
+</resources>

+ 17 - 0
app/src/test/java/com/zqx/kedaxunfei/ExampleUnitTest.java

@@ -0,0 +1,17 @@
+package com.zqx.kedaxunfei;
+
+import org.junit.Test;
+
+import static org.junit.Assert.*;
+
+/**
+ * Example local unit test, which will execute on the development machine (host).
+ *
+ * @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
+ */
+public class ExampleUnitTest {
+    @Test
+    public void addition_isCorrect() throws Exception {
+        assertEquals(4, 2 + 2);
+    }
+}

+ 23 - 0
build.gradle

@@ -0,0 +1,23 @@
+// Top-level build file where you can add configuration options common to all sub-projects/modules.
+
+buildscript {
+    repositories {
+        jcenter()
+    }
+    dependencies {
+        classpath 'com.android.tools.build:gradle:3.0.0'
+
+        // NOTE: Do not place your application dependencies here; they belong
+        // in the individual module build.gradle files
+    }
+}
+
+allprojects {
+    repositories {
+        jcenter()
+    }
+}
+
+task clean(type: Delete) {
+    delete rootProject.buildDir
+}

+ 17 - 0
gradle.properties

@@ -0,0 +1,17 @@
+# Project-wide Gradle settings.
+
+# IDE (e.g. Android Studio) users:
+# Gradle settings configured through the IDE *will override*
+# any settings specified in this file.
+
+# For more details on how to configure your build environment visit
+# http://www.gradle.org/docs/current/userguide/build_environment.html
+
+# Specifies the JVM arguments used for the daemon process.
+# The setting is particularly useful for tweaking memory settings.
+org.gradle.jvmargs=-Xmx1536m
+
+# When configured, Gradle will run in incubating parallel mode.
+# This option should only be used with decoupled projects. More details, visit
+# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
+# org.gradle.parallel=true

+ 172 - 0
gradlew

@@ -0,0 +1,172 @@
+#!/usr/bin/env sh
+
+##############################################################################
+##
+##  Gradle start up script for UN*X
+##
+##############################################################################
+
+# Attempt to set APP_HOME
+# Resolve links: $0 may be a link
+PRG="$0"
+# Need this for relative symlinks.
+while [ -h "$PRG" ] ; do
+    ls=`ls -ld "$PRG"`
+    link=`expr "$ls" : '.*-> \(.*\)$'`
+    if expr "$link" : '/.*' > /dev/null; then
+        PRG="$link"
+    else
+        PRG=`dirname "$PRG"`"/$link"
+    fi
+done
+SAVED="`pwd`"
+cd "`dirname \"$PRG\"`/" >/dev/null
+APP_HOME="`pwd -P`"
+cd "$SAVED" >/dev/null
+
+APP_NAME="Gradle"
+APP_BASE_NAME=`basename "$0"`
+
+# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+DEFAULT_JVM_OPTS=""
+
+# Use the maximum available, or set MAX_FD != -1 to use that value.
+MAX_FD="maximum"
+
+warn () {
+    echo "$*"
+}
+
+die () {
+    echo
+    echo "$*"
+    echo
+    exit 1
+}
+
+# OS specific support (must be 'true' or 'false').
+cygwin=false
+msys=false
+darwin=false
+nonstop=false
+case "`uname`" in
+  CYGWIN* )
+    cygwin=true
+    ;;
+  Darwin* )
+    darwin=true
+    ;;
+  MINGW* )
+    msys=true
+    ;;
+  NONSTOP* )
+    nonstop=true
+    ;;
+esac
+
+CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
+
+# Determine the Java command to use to start the JVM.
+if [ -n "$JAVA_HOME" ] ; then
+    if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
+        # IBM's JDK on AIX uses strange locations for the executables
+        JAVACMD="$JAVA_HOME/jre/sh/java"
+    else
+        JAVACMD="$JAVA_HOME/bin/java"
+    fi
+    if [ ! -x "$JAVACMD" ] ; then
+        die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+    fi
+else
+    JAVACMD="java"
+    which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+fi
+
+# Increase the maximum file descriptors if we can.
+if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
+    MAX_FD_LIMIT=`ulimit -H -n`
+    if [ $? -eq 0 ] ; then
+        if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
+            MAX_FD="$MAX_FD_LIMIT"
+        fi
+        ulimit -n $MAX_FD
+        if [ $? -ne 0 ] ; then
+            warn "Could not set maximum file descriptor limit: $MAX_FD"
+        fi
+    else
+        warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
+    fi
+fi
+
+# For Darwin, add options to specify how the application appears in the dock
+if $darwin; then
+    GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
+fi
+
+# For Cygwin, switch paths to Windows format before running java
+if $cygwin ; then
+    APP_HOME=`cygpath --path --mixed "$APP_HOME"`
+    CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
+    JAVACMD=`cygpath --unix "$JAVACMD"`
+
+    # We build the pattern for arguments to be converted via cygpath
+    ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
+    SEP=""
+    for dir in $ROOTDIRSRAW ; do
+        ROOTDIRS="$ROOTDIRS$SEP$dir"
+        SEP="|"
+    done
+    OURCYGPATTERN="(^($ROOTDIRS))"
+    # Add a user-defined pattern to the cygpath arguments
+    if [ "$GRADLE_CYGPATTERN" != "" ] ; then
+        OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
+    fi
+    # Now convert the arguments - kludge to limit ourselves to /bin/sh
+    i=0
+    for arg in "$@" ; do
+        CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
+        CHECK2=`echo "$arg"|egrep -c "^-"`                                 ### Determine if an option
+
+        if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then                    ### Added a condition
+            eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
+        else
+            eval `echo args$i`="\"$arg\""
+        fi
+        i=$((i+1))
+    done
+    case $i in
+        (0) set -- ;;
+        (1) set -- "$args0" ;;
+        (2) set -- "$args0" "$args1" ;;
+        (3) set -- "$args0" "$args1" "$args2" ;;
+        (4) set -- "$args0" "$args1" "$args2" "$args3" ;;
+        (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
+        (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
+        (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
+        (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
+        (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
+    esac
+fi
+
+# Escape application args
+save () {
+    for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
+    echo " "
+}
+APP_ARGS=$(save "$@")
+
+# Collect all arguments for the java command, following the shell quoting and substitution rules
+eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
+
+# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong
+if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then
+  cd "$(dirname "$0")"
+fi
+
+exec "$JAVACMD" "$@"

+ 84 - 0
gradlew.bat

@@ -0,0 +1,84 @@
+@if "%DEBUG%" == "" @echo off
+@rem ##########################################################################
+@rem
+@rem  Gradle startup script for Windows
+@rem
+@rem ##########################################################################
+
+@rem Set local scope for the variables with windows NT shell
+if "%OS%"=="Windows_NT" setlocal
+
+set DIRNAME=%~dp0
+if "%DIRNAME%" == "" set DIRNAME=.
+set APP_BASE_NAME=%~n0
+set APP_HOME=%DIRNAME%
+
+@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+set DEFAULT_JVM_OPTS=
+
+@rem Find java.exe
+if defined JAVA_HOME goto findJavaFromJavaHome
+
+set JAVA_EXE=java.exe
+%JAVA_EXE% -version >NUL 2>&1
+if "%ERRORLEVEL%" == "0" goto init
+
+echo.
+echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:findJavaFromJavaHome
+set JAVA_HOME=%JAVA_HOME:"=%
+set JAVA_EXE=%JAVA_HOME%/bin/java.exe
+
+if exist "%JAVA_EXE%" goto init
+
+echo.
+echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:init
+@rem Get command-line arguments, handling Windows variants
+
+if not "%OS%" == "Windows_NT" goto win9xME_args
+
+:win9xME_args
+@rem Slurp the command line arguments.
+set CMD_LINE_ARGS=
+set _SKIP=2
+
+:win9xME_args_slurp
+if "x%~1" == "x" goto execute
+
+set CMD_LINE_ARGS=%*
+
+:execute
+@rem Setup the command line
+
+set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
+
+@rem Execute Gradle
+"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
+
+:end
+@rem End local scope for the variables with windows NT shell
+if "%ERRORLEVEL%"=="0" goto mainEnd
+
+:fail
+rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
+rem the _cmd.exe /c_ return code!
+if  not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
+exit /b 1
+
+:mainEnd
+if "%OS%"=="Windows_NT" endlocal
+
+:omega

+ 1 - 0
settings.gradle

@@ -0,0 +1 @@
+include ':app'