Commit 0648fe46aa4e4fe63eb3d3ee24a76227f9f655dc
1 parent
d37e980ebb
Exists in
master
绑定老师
Showing
14 changed files
with
688 additions
and
79 deletions
Show diff stats
app/src/main/AndroidManifest.xml
| 1 | <?xml version="1.0" encoding="utf-8"?> | 1 | <?xml version="1.0" encoding="utf-8"?> |
| 2 | <manifest xmlns:android="http://schemas.android.com/apk/res/android" | 2 | <manifest xmlns:android="http://schemas.android.com/apk/res/android" |
| 3 | xmlns:tools="http://schemas.android.com/tools" | 3 | xmlns:tools="http://schemas.android.com/tools" |
| 4 | package="com.hjx.parent"> | 4 | package="com.hjx.parent"> |
| 5 | 5 | ||
| 6 | 6 | ||
| 7 | <uses-permission android:name="android.permission.CHANGE_WIFI_MULTICAST_STATE" /> | 7 | <uses-permission android:name="android.permission.CHANGE_WIFI_MULTICAST_STATE" /> |
| 8 | <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> <!-- 允许程序改变网络链接状态 --> | 8 | <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /> <!-- 允许程序改变网络链接状态 --> |
| 9 | <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <!-- 允许程序访问访问WIFI网络状态信息 --> | 9 | <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /> <!-- 允许程序访问访问WIFI网络状态信息 --> |
| 10 | <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> <!-- 允许程序改变WIFI链接状态 --> | 10 | <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /> <!-- 允许程序改变WIFI链接状态 --> |
| 11 | <!-- 6.0系统需要添加权限才能获得wifi列表 --> | 11 | <!-- 6.0系统需要添加权限才能获得wifi列表 --> |
| 12 | <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> | 12 | <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> |
| 13 | <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> | 13 | <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> |
| 14 | <uses-permission android:name="android.permission.INTERNET" /> | 14 | <uses-permission android:name="android.permission.INTERNET" /> |
| 15 | <uses-permission android:name="android.permission.RECORD_AUDIO" /> | 15 | <uses-permission android:name="android.permission.RECORD_AUDIO" /> |
| 16 | <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> | 16 | <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> |
| 17 | 17 | ||
| 18 | <uses-permission android:name="android.permission.DISABLE_KEYGUARD" /> | 18 | <uses-permission android:name="android.permission.DISABLE_KEYGUARD" /> |
| 19 | <uses-permission android:name="android.permission.READ_PHONE_STATE" /> | 19 | <uses-permission android:name="android.permission.READ_PHONE_STATE" /> |
| 20 | <uses-permission android:name="android.permission.WAKE_LOCK" /> | 20 | <uses-permission android:name="android.permission.WAKE_LOCK" /> |
| 21 | <uses-permission android:name="android.permission.CAMERA" /> | 21 | <uses-permission android:name="android.permission.CAMERA" /> |
| 22 | <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> | 22 | <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> |
| 23 | <uses-permission android:name="android.permission.VIBRATE" /> | 23 | <uses-permission android:name="android.permission.VIBRATE" /> |
| 24 | 24 | ||
| 25 | <application | 25 | <application |
| 26 | android:name=".MyApplication" | 26 | android:name=".MyApplication" |
| 27 | android:allowBackup="true" | 27 | android:allowBackup="true" |
| 28 | android:icon="@mipmap/icon" | 28 | android:icon="@mipmap/icon" |
| 29 | android:label="@string/app_name" | 29 | android:label="@string/app_name" |
| 30 | android:networkSecurityConfig="@xml/network_security_config" | 30 | android:networkSecurityConfig="@xml/network_security_config" |
| 31 | android:supportsRtl="true" | 31 | android:supportsRtl="true" |
| 32 | android:theme="@style/Theme.Parent"> | 32 | android:theme="@style/Theme.Parent"> |
| 33 | <activity | 33 | <activity |
| 34 | android:name=".LoginActivity" | 34 | android:name=".LoginActivity" |
| 35 | android:exported="true" | 35 | android:exported="true" |
| 36 | android:theme="@style/ThemeSplash"> | 36 | android:theme="@style/ThemeSplash"> |
| 37 | <intent-filter> | 37 | <intent-filter> |
| 38 | <action android:name="android.intent.action.MAIN" /> | 38 | <action android:name="android.intent.action.MAIN" /> |
| 39 | <category android:name="android.intent.category.LAUNCHER" /> | 39 | <category android:name="android.intent.category.LAUNCHER" /> |
| 40 | </intent-filter> | 40 | </intent-filter> |
| 41 | </activity> | 41 | </activity> |
| 42 | <activity | 42 | <activity |
| 43 | android:name=".MainActivity" | 43 | android:name=".MainActivity" |
| 44 | android:launchMode="singleTask" | 44 | android:launchMode="singleTask" |
| 45 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 45 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 46 | <activity | 46 | <activity |
| 47 | android:name=".RegisterActivity" | 47 | android:name=".RegisterActivity" |
| 48 | android:theme="@style/ThemeSplash" /> | 48 | android:theme="@style/ThemeSplash" /> |
| 49 | <activity | 49 | <activity |
| 50 | android:name=".UserActivity" | 50 | android:name=".UserActivity" |
| 51 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 51 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 52 | <activity | 52 | <activity |
| 53 | android:name=".YinsiActivity" | 53 | android:name=".YinsiActivity" |
| 54 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 54 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 55 | <activity | 55 | <activity |
| 56 | android:name=".QRActivity" | 56 | android:name=".QRActivity" |
| 57 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 57 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 58 | <activity | 58 | <activity |
| 59 | android:name=".AddStudentActivity" | 59 | android:name=".AddStudentActivity" |
| 60 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 60 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 61 | <activity | 61 | <activity |
| 62 | android:name=".NickActivity" | 62 | android:name=".NickActivity" |
| 63 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 63 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 64 | <activity | 64 | <activity |
| 65 | android:name=".SexActivity" | 65 | android:name=".SexActivity" |
| 66 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 66 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 67 | <activity | 67 | <activity |
| 68 | android:name=".NianActivity" | 68 | android:name=".NianActivity" |
| 69 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 69 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 70 | <activity | 70 | <activity |
| 71 | android:name=".ShenActivity" | 71 | android:name=".ShenActivity" |
| 72 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 72 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 73 | <activity | 73 | <activity |
| 74 | android:name=".AccountActivity" | 74 | android:name=".AccountActivity" |
| 75 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 75 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 76 | 76 | ||
| 77 | <activity | 77 | <activity |
| 78 | android:name=".ChangePwdActivity" | 78 | android:name=".ChangePwdActivity" |
| 79 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 79 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 80 | <activity | 80 | <activity |
| 81 | android:name=".EditStudentActivity" | 81 | android:name=".EditStudentActivity" |
| 82 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 82 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 83 | <activity | 83 | <activity |
| 84 | android:name=".ChooseActivity" | 84 | android:name=".ChooseActivity" |
| 85 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | 85 | android:theme="@style/Theme.AppCompat.NoActionBar" /> |
| 86 | <activity | ||
| 87 | android:name=".AddTeacherActivity" | ||
| 88 | android:theme="@style/Theme.AppCompat.NoActionBar" /> | ||
| 86 | 89 | ||
| 87 | <provider | 90 | <provider |
| 88 | android:name="androidx.core.content.FileProvider" | 91 | android:name="androidx.core.content.FileProvider" |
| 89 | android:authorities="com.hjx.parent.fileprovider" | 92 | android:authorities="com.hjx.parent.fileprovider" |
| 90 | android:exported="false" | 93 | android:exported="false" |
| 91 | android:grantUriPermissions="true"> | 94 | android:grantUriPermissions="true"> |
| 92 | <meta-data | 95 | <meta-data |
| 93 | android:name="android.support.FILE_PROVIDER_PATHS" | 96 | android:name="android.support.FILE_PROVIDER_PATHS" |
| 94 | android:resource="@xml/file_provider_paths" | 97 | android:resource="@xml/file_provider_paths" |
| 95 | tools:replace="android:resource" /> | 98 | tools:replace="android:resource" /> |
| 96 | </provider> | 99 | </provider> |
| 97 | </application> | 100 | </application> |
| 98 | 101 | ||
| 99 | </manifest> | 102 | </manifest> |
app/src/main/java/com/hjx/parent/AddStudentActivity.java
| 1 | package com.hjx.parent; | 1 | package com.hjx.parent; |
| 2 | 2 | ||
| 3 | import android.content.DialogInterface; | ||
| 3 | import android.content.Intent; | 4 | import android.content.Intent; |
| 4 | import android.graphics.Bitmap; | 5 | import android.graphics.Bitmap; |
| 5 | import android.graphics.Color; | 6 | import android.graphics.Color; |
| 6 | import android.net.Uri; | 7 | import android.net.Uri; |
| 7 | import android.os.Build; | 8 | import android.os.Build; |
| 8 | import android.os.Bundle; | 9 | import android.os.Bundle; |
| 9 | import android.os.Environment; | 10 | import android.os.Environment; |
| 10 | import android.provider.MediaStore; | 11 | import android.provider.MediaStore; |
| 12 | import android.text.TextUtils; | ||
| 11 | import android.util.Log; | 13 | import android.util.Log; |
| 12 | import android.view.LayoutInflater; | 14 | import android.view.LayoutInflater; |
| 13 | import android.view.View; | 15 | import android.view.View; |
| 14 | import android.widget.Button; | 16 | import android.widget.Button; |
| 15 | import android.widget.ImageView; | 17 | import android.widget.ImageView; |
| 18 | import android.widget.LinearLayout; | ||
| 19 | import android.widget.RelativeLayout; | ||
| 16 | import android.widget.TextView; | 20 | import android.widget.TextView; |
| 17 | import android.widget.Toast; | 21 | import android.widget.Toast; |
| 18 | 22 | ||
| 19 | import androidx.core.content.FileProvider; | 23 | import androidx.core.content.FileProvider; |
| 20 | 24 | ||
| 21 | import com.bumptech.glide.Glide; | 25 | import com.bumptech.glide.Glide; |
| 22 | import com.bumptech.glide.load.resource.bitmap.RoundedCorners; | 26 | import com.bumptech.glide.load.resource.bitmap.RoundedCorners; |
| 23 | import com.bumptech.glide.request.RequestOptions; | 27 | import com.bumptech.glide.request.RequestOptions; |
| 24 | import com.google.android.material.bottomsheet.BottomSheetDialog; | 28 | import com.google.android.material.bottomsheet.BottomSheetDialog; |
| 29 | import com.google.gson.Gson; | ||
| 25 | import com.hjq.permissions.OnPermissionCallback; | 30 | import com.hjq.permissions.OnPermissionCallback; |
| 26 | import com.hjq.permissions.Permission; | 31 | import com.hjq.permissions.Permission; |
| 27 | import com.hjq.permissions.XXPermissions; | 32 | import com.hjq.permissions.XXPermissions; |
| 28 | import com.prws.common.base.BaseActivity; | 33 | import com.prws.common.base.BaseActivity; |
| 29 | import com.prws.common.base.BasePresenter; | 34 | import com.prws.common.base.BasePresenter; |
| 30 | import com.prws.common.bean.ResponseResult; | 35 | import com.prws.common.bean.ResponseResult; |
| 36 | import com.prws.common.bean.Teacher; | ||
| 31 | import com.prws.common.net.NetWorks; | 37 | import com.prws.common.net.NetWorks; |
| 32 | import com.prws.common.utils.LogUtil; | 38 | import com.prws.common.utils.LogUtil; |
| 33 | import com.prws.common.utils.ScreenUtils; | 39 | import com.prws.common.utils.ScreenUtils; |
| 34 | import com.prws.common.utils.SharedPreferencesUtil; | 40 | import com.prws.common.utils.SharedPreferencesUtil; |
| 35 | 41 | ||
| 36 | import org.json.JSONObject; | 42 | import org.json.JSONObject; |
| 37 | 43 | ||
| 38 | import java.io.File; | 44 | import java.io.File; |
| 39 | import java.io.FileOutputStream; | 45 | import java.io.FileOutputStream; |
| 40 | import java.io.IOException; | 46 | import java.io.IOException; |
| 41 | import java.util.HashMap; | 47 | import java.util.HashMap; |
| 42 | import java.util.List; | 48 | import java.util.List; |
| 43 | import java.util.Map; | 49 | import java.util.Map; |
| 44 | 50 | ||
| 45 | import butterknife.BindView; | 51 | import butterknife.BindView; |
| 46 | import butterknife.OnClick; | 52 | import butterknife.OnClick; |
| 47 | import io.reactivex.Observer; | 53 | import io.reactivex.Observer; |
| 48 | import io.reactivex.disposables.Disposable; | 54 | import io.reactivex.disposables.Disposable; |
| 49 | import okhttp3.ResponseBody; | 55 | import okhttp3.ResponseBody; |
| 50 | 56 | ||
| 51 | public class AddStudentActivity extends BaseActivity { | 57 | public class AddStudentActivity extends BaseActivity { |
| 52 | @Override | 58 | @Override |
| 53 | protected int layoutResId() { | 59 | protected int layoutResId() { |
| 54 | return R.layout.activity_add_stu; | 60 | return R.layout.activity_add_stu; |
| 55 | } | 61 | } |
| 56 | 62 | ||
| 57 | @Override | 63 | @Override |
| 58 | public Object getContract() { | 64 | public Object getContract() { |
| 59 | return null; | 65 | return null; |
| 60 | } | 66 | } |
| 61 | 67 | ||
| 62 | @Override | 68 | @Override |
| 63 | public BasePresenter getPresenter() { | 69 | public BasePresenter getPresenter() { |
| 64 | return null; | 70 | return null; |
| 65 | } | 71 | } |
| 66 | 72 | ||
| 67 | View view_2; | 73 | View view_2; |
| 68 | View view_3; | 74 | View view_3; |
| 69 | View view_4; | 75 | View view_4; |
| 70 | View view_5; | 76 | View view_5; |
| 77 | @BindView(R.id.tv_teacher) | ||
| 78 | TextView tv_teacher; | ||
| 79 | @BindView(R.id.rl_teacher) | ||
| 80 | RelativeLayout rl_teacher; | ||
| 81 | @BindView(R.id.iv_teacher) | ||
| 82 | ImageView iv_teacher; | ||
| 83 | @BindView(R.id.tv_bind) | ||
| 84 | TextView tv_bind; | ||
| 71 | Button btn_next; | 85 | Button btn_next; |
| 72 | TextView tv_name, tv_sex, tv_nian, tv_shen; | 86 | TextView tv_name, tv_sex, tv_nian, tv_shen; |
| 73 | @BindView(R.id.iv_avatar) | 87 | @BindView(R.id.iv_avatar) |
| 74 | ImageView iv_avatar; | 88 | ImageView iv_avatar; |
| 75 | 89 | ||
| 76 | @Override | 90 | @Override |
| 77 | protected void initView() { | 91 | protected void initView() { |
| 78 | view_2 = findViewById(R.id.view_2); | 92 | view_2 = findViewById(R.id.view_2); |
| 79 | view_3 = findViewById(R.id.view_3); | 93 | view_3 = findViewById(R.id.view_3); |
| 80 | view_4 = findViewById(R.id.view_4); | 94 | view_4 = findViewById(R.id.view_4); |
| 81 | view_5 = findViewById(R.id.view_5); | 95 | view_5 = findViewById(R.id.view_5); |
| 82 | tv_name = findViewById(R.id.tv_name); | 96 | tv_name = findViewById(R.id.tv_name); |
| 83 | tv_sex = findViewById(R.id.tv_sex); | 97 | tv_sex = findViewById(R.id.tv_sex); |
| 84 | tv_nian = findViewById(R.id.tv_nian); | 98 | tv_nian = findViewById(R.id.tv_nian); |
| 85 | tv_shen = findViewById(R.id.tv_shen); | 99 | tv_shen = findViewById(R.id.tv_shen); |
| 86 | btn_next = findViewById(R.id.btn_next); | 100 | btn_next = findViewById(R.id.btn_next); |
| 87 | } | 101 | } |
| 88 | 102 | ||
| 89 | boolean isName = false; | 103 | boolean isName = false; |
| 90 | boolean isSex = false; | 104 | boolean isSex = false; |
| 91 | boolean isNian = false; | 105 | boolean isNian = false; |
| 92 | boolean isShen = false; | 106 | boolean isShen = false; |
| 93 | private static int CAMERA_REQUEST_CODE = 343; | 107 | private static int CAMERA_REQUEST_CODE = 343; |
| 94 | private static int ALBUM_REQUEST_CODE = 456; | 108 | private static int ALBUM_REQUEST_CODE = 456; |
| 95 | private static int CROP_REQUEST_CODE = 234; | 109 | private static int CROP_REQUEST_CODE = 234; |
| 110 | private static int BIND_TEACHER_CODE = 345; | ||
| 96 | private File tempFile; | 111 | private File tempFile; |
| 97 | private String path; | 112 | private String path; |
| 113 | private Teacher teacher; | ||
| 98 | 114 | ||
| 99 | @Override | 115 | @Override |
| 100 | protected void onStart() { | 116 | protected void onStart() { |
| 101 | super.onStart(); | 117 | super.onStart(); |
| 102 | String name = (String) SharedPreferencesUtil.getData("setName", ""); | 118 | String name = (String) SharedPreferencesUtil.getData("setName", ""); |
| 103 | String sex = (String) SharedPreferencesUtil.getData("setSex", ""); | 119 | String sex = (String) SharedPreferencesUtil.getData("setSex", ""); |
| 104 | String nian = (String) SharedPreferencesUtil.getData("setNian", "") + SharedPreferencesUtil.getData("setXueq", ""); | 120 | String nian = (String) SharedPreferencesUtil.getData("setNian", "") + SharedPreferencesUtil.getData("setXueq", ""); |
| 105 | String shen = (String) SharedPreferencesUtil.getData("setShen", ""); | 121 | String shen = (String) SharedPreferencesUtil.getData("setShen", ""); |
| 106 | 122 | ||
| 107 | if (name != null && name.length() > 0) { | 123 | if (name != null && name.length() > 0) { |
| 108 | tv_name.setText(name); | 124 | tv_name.setText(name); |
| 109 | isName = true; | 125 | isName = true; |
| 110 | } else { | 126 | } else { |
| 111 | isName = false; | 127 | isName = false; |
| 112 | } | 128 | } |
| 113 | if (sex != null && sex.length() > 0) { | 129 | if (sex != null && sex.length() > 0) { |
| 114 | tv_sex.setText(sex); | 130 | tv_sex.setText(sex); |
| 115 | isSex = true; | 131 | isSex = true; |
| 116 | } else { | 132 | } else { |
| 117 | isSex = false; | 133 | isSex = false; |
| 118 | } | 134 | } |
| 119 | if (nian != null && nian.length() > 0) { | 135 | if (nian != null && nian.length() > 0) { |
| 120 | tv_nian.setText(nian); | 136 | tv_nian.setText(nian); |
| 121 | isNian = true; | 137 | isNian = true; |
| 122 | } else { | 138 | } else { |
| 123 | isNian = false; | 139 | isNian = false; |
| 124 | } | 140 | } |
| 125 | if (shen != null && shen.length() > 0) { | 141 | if (shen != null && shen.length() > 0) { |
| 126 | tv_shen.setText(shen); | 142 | tv_shen.setText(shen); |
| 127 | isShen = true; | 143 | isShen = true; |
| 128 | } else { | 144 | } else { |
| 129 | isShen = false; | 145 | isShen = false; |
| 130 | } | 146 | } |
| 131 | 147 | ||
| 132 | if (isName && isSex && isNian && isShen) { | 148 | if (isName && isSex && isNian && isShen) { |
| 133 | btn_next.setTextColor(Color.WHITE); | 149 | btn_next.setTextColor(Color.WHITE); |
| 134 | btn_next.setBackground(getResources().getDrawable(R.drawable.bg_solid_btn)); | 150 | btn_next.setBackground(getResources().getDrawable(R.drawable.bg_solid_btn)); |
| 135 | } | 151 | } |
| 136 | 152 | ||
| 137 | } | 153 | } |
| 138 | 154 | ||
| 139 | @Override | 155 | @Override |
| 140 | protected void initListener() { | 156 | protected void initListener() { |
| 141 | view_2.setOnClickListener(view -> startActivity(NickActivity.class)); | 157 | view_2.setOnClickListener(view -> startActivity(NickActivity.class)); |
| 142 | view_3.setOnClickListener(view -> startActivity(SexActivity.class)); | 158 | view_3.setOnClickListener(view -> startActivity(SexActivity.class)); |
| 143 | view_4.setOnClickListener(view -> startActivity(NianActivity.class)); | 159 | view_4.setOnClickListener(view -> startActivity(NianActivity.class)); |
| 144 | view_5.setOnClickListener(view -> startActivity(ShenActivity.class)); | 160 | view_5.setOnClickListener(view -> startActivity(ShenActivity.class)); |
| 145 | findViewById(R.id.tv_cancel).setOnClickListener(view -> onBackPressed()); | 161 | findViewById(R.id.tv_cancel).setOnClickListener(view -> onBackPressed()); |
| 146 | btn_next.setOnClickListener(view -> { | 162 | btn_next.setOnClickListener(view -> { |
| 147 | if (isName && isSex && isNian && isShen) { | 163 | if (isName && isSex && isNian && isShen) { |
| 148 | addStudent(); | 164 | if (teacher != null) { |
| 165 | addStudent(); | ||
| 166 | } else { | ||
| 167 | showDialog("温馨提示", "您还未绑定老师,是否绑定?", "去绑定", "暂不绑定", new DialogInterface.OnClickListener() { | ||
| 168 | @Override | ||
| 169 | public void onClick(DialogInterface dialogInterface, int i) { | ||
| 170 | dialogInterface.dismiss(); | ||
| 171 | showDialog("温馨提示", "您暂未绑定老师,如需绑定老师\n" + "请联系400-800-3813", "确定", "", null, new DialogInterface.OnClickListener() { | ||
| 172 | @Override | ||
| 173 | public void onClick(DialogInterface dialogInterface, int i) { | ||
| 174 | addStudent(); | ||
| 175 | } | ||
| 176 | }); | ||
| 177 | } | ||
| 178 | }, new DialogInterface.OnClickListener() { | ||
| 179 | @Override | ||
| 180 | public void onClick(DialogInterface dialogInterface, int i) { | ||
| 181 | Intent intent = new Intent(AddStudentActivity.this, AddTeacherActivity.class); | ||
| 182 | startActivityForResult(intent, BIND_TEACHER_CODE); | ||
| 183 | } | ||
| 184 | }); | ||
| 185 | } | ||
| 149 | } else { | 186 | } else { |
| 150 | Toast.makeText(this, "请完成设置后点击", Toast.LENGTH_SHORT).show(); | 187 | Toast.makeText(this, "请完成设置后点击", Toast.LENGTH_SHORT).show(); |
| 151 | } | 188 | } |
| 152 | }); | 189 | }); |
| 153 | } | 190 | } |
| 154 | 191 | ||
| 155 | @Override | 192 | @Override |
| 156 | protected void onDestroy() { | 193 | protected void onDestroy() { |
| 157 | super.onDestroy(); | 194 | super.onDestroy(); |
| 158 | SharedPreferencesUtil.putData("setName", ""); | 195 | SharedPreferencesUtil.putData("setName", ""); |
| 159 | SharedPreferencesUtil.putData("setSex", ""); | 196 | SharedPreferencesUtil.putData("setSex", ""); |
| 160 | SharedPreferencesUtil.putData("setNian", ""); | 197 | SharedPreferencesUtil.putData("setNian", ""); |
| 161 | SharedPreferencesUtil.putData("setShen", ""); | 198 | SharedPreferencesUtil.putData("setShen", ""); |
| 162 | SharedPreferencesUtil.putData("setXueq", ""); | 199 | SharedPreferencesUtil.putData("setXueq", ""); |
| 163 | SharedPreferencesUtil.putData("grade", 0); | 200 | SharedPreferencesUtil.putData("grade", 0); |
| 164 | } | 201 | } |
| 165 | 202 | ||
| 166 | 203 | ||
| 167 | public void addStudent() { | 204 | public void addStudent() { |
| 168 | String name = (String) SharedPreferencesUtil.getData("setName", ""); | 205 | String name = (String) SharedPreferencesUtil.getData("setName", ""); |
| 169 | String sex = (String) SharedPreferencesUtil.getData("setSex", ""); | 206 | String sex = (String) SharedPreferencesUtil.getData("setSex", ""); |
| 170 | String nian = (String) SharedPreferencesUtil.getData("setNian", ""); | 207 | String nian = (String) SharedPreferencesUtil.getData("setNian", ""); |
| 171 | String shen = (String) SharedPreferencesUtil.getData("setShen", ""); | 208 | String shen = (String) SharedPreferencesUtil.getData("setShen", ""); |
| 172 | String xueq = (String) SharedPreferencesUtil.getData("setXueq", ""); | 209 | String xueq = (String) SharedPreferencesUtil.getData("setXueq", ""); |
| 173 | |||
| 174 | |||
| 175 | Map map = new HashMap(); | 210 | Map map = new HashMap(); |
| 176 | map.put("nickName", name); | 211 | map.put("nickName", name); |
| 177 | map.put("gender", "男".equals(sex) ? 0 : 1); | 212 | map.put("gender", "男".equals(sex) ? 0 : 1); |
| 178 | map.put("gradeId", SharedPreferencesUtil.getData("grade", 1)); | 213 | map.put("gradeId", SharedPreferencesUtil.getData("grade", 1)); |
| 179 | map.put("parentIdentity", shen); | 214 | map.put("parentIdentity", shen); |
| 180 | map.put("term", xueq); | 215 | map.put("term", xueq); |
| 216 | if (teacher != null) | ||
| 217 | map.put("userId", teacher.getId()); | ||
| 181 | if (path != null) { | 218 | if (path != null) { |
| 182 | map.put("photo", path); | 219 | map.put("photo", path); |
| 183 | } | 220 | } |
| 184 | |||
| 185 | NetWorks.registerStudent(NetWorks.getMapRequestBody(map), new Observer<ResponseBody>() { | 221 | NetWorks.registerStudent(NetWorks.getMapRequestBody(map), new Observer<ResponseBody>() { |
| 186 | @Override | 222 | @Override |
| 187 | public void onSubscribe(Disposable d) { | 223 | public void onSubscribe(Disposable d) { |
| 188 | 224 | ||
| 189 | } | 225 | } |
| 190 | 226 | ||
| 191 | @Override | 227 | @Override |
| 192 | public void onNext(ResponseBody responseBody) { | 228 | public void onNext(ResponseBody responseBody) { |
| 193 | try { | 229 | try { |
| 194 | |||
| 195 | String str = responseBody.string().toString(); | 230 | String str = responseBody.string().toString(); |
| 196 | LogUtil.e(TAG, "----" + str); | 231 | LogUtil.e(TAG, "----" + str); |
| 197 | JSONObject jo = new JSONObject(str); | 232 | JSONObject jo = new JSONObject(str); |
| 198 | boolean isSucceed = jo.getBoolean("success"); | 233 | boolean isSucceed = jo.getBoolean("success"); |
| 199 | if (isSucceed) { | 234 | if (isSucceed) { |
| 200 | finish(); | 235 | finish(); |
| 201 | } else { | 236 | } else { |
| 202 | Toast.makeText(AddStudentActivity.this, jo.getString("msg"), Toast.LENGTH_SHORT).show(); | 237 | Toast.makeText(AddStudentActivity.this, jo.getString("msg"), Toast.LENGTH_SHORT).show(); |
| 203 | } | 238 | } |
| 204 | } catch (Exception e) { | 239 | } catch (Exception e) { |
| 205 | e.printStackTrace(); | 240 | e.printStackTrace(); |
| 206 | Toast.makeText(AddStudentActivity.this, "服务繁忙,请重试", Toast.LENGTH_SHORT).show(); | 241 | Toast.makeText(AddStudentActivity.this, "服务繁忙,请重试", Toast.LENGTH_SHORT).show(); |
| 207 | } | 242 | } |
| 208 | |||
| 209 | } | 243 | } |
| 210 | 244 | ||
| 211 | @Override | 245 | @Override |
| 212 | public void onError(Throwable e) { | 246 | public void onError(Throwable e) { |
| 213 | 247 | ||
| 214 | } | 248 | } |
| 215 | 249 | ||
| 216 | @Override | 250 | @Override |
| 217 | public void onComplete() { | 251 | public void onComplete() { |
| 218 | 252 | ||
| 219 | } | 253 | } |
| 220 | 254 | ||
| 221 | }); | 255 | }); |
| 222 | } | 256 | } |
| 223 | 257 | ||
| 258 | |||
| 224 | @Override | 259 | @Override |
| 225 | protected void initData() { | 260 | protected void initData() { |
| 226 | 261 | ||
| 227 | } | 262 | } |
| 228 | 263 | ||
| 229 | @Override | 264 | @Override |
| 230 | public void onNetChanged(int netWorkState) { | 265 | public void onNetChanged(int netWorkState) { |
| 231 | 266 | ||
| 232 | } | 267 | } |
| 233 | 268 | ||
| 234 | @OnClick(R.id.iv_avatar) | 269 | @OnClick(R.id.iv_avatar) |
| 235 | public void showButtonDialog(View view) { | 270 | public void showButtonDialog(View view) { |
| 236 | BottomSheetDialog dialog = new BottomSheetDialog(this, R.style.BottomSheetDialog); | 271 | BottomSheetDialog dialog = new BottomSheetDialog(this, R.style.BottomSheetDialog); |
| 237 | View bottomView = LayoutInflater.from(this).inflate(R.layout.bottom_sheet_layout, null); | 272 | View bottomView = LayoutInflater.from(this).inflate(R.layout.bottom_sheet_layout, null); |
| 238 | dialog.setContentView(bottomView); | 273 | dialog.setContentView(bottomView); |
| 239 | bottomView.findViewById(R.id.take_photo).setOnClickListener(new View.OnClickListener() { | 274 | bottomView.findViewById(R.id.take_photo).setOnClickListener(new View.OnClickListener() { |
| 240 | @Override | 275 | @Override |
| 241 | public void onClick(View view) { | 276 | public void onClick(View view) { |
| 242 | dialog.dismiss(); | 277 | dialog.dismiss(); |
| 243 | if (!XXPermissions.isGranted(AddStudentActivity.this, Permission.CAMERA)) { | 278 | if (!XXPermissions.isGranted(AddStudentActivity.this, Permission.CAMERA)) { |
| 244 | XXPermissions.with(AddStudentActivity.this) | 279 | XXPermissions.with(AddStudentActivity.this) |
| 245 | // 申请多个权限 | 280 | // 申请多个权限 |
| 246 | .permission(Permission.CAMERA) | 281 | .permission(Permission.CAMERA) |
| 247 | .request(new OnPermissionCallback() { | 282 | .request(new OnPermissionCallback() { |
| 248 | @Override | 283 | @Override |
| 249 | public void onGranted(List<String> permissions, boolean all) { | 284 | public void onGranted(List<String> permissions, boolean all) { |
| 250 | if (all) { | 285 | if (all) { |
| 251 | //开启扫码界面 | 286 | //开启扫码界面 |
| 252 | getPicFromCamera(); | 287 | getPicFromCamera(); |
| 253 | } else { | 288 | } else { |
| 254 | Toast.makeText(AddStudentActivity.this, "需要相机权限", Toast.LENGTH_SHORT).show(); | 289 | Toast.makeText(AddStudentActivity.this, "需要相机权限", Toast.LENGTH_SHORT).show(); |
| 255 | } | 290 | } |
| 256 | } | 291 | } |
| 257 | 292 | ||
| 258 | @Override | 293 | @Override |
| 259 | public void onDenied(List<String> permissions, boolean never) { | 294 | public void onDenied(List<String> permissions, boolean never) { |
| 260 | XXPermissions.startPermissionActivity(AddStudentActivity.this, permissions); | 295 | XXPermissions.startPermissionActivity(AddStudentActivity.this, permissions); |
| 261 | } | 296 | } |
| 262 | }); | 297 | }); |
| 263 | } else { | 298 | } else { |
| 264 | getPicFromCamera(); | 299 | getPicFromCamera(); |
| 265 | } | 300 | } |
| 266 | } | 301 | } |
| 267 | }); | 302 | }); |
| 268 | bottomView.findViewById(R.id.choose_photo).setOnClickListener(new View.OnClickListener() { | 303 | bottomView.findViewById(R.id.choose_photo).setOnClickListener(new View.OnClickListener() { |
| 269 | @Override | 304 | @Override |
| 270 | public void onClick(View view) { | 305 | public void onClick(View view) { |
| 271 | dialog.dismiss(); | 306 | dialog.dismiss(); |
| 272 | getPicFromAlbm(); | 307 | getPicFromAlbm(); |
| 273 | } | 308 | } |
| 274 | }); | 309 | }); |
| 275 | bottomView.findViewById(R.id.cancel).setOnClickListener(new View.OnClickListener() { | 310 | bottomView.findViewById(R.id.cancel).setOnClickListener(new View.OnClickListener() { |
| 276 | @Override | 311 | @Override |
| 277 | public void onClick(View view) { | 312 | public void onClick(View view) { |
| 278 | dialog.dismiss(); | 313 | dialog.dismiss(); |
| 279 | } | 314 | } |
| 280 | }); | 315 | }); |
| 281 | dialog.show(); | 316 | dialog.show(); |
| 282 | } | 317 | } |
| 283 | 318 | ||
| 284 | private void cropPhoto(Uri uri) { | 319 | private void cropPhoto(Uri uri) { |
| 285 | Uri contentUri = Uri.fromFile(new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), System.currentTimeMillis() + ".jpg")); | 320 | Uri contentUri = Uri.fromFile(new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), System.currentTimeMillis() + ".jpg")); |
| 286 | Intent intent = new Intent("com.android.camera.action.CROP"); | 321 | Intent intent = new Intent("com.android.camera.action.CROP"); |
| 287 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { | 322 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { |
| 288 | //Android 7.0需要临时添加读取Url的权限, 添加此属性是为了解决:调用裁剪框时候提示:图片无法加载或者加载图片失败或者无法加载此图片 | 323 | //Android 7.0需要临时添加读取Url的权限, 添加此属性是为了解决:调用裁剪框时候提示:图片无法加载或者加载图片失败或者无法加载此图片 |
| 289 | intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION); | 324 | intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION); |
| 290 | } | 325 | } |
| 291 | intent.setDataAndType(uri, "image/*"); | 326 | intent.setDataAndType(uri, "image/*"); |
| 292 | intent.putExtra("crop", "true");//发送裁剪信号,去掉也能进行裁剪 | 327 | intent.putExtra("crop", "true");//发送裁剪信号,去掉也能进行裁剪 |
| 293 | intent.putExtra("scale", true);// 设置缩放 | 328 | intent.putExtra("scale", true);// 设置缩放 |
| 294 | intent.putExtra("scaleUpIfNeeded", true);// 去黑边 | 329 | intent.putExtra("scaleUpIfNeeded", true);// 去黑边 |
| 295 | intent.putExtra("aspectX", 1); | 330 | intent.putExtra("aspectX", 1); |
| 296 | intent.putExtra("aspectY", 1); | 331 | intent.putExtra("aspectY", 1); |
| 297 | //上述两个属性控制裁剪框的缩放比例。 | 332 | //上述两个属性控制裁剪框的缩放比例。 |
| 298 | //当用户用手拉伸裁剪框时候,裁剪框会按照上述比例缩放。 | 333 | //当用户用手拉伸裁剪框时候,裁剪框会按照上述比例缩放。 |
| 299 | intent.putExtra("outputX", 300);//属性控制裁剪完毕,保存的图片的大小格式。 | 334 | intent.putExtra("outputX", 300);//属性控制裁剪完毕,保存的图片的大小格式。 |
| 300 | intent.putExtra("outputY", 300);//你按照1:1的比例来裁剪的,如果最后成像是800*400,那么按照2:1的样式保存, | 335 | intent.putExtra("outputY", 300);//你按照1:1的比例来裁剪的,如果最后成像是800*400,那么按照2:1的样式保存, |
| 301 | intent.putExtra("outputFormat", Bitmap.CompressFormat.JPEG.toString());//输出裁剪文件的格式 | 336 | intent.putExtra("outputFormat", Bitmap.CompressFormat.JPEG.toString());//输出裁剪文件的格式 |
| 302 | intent.putExtra("return-data", true);//是否返回裁剪后图片的Bitmap | 337 | intent.putExtra("return-data", true);//是否返回裁剪后图片的Bitmap |
| 303 | intent.putExtra(MediaStore.EXTRA_OUTPUT, contentUri);//设置输出路径 | 338 | intent.putExtra(MediaStore.EXTRA_OUTPUT, contentUri);//设置输出路径 |
| 304 | startActivityForResult(intent, CROP_REQUEST_CODE); | 339 | startActivityForResult(intent, CROP_REQUEST_CODE); |
| 305 | } | 340 | } |
| 306 | 341 | ||
| 307 | @Override | 342 | @Override |
| 308 | protected void onActivityResult(int requestCode, int resultCode, Intent intent) { | 343 | protected void onActivityResult(int requestCode, int resultCode, Intent intent) { |
| 309 | super.onActivityResult(requestCode, resultCode, intent); | 344 | super.onActivityResult(requestCode, resultCode, intent); |
| 310 | if (requestCode == CAMERA_REQUEST_CODE) { | 345 | if (requestCode == CAMERA_REQUEST_CODE) { |
| 311 | if (resultCode == RESULT_OK) { | 346 | if (resultCode == RESULT_OK) { |
| 312 | //用相机返回的照片去调用剪裁也需要对Uri进行处理 | 347 | //用相机返回的照片去调用剪裁也需要对Uri进行处理 |
| 313 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { | 348 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { |
| 314 | Uri contentUri = FileProvider.getUriForFile(AddStudentActivity.this, | 349 | Uri contentUri = FileProvider.getUriForFile(AddStudentActivity.this, |
| 315 | this.getPackageName() + ".fileprovider", tempFile); | 350 | this.getPackageName() + ".fileprovider", tempFile); |
| 316 | cropPhoto(contentUri); | 351 | cropPhoto(contentUri); |
| 317 | } else { | 352 | } else { |
| 318 | cropPhoto(Uri.fromFile(tempFile)); | 353 | cropPhoto(Uri.fromFile(tempFile)); |
| 319 | } | 354 | } |
| 320 | } | 355 | } |
| 321 | } else if (requestCode == ALBUM_REQUEST_CODE) { | 356 | } else if (requestCode == ALBUM_REQUEST_CODE) { |
| 322 | if (resultCode == RESULT_OK) { | 357 | if (resultCode == RESULT_OK) { |
| 323 | Uri uri = intent.getData(); | 358 | Uri uri = intent.getData(); |
| 324 | cropPhoto(uri); | 359 | cropPhoto(uri); |
| 325 | } | 360 | } |
| 326 | } else if (requestCode == CROP_REQUEST_CODE) { | 361 | } else if (requestCode == CROP_REQUEST_CODE) { |
| 327 | if (intent == null) { | 362 | if (intent == null) { |
| 328 | return; | 363 | return; |
| 329 | } | 364 | } |
| 330 | Bundle bundle = intent.getExtras(); | 365 | Bundle bundle = intent.getExtras(); |
| 331 | if (bundle != null) { | 366 | if (bundle != null) { |
| 332 | //在这里获得了剪裁后的Bitmap对象,可以用于上传 | 367 | //在这里获得了剪裁后的Bitmap对象,可以用于上传 |
| 333 | Bitmap image = bundle.getParcelable("data"); | 368 | Bitmap image = bundle.getParcelable("data"); |
| 334 | //设置到ImageView上 | 369 | //设置到ImageView上 |
| 335 | //也可以进行一些保存、压缩等操作后上传 | 370 | //也可以进行一些保存、压缩等操作后上传 |
| 336 | File file = saveImage("head_output", image); | 371 | File file = saveImage("head_output", image); |
| 337 | uploadAvatar(file); | 372 | uploadAvatar(file); |
| 338 | // Log.d("dsadsadsa",path); | 373 | } |
| 374 | } else if (requestCode == BIND_TEACHER_CODE && resultCode == 1000) { | ||
| 375 | String t = intent.getStringExtra("teacher"); | ||
| 376 | teacher = new Gson().fromJson(t, Teacher.class); | ||
| 377 | rl_teacher.setVisibility(View.VISIBLE); | ||
| 378 | tv_bind.setText("重新绑定"); | ||
| 379 | tv_teacher.setText(teacher.getUserName()); | ||
| 380 | if (!TextUtils.isEmpty(teacher.getPhoto())) { | ||
| 381 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(AddStudentActivity.this, 20)); | ||
| 382 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); | ||
| 383 | Glide.with(AddStudentActivity.this).load(teacher.getPhoto()).apply(options).into(iv_teacher); | ||
| 339 | } | 384 | } |
| 340 | } | 385 | } |
| 341 | } | 386 | } |
| 342 | 387 | ||
| 343 | private void uploadAvatar(File file) { | 388 | private void uploadAvatar(File file) { |
| 344 | NetWorks.uploadAvatar(file, new Observer<ResponseResult<Map<String, String>>>() { | 389 | NetWorks.uploadAvatar(file, new Observer<ResponseResult<Map<String, String>>>() { |
| 345 | @Override | 390 | @Override |
| 346 | public void onSubscribe(Disposable d) { | 391 | public void onSubscribe(Disposable d) { |
| 347 | 392 | ||
| 348 | } | 393 | } |
| 349 | 394 | ||
| 350 | @Override | 395 | @Override |
| 351 | public void onNext(ResponseResult<Map<String, String>> responseBody) { | 396 | public void onNext(ResponseResult<Map<String, String>> responseBody) { |
| 352 | if (responseBody.getData() != null && responseBody.getCode() == 200) { | 397 | if (responseBody.getData() != null && responseBody.getCode() == 200) { |
| 353 | path = responseBody.getData().get("imageUrl"); | 398 | path = responseBody.getData().get("imageUrl"); |
| 354 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(AddStudentActivity.this, 45)); | 399 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(AddStudentActivity.this, 45)); |
| 355 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); | 400 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); |
| 356 | Glide.with(AddStudentActivity.this).load(path).apply(options).into(iv_avatar); | 401 | Glide.with(AddStudentActivity.this).load(path).apply(options).into(iv_avatar); |
| 357 | } | 402 | } |
| 358 | } | 403 | } |
| 359 | 404 | ||
| 360 | @Override | 405 | @Override |
| 361 | public void onError(Throwable e) { | 406 | public void onError(Throwable e) { |
| 362 | e.toString(); | 407 | e.toString(); |
| 363 | } | 408 | } |
| 364 | 409 | ||
| 365 | @Override | 410 | @Override |
| 366 | public void onComplete() { | 411 | public void onComplete() { |
| 367 | 412 | ||
| 368 | } | 413 | } |
| 369 | }); | 414 | }); |
| 370 | } | 415 | } |
| 371 | 416 | ||
| 372 | public File saveImage(String name, Bitmap bmp) { | 417 | public File saveImage(String name, Bitmap bmp) { |
| 373 | File appDir = new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES).getPath()); | 418 | File appDir = new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES).getPath()); |
| 374 | if (!appDir.exists()) { | 419 | if (!appDir.exists()) { |
| 375 | appDir.mkdir(); | 420 | appDir.mkdir(); |
| 376 | } | 421 | } |
| 377 | String fileName = name + ".jpg"; | 422 | String fileName = name + ".jpg"; |
| 378 | File file = new File(appDir, fileName); | 423 | File file = new File(appDir, fileName); |
| 379 | try { | 424 | try { |
| 380 | FileOutputStream fos = new FileOutputStream(file); | 425 | FileOutputStream fos = new FileOutputStream(file); |
| 381 | bmp.compress(Bitmap.CompressFormat.PNG, 100, fos); | 426 | bmp.compress(Bitmap.CompressFormat.PNG, 100, fos); |
| 382 | fos.flush(); | 427 | fos.flush(); |
| 383 | fos.close(); | 428 | fos.close(); |
| 384 | return file; | 429 | return file; |
| 385 | } catch (IOException e) { | 430 | } catch (IOException e) { |
| 386 | Log.d("dsadsadsa", e.getLocalizedMessage()); | ||
| 387 | e.printStackTrace(); | 431 | e.printStackTrace(); |
| 388 | } | 432 | } |
| 389 | return null; | 433 | return null; |
| 390 | } | 434 | } |
| 391 | 435 | ||
| 392 | private void getPicFromCamera() { | 436 | private void getPicFromCamera() { |
| 393 | //用于保存调用相机拍照后所生成的文件 | 437 | //用于保存调用相机拍照后所生成的文件 |
| 394 | tempFile = new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), System.currentTimeMillis() + ".jpg"); | 438 | tempFile = new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), System.currentTimeMillis() + ".jpg"); |
| 395 | //跳转到调用系统相机 | 439 | //跳转到调用系统相机 |
| 396 | Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); | 440 | Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); |
| 397 | //判断版本 | 441 | //判断版本 |
| 398 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { //如果在Android7.0以上,使用FileProvider获取Uri | 442 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { //如果在Android7.0以上,使用FileProvider获取Uri |
| 399 | intent.setFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION); | 443 | intent.setFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION); |
| 400 | Uri contentUri = FileProvider.getUriForFile(AddStudentActivity.this, | 444 | Uri contentUri = FileProvider.getUriForFile(AddStudentActivity.this, |
| 401 | this.getPackageName() + ".fileprovider", tempFile); | 445 | this.getPackageName() + ".fileprovider", tempFile); |
| 402 | intent.putExtra(MediaStore.EXTRA_OUTPUT, contentUri); | 446 | intent.putExtra(MediaStore.EXTRA_OUTPUT, contentUri); |
| 403 | } else { //否则使用Uri.fromFile(file)方法获取Uri | 447 | } else { //否则使用Uri.fromFile(file)方法获取Uri |
| 404 | intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(tempFile)); | 448 | intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(tempFile)); |
| 405 | } | 449 | } |
| 406 | startActivityForResult(intent, CAMERA_REQUEST_CODE); | 450 | startActivityForResult(intent, CAMERA_REQUEST_CODE); |
| 407 | } | 451 | } |
| 408 | 452 | ||
| 409 | /** | 453 | /** |
| 410 | * 从相册获取图片 | 454 | * 从相册获取图片 |
| 411 | */ | 455 | */ |
| 412 | private void getPicFromAlbm() { | 456 | private void getPicFromAlbm() { |
| 413 | Intent photoPickerIntent = new Intent(Intent.ACTION_PICK); | 457 | Intent photoPickerIntent = new Intent(Intent.ACTION_PICK); |
| 414 | photoPickerIntent.setType("image/*"); | 458 | photoPickerIntent.setType("image/*"); |
| 415 | startActivityForResult(photoPickerIntent, ALBUM_REQUEST_CODE); | 459 | startActivityForResult(photoPickerIntent, ALBUM_REQUEST_CODE); |
| 416 | } | 460 | } |
| 417 | 461 | ||
| 462 | |||
| 463 | @OnClick(R.id.view_6) |
app/src/main/java/com/hjx/parent/AddTeacherActivity.java
| File was created | 1 | package com.hjx.parent; | |
| 2 | |||
| 3 | import android.content.Intent; | ||
| 4 | import android.graphics.Color; | ||
| 5 | import android.text.Editable; | ||
| 6 | import android.text.TextUtils; | ||
| 7 | import android.text.TextWatcher; | ||
| 8 | import android.view.View; | ||
| 9 | import android.widget.Button; | ||
| 10 | import android.widget.EditText; | ||
| 11 | import android.widget.ImageView; | ||
| 12 | import android.widget.RelativeLayout; | ||
| 13 | import android.widget.TextView; | ||
| 14 | |||
| 15 | import com.bumptech.glide.Glide; | ||
| 16 | import com.bumptech.glide.load.resource.bitmap.RoundedCorners; | ||
| 17 | import com.bumptech.glide.request.RequestOptions; | ||
| 18 | import com.google.gson.Gson; | ||
| 19 | import com.prws.common.base.BaseActivity; | ||
| 20 | import com.prws.common.base.BasePresenter; | ||
| 21 | import com.prws.common.bean.ResponseResult; | ||
| 22 | import com.prws.common.bean.Teacher; | ||
| 23 | import com.prws.common.net.NetWorks; | ||
| 24 | import com.prws.common.utils.Common; | ||
| 25 | import com.prws.common.utils.ScreenUtils; | ||
| 26 | |||
| 27 | import butterknife.BindView; | ||
| 28 | import butterknife.OnClick; | ||
| 29 | import io.reactivex.Observer; | ||
| 30 | import io.reactivex.disposables.Disposable; | ||
| 31 | |||
| 32 | public class AddTeacherActivity extends BaseActivity { | ||
| 33 | @BindView(R.id.et_1) | ||
| 34 | EditText et_1; | ||
| 35 | @BindView(R.id.btn_next) | ||
| 36 | Button btn_next; | ||
| 37 | @BindView(R.id.rl_teacher) | ||
| 38 | RelativeLayout rl_teacher; | ||
| 39 | @BindView(R.id.iv_teacher) | ||
| 40 | ImageView iv_teacher; | ||
| 41 | @BindView(R.id.tv_teacher) | ||
| 42 | TextView tv_teacher; | ||
| 43 | Teacher teacher; | ||
| 44 | |||
| 45 | @Override | ||
| 46 | protected int layoutResId() { | ||
| 47 | return R.layout.activity_add_teacher; | ||
| 48 | } | ||
| 49 | |||
| 50 | @Override | ||
| 51 | public Object getContract() { | ||
| 52 | return null; | ||
| 53 | } | ||
| 54 | |||
| 55 | @Override | ||
| 56 | public BasePresenter getPresenter() { | ||
| 57 | return null; | ||
| 58 | } | ||
| 59 | |||
| 60 | @Override | ||
| 61 | protected void initView() { | ||
| 62 | et_1.addTextChangedListener(new TextWatcher() { | ||
| 63 | @Override | ||
| 64 | public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) { | ||
| 65 | |||
| 66 | } | ||
| 67 | |||
| 68 | @Override | ||
| 69 | public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) { | ||
| 70 | |||
| 71 | } | ||
| 72 | |||
| 73 | @Override | ||
| 74 | public void afterTextChanged(Editable editable) { | ||
| 75 | if (editable.length() == 11) { | ||
| 76 | if (Common.isValidPhoneNumber(editable.toString())) { | ||
| 77 | searchTeacher(editable.toString()); | ||
| 78 | } else { | ||
| 79 | rl_teacher.setVisibility(View.GONE); | ||
| 80 | showToast("请输入正确的手机号码"); | ||
| 81 | btn_next.setTextColor(Color.parseColor("#999999")); | ||
| 82 | btn_next.setBackgroundResource(R.drawable.bg_solid_btn_grad); | ||
| 83 | btn_next.setEnabled(false); | ||
| 84 | } | ||
| 85 | } else { | ||
| 86 | rl_teacher.setVisibility(View.GONE); | ||
| 87 | btn_next.setBackgroundResource(R.drawable.bg_solid_btn_grad); | ||
| 88 | btn_next.setTextColor(Color.parseColor("#999999")); | ||
| 89 | btn_next.setEnabled(false); | ||
| 90 | } | ||
| 91 | } | ||
| 92 | }); | ||
| 93 | } | ||
| 94 | |||
| 95 | |||
| 96 | public void searchTeacher(String phone) { | ||
| 97 | NetWorks.searchTeacher(phone, new Observer<ResponseResult<Teacher>>() { | ||
| 98 | @Override | ||
| 99 | public void onSubscribe(Disposable d) { | ||
| 100 | |||
| 101 | } | ||
| 102 | |||
| 103 | @Override | ||
| 104 | public void onNext(ResponseResult<Teacher> result) { | ||
| 105 | if (result != null && result.getCode() == 200) { | ||
| 106 | teacher = result.getData(); | ||
| 107 | rl_teacher.setVisibility(View.VISIBLE); | ||
| 108 | if (!TextUtils.isEmpty(teacher.getPhoto())) { | ||
| 109 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(AddTeacherActivity.this, 20)); | ||
| 110 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); | ||
| 111 | Glide.with(AddTeacherActivity.this).load(teacher.getPhoto()).apply(options).into(iv_teacher); | ||
| 112 | } else { | ||
| 113 | iv_teacher.setImageResource(R.mipmap.ic_teacher_male); | ||
| 114 | } | ||
| 115 | tv_teacher.setText(teacher.getUserName()); | ||
| 116 | btn_next.setBackgroundResource(R.drawable.bg_solid_btn); | ||
| 117 | btn_next.setTextColor(Color.WHITE); | ||
| 118 | btn_next.setEnabled(true); | ||
| 119 | } | ||
| 120 | } | ||
| 121 | |||
| 122 | @Override | ||
| 123 | public void onError(Throwable e) { | ||
| 124 | |||
| 125 | } | ||
| 126 | |||
| 127 | @Override | ||
| 128 | public void onComplete() { | ||
| 129 | |||
| 130 | } | ||
| 131 | }); | ||
| 132 | } | ||
| 133 | |||
| 134 | @OnClick(R.id.btn_next) | ||
| 135 | public void confirm(View view) { | ||
| 136 | Intent intent = new Intent(); | ||
| 137 | intent.putExtra("teacher", new Gson().toJson(teacher)); | ||
| 138 | setResult(1000,intent); | ||
| 139 | finish(); | ||
| 140 | } | ||
| 141 | |||
| 142 | @Override | ||
| 143 | protected void initListener() { | ||
| 144 | |||
| 145 | } | ||
| 146 | |||
| 147 | @Override | ||
| 148 | protected void initData() { | ||
| 149 | |||
| 150 | } | ||
| 151 | |||
| 152 | @Override | ||
| 153 | public void onNetChanged(int netWorkState) { | ||
| 154 | |||
| 155 | } | ||
| 156 | |||
| 157 | } | ||
| 158 |
app/src/main/java/com/hjx/parent/ChangePwdActivity.java
| 1 | package com.hjx.parent; | 1 | package com.hjx.parent; |
| 2 | 2 | ||
| 3 | import android.widget.EditText; | 3 | import android.widget.EditText; |
| 4 | import android.widget.TextView; | 4 | import android.widget.TextView; |
| 5 | import android.widget.Toast; | 5 | import android.widget.Toast; |
| 6 | 6 | ||
| 7 | import com.prws.common.base.BaseActivity; | 7 | import com.prws.common.base.BaseActivity; |
| 8 | import com.prws.common.base.BasePresenter; | 8 | import com.prws.common.base.BasePresenter; |
| 9 | import com.prws.common.net.NetWorks; | 9 | import com.prws.common.net.NetWorks; |
| 10 | import com.prws.common.utils.LogUtil; | 10 | import com.prws.common.utils.LogUtil; |
| 11 | import com.prws.common.utils.SharedPreferencesUtil; | 11 | import com.prws.common.utils.SharedPreferencesUtil; |
| 12 | 12 | ||
| 13 | import org.json.JSONObject; | 13 | import org.json.JSONObject; |
| 14 | 14 | ||
| 15 | import java.util.HashMap; | 15 | import java.util.HashMap; |
| 16 | import java.util.Map; | 16 | import java.util.Map; |
| 17 | 17 | ||
| 18 | import butterknife.BindView; | 18 | import butterknife.BindView; |
| 19 | import io.reactivex.Observer; | 19 | import io.reactivex.Observer; |
| 20 | import io.reactivex.disposables.Disposable; | 20 | import io.reactivex.disposables.Disposable; |
| 21 | import okhttp3.ResponseBody; | 21 | import okhttp3.ResponseBody; |
| 22 | 22 | ||
| 23 | public class ChangePwdActivity extends BaseActivity { | 23 | public class ChangePwdActivity extends BaseActivity { |
| 24 | @BindView(R.id.et_old_password) | 24 | @BindView(R.id.et_old_password) |
| 25 | EditText et_old_password; | 25 | EditText et_old_password; |
| 26 | @BindView(R.id.et_pwd_2) | 26 | @BindView(R.id.et_pwd_2) |
| 27 | EditText et_pwd_2; | 27 | EditText et_pwd_2; |
| 28 | 28 | ||
| 29 | @Override | 29 | @Override |
| 30 | protected int layoutResId() { | 30 | protected int layoutResId() { |
| 31 | return R.layout.activity_changem; | 31 | return R.layout.activity_changem; |
| 32 | } | 32 | } |
| 33 | 33 | ||
| 34 | @Override | 34 | @Override |
| 35 | public Object getContract() { | 35 | public Object getContract() { |
| 36 | return null; | 36 | return null; |
| 37 | } | 37 | } |
| 38 | 38 | ||
| 39 | @Override | 39 | @Override |
| 40 | public BasePresenter getPresenter() { | 40 | public BasePresenter getPresenter() { |
| 41 | return null; | 41 | return null; |
| 42 | } | 42 | } |
| 43 | 43 | ||
| 44 | 44 | ||
| 45 | EditText et_pwd; | 45 | EditText et_pwd; |
| 46 | 46 | ||
| 47 | @Override | 47 | @Override |
| 48 | protected void initView() { | 48 | protected void initView() { |
| 49 | et_pwd = findViewById(R.id.et_pwd); | 49 | et_pwd = findViewById(R.id.et_pwd); |
| 50 | } | 50 | } |
| 51 | 51 | ||
| 52 | @Override | 52 | @Override |
| 53 | protected void initListener() { | 53 | protected void initListener() { |
| 54 | findViewById(R.id.iv_back).setOnClickListener(view -> onBackPressed()); | 54 | findViewById(R.id.iv_back).setOnClickListener(view -> onBackPressed()); |
| 55 | findViewById(R.id.btn_next).setOnClickListener(view -> { | 55 | findViewById(R.id.btn_next).setOnClickListener(view -> { |
| 56 | String pwd = et_pwd.getText().toString().trim(); | 56 | String pwd = et_pwd.getText().toString().trim(); |
| 57 | if (pwd == null || pwd.length() == 0) { | 57 | if (pwd == null || pwd.length() == 0) { |
| 58 | Toast.makeText(this, "密码不能为空", Toast.LENGTH_SHORT).show(); | 58 | Toast.makeText(this, "密码不能为空", Toast.LENGTH_SHORT).show(); |
| 59 | return; | 59 | return; |
| 60 | } | 60 | } |
| 61 | if (pwd.length() < 6 || pwd.length() > 16) { | 61 | if (pwd.length() < 6 || pwd.length() > 16) { |
| 62 | Toast.makeText(this, "密码必须为6-16位,数字或字母", Toast.LENGTH_SHORT).show(); | 62 | Toast.makeText(this, "密码必须为6-16位,数字或字母", Toast.LENGTH_SHORT).show(); |
| 63 | return; | 63 | return; |
| 64 | } | 64 | } |
| 65 | if (!pwd.equals(et_pwd_2.getText().toString())) { | 65 | if (!pwd.equals(et_pwd_2.getText().toString())) { |
| 66 | Toast.makeText(this, "两次密码输入不一致", Toast.LENGTH_SHORT).show(); | 66 | Toast.makeText(this, "两次密码输入不一致", Toast.LENGTH_SHORT).show(); |
| 67 | return; | 67 | return; |
| 68 | } | 68 | } |
| 69 | changePwd(pwd); | 69 | changePwd(pwd); |
| 70 | }); | 70 | }); |
| 71 | } | 71 | } |
| 72 | 72 | ||
| 73 | public void changePwd(String pwd) { | 73 | public void changePwd(String pwd) { |
| 74 | String userId = (String) SharedPreferencesUtil.getData("userId", ""); | 74 | String userId = (String) SharedPreferencesUtil.getData("userId", ""); |
| 75 | Map map = new HashMap(); | 75 | Map map = new HashMap(); |
| 76 | map.put("userId", userId); | 76 | map.put("userId", userId); |
| 77 | map.put("password", pwd); | 77 | map.put("password", pwd); |
| 78 | map.put("oldPassword", et_old_password.getText().toString()); | 78 | map.put("oldPassword", et_old_password.getText().toString()); |
| 79 | NetWorks.changePassword(NetWorks.getMapRequestBody(map), new Observer<ResponseBody>() { | 79 | NetWorks.changePassword(NetWorks.getMapRequestBody(map), new Observer<ResponseBody>() { |
| 80 | @Override | 80 | @Override |
| 81 | public void onSubscribe(Disposable d) { | 81 | public void onSubscribe(Disposable d) { |
| 82 | 82 | ||
| 83 | } | 83 | } |
| 84 | 84 | ||
| 85 | @Override | 85 | @Override |
| 86 | public void onNext(ResponseBody responseBody) { | 86 | public void onNext(ResponseBody responseBody) { |
| 87 | try { | 87 | try { |
| 88 | 88 | ||
| 89 | String str = responseBody.string().toString(); | 89 | String str = responseBody.string().toString(); |
| 90 | |||
| 91 | |||
| 92 | LogUtil.e(TAG, "----" + str); | 90 | LogUtil.e(TAG, "----" + str); |
| 93 | JSONObject jo = new JSONObject(str); | 91 | JSONObject jo = new JSONObject(str); |
| 94 | boolean isSucceed = jo.getBoolean("success"); | 92 | boolean isSucceed = jo.getBoolean("success"); |
| 95 | if (isSucceed) { | 93 | if (isSucceed) { |
| 96 | Toast.makeText(ChangePwdActivity.this, "修改成功", Toast.LENGTH_SHORT).show(); | 94 | Toast.makeText(ChangePwdActivity.this, "修改成功", Toast.LENGTH_SHORT).show(); |
| 97 | finish(); | 95 | finish(); |
| 98 | 96 | ||
| 99 | } else { | 97 | } else { |
| 100 | Toast.makeText(ChangePwdActivity.this, jo.getString("msg"), Toast.LENGTH_SHORT).show(); | 98 | Toast.makeText(ChangePwdActivity.this, jo.getString("msg"), Toast.LENGTH_SHORT).show(); |
| 101 | } | 99 | } |
| 102 | } catch (Exception e) { | 100 | } catch (Exception e) { |
| 103 | e.printStackTrace(); | 101 | e.printStackTrace(); |
| 104 | Toast.makeText(ChangePwdActivity.this, "服务繁忙,请重试", Toast.LENGTH_SHORT).show(); | 102 | Toast.makeText(ChangePwdActivity.this, "服务繁忙,请重试", Toast.LENGTH_SHORT).show(); |
| 105 | } | 103 | } |
| 106 | 104 | ||
| 107 | } | 105 | } |
| 108 | 106 | ||
| 109 | @Override | 107 | @Override |
| 110 | public void onError(Throwable e) { | 108 | public void onError(Throwable e) { |
| 111 | 109 | ||
| 112 | } | 110 | } |
| 113 | 111 | ||
| 114 | @Override | 112 | @Override |
| 115 | public void onComplete() { | 113 | public void onComplete() { |
| 116 | 114 | ||
| 117 | } | 115 | } |
| 118 | }); | 116 | }); |
| 119 | 117 | ||
| 120 | } | 118 | } |
| 121 | 119 | ||
| 122 | @Override | 120 | @Override |
| 123 | protected void initData() { | 121 | protected void initData() { |
| 124 | 122 | ||
| 125 | } | 123 | } |
| 126 | 124 | ||
| 127 | @Override | 125 | @Override |
| 128 | public void onNetChanged(int netWorkState) { | 126 | public void onNetChanged(int netWorkState) { |
| 129 | 127 | ||
| 130 | } | 128 | } |
| 131 | } | 129 | } |
app/src/main/java/com/hjx/parent/ChooseActivity.java
| 1 | package com.hjx.parent; | 1 | package com.hjx.parent; |
| 2 | 2 | ||
| 3 | import android.content.Intent; | 3 | import android.content.Intent; |
| 4 | import android.text.TextUtils; | 4 | import android.text.TextUtils; |
| 5 | import android.view.View; | 5 | import android.view.View; |
| 6 | import android.widget.ImageView; | 6 | import android.widget.ImageView; |
| 7 | 7 | ||
| 8 | import androidx.annotation.NonNull; | 8 | import androidx.annotation.NonNull; |
| 9 | import androidx.recyclerview.widget.LinearLayoutManager; | 9 | import androidx.recyclerview.widget.LinearLayoutManager; |
| 10 | import androidx.recyclerview.widget.RecyclerView; | 10 | import androidx.recyclerview.widget.RecyclerView; |
| 11 | 11 | ||
| 12 | import com.bumptech.glide.Glide; | 12 | import com.bumptech.glide.Glide; |
| 13 | import com.bumptech.glide.load.resource.bitmap.RoundedCorners; | 13 | import com.bumptech.glide.load.resource.bitmap.RoundedCorners; |
| 14 | import com.bumptech.glide.request.RequestOptions; | 14 | import com.bumptech.glide.request.RequestOptions; |
| 15 | import com.chad.library.adapter.base.BaseQuickAdapter; | 15 | import com.chad.library.adapter.base.BaseQuickAdapter; |
| 16 | import com.chad.library.adapter.base.BaseViewHolder; | 16 | import com.chad.library.adapter.base.BaseViewHolder; |
| 17 | import com.google.gson.Gson; | 17 | import com.google.gson.Gson; |
| 18 | import com.hjx.parent.bean.StudentBean; | 18 | import com.hjx.parent.bean.StudentBean; |
| 19 | import com.prws.common.base.BaseActivity; | 19 | import com.prws.common.base.BaseActivity; |
| 20 | import com.prws.common.base.BasePresenter; | 20 | import com.prws.common.base.BasePresenter; |
| 21 | import com.prws.common.net.NetWorks; | 21 | import com.prws.common.net.NetWorks; |
| 22 | import com.prws.common.utils.LogUtil; | 22 | import com.prws.common.utils.LogUtil; |
| 23 | import com.prws.common.utils.ScreenUtils; | 23 | import com.prws.common.utils.ScreenUtils; |
| 24 | import com.prws.common.utils.SharedPreferencesUtil; | 24 | import com.prws.common.utils.SharedPreferencesUtil; |
| 25 | 25 | ||
| 26 | import org.json.JSONArray; | 26 | import org.json.JSONArray; |
| 27 | import org.json.JSONObject; | 27 | import org.json.JSONObject; |
| 28 | 28 | ||
| 29 | import java.util.ArrayList; | 29 | import java.util.ArrayList; |
| 30 | 30 | ||
| 31 | import butterknife.BindView; | 31 | import butterknife.BindView; |
| 32 | import butterknife.OnClick; | 32 | import butterknife.OnClick; |
| 33 | import io.reactivex.Observer; | 33 | import io.reactivex.Observer; |
| 34 | import io.reactivex.disposables.Disposable; | 34 | import io.reactivex.disposables.Disposable; |
| 35 | import okhttp3.ResponseBody; | 35 | import okhttp3.ResponseBody; |
| 36 | 36 | ||
| 37 | public class ChooseActivity extends BaseActivity { | 37 | public class ChooseActivity extends BaseActivity { |
| 38 | @BindView(R.id.recycle) | 38 | @BindView(R.id.recycle) |
| 39 | RecyclerView recycle; | 39 | RecyclerView recycle; |
| 40 | private int select = 0; | 40 | private int select = 0; |
| 41 | 41 | ||
| 42 | @Override | 42 | @Override |
| 43 | protected int layoutResId() { | 43 | protected int layoutResId() { |
| 44 | return R.layout.choose_activity; | 44 | return R.layout.choose_activity; |
| 45 | } | 45 | } |
| 46 | 46 | ||
| 47 | @Override | 47 | @Override |
| 48 | public Object getContract() { | 48 | public Object getContract() { |
| 49 | return null; | 49 | return null; |
| 50 | } | 50 | } |
| 51 | 51 | ||
| 52 | @Override | 52 | @Override |
| 53 | public BasePresenter getPresenter() { | 53 | public BasePresenter getPresenter() { |
| 54 | return null; | 54 | return null; |
| 55 | } | 55 | } |
| 56 | 56 | ||
| 57 | @Override | 57 | @Override |
| 58 | protected void initView() { | 58 | protected void initView() { |
| 59 | 59 | ||
| 60 | } | 60 | } |
| 61 | 61 | ||
| 62 | @Override | 62 | @Override |
| 63 | protected void initListener() { | 63 | protected void initListener() { |
| 64 | 64 | ||
| 65 | } | 65 | } |
| 66 | 66 | ||
| 67 | @Override | 67 | @Override |
| 68 | protected void initData() { | 68 | protected void initData() { |
| 69 | 69 | ||
| 70 | } | 70 | } |
| 71 | 71 | ||
| 72 | @Override | 72 | @Override |
| 73 | public void onNetChanged(int netWorkState) { | 73 | public void onNetChanged(int netWorkState) { |
| 74 | 74 | ||
| 75 | } | 75 | } |
| 76 | 76 | ||
| 77 | @Override | 77 | @Override |
| 78 | protected void onResume() { | 78 | protected void onResume() { |
| 79 | super.onResume(); | 79 | super.onResume(); |
| 80 | loadChildList(); | 80 | loadChildList(); |
| 81 | } | 81 | } |
| 82 | 82 | ||
| 83 | ArrayList<StudentBean> alist = new ArrayList<>(); | 83 | ArrayList<StudentBean> alist = new ArrayList<>(); |
| 84 | 84 | ||
| 85 | public void loadChildList() { | 85 | public void loadChildList() { |
| 86 | NetWorks.listChildren(new Observer<ResponseBody>() { | 86 | NetWorks.listChildren(new Observer<ResponseBody>() { |
| 87 | @Override | 87 | @Override |
| 88 | public void onSubscribe(Disposable d) { | 88 | public void onSubscribe(Disposable d) { |
| 89 | 89 | ||
| 90 | } | 90 | } |
| 91 | 91 | ||
| 92 | @Override | 92 | @Override |
| 93 | public void onNext(ResponseBody responseBody) { | 93 | public void onNext(ResponseBody responseBody) { |
| 94 | try { | 94 | try { |
| 95 | |||
| 96 | String str = responseBody.string().toString(); | 95 | String str = responseBody.string().toString(); |
| 97 | |||
| 98 | |||
| 99 | LogUtil.e("TAG", "----" + str); | 96 | LogUtil.e("TAG", "----" + str); |
| 100 | JSONObject jo = new JSONObject(str); | 97 | JSONObject jo = new JSONObject(str); |
| 101 | boolean isSucceed = jo.getBoolean("success"); | 98 | boolean isSucceed = jo.getBoolean("success"); |
| 102 | if (isSucceed) { | 99 | if (isSucceed) { |
| 103 | JSONArray jarr = jo.getJSONArray("data"); | 100 | JSONArray jarr = jo.getJSONArray("data"); |
| 104 | alist.clear(); | 101 | alist.clear(); |
| 105 | for (int i = 0; i < jarr.length(); i++) { | 102 | for (int i = 0; i < jarr.length(); i++) { |
| 106 | JSONObject jo2 = jarr.getJSONObject(i); | 103 | JSONObject jo2 = jarr.getJSONObject(i); |
| 107 | Gson gson = new Gson(); | 104 | Gson gson = new Gson(); |
| 108 | StudentBean sb = gson.fromJson(jo2.toString(), StudentBean.class); | 105 | StudentBean sb = gson.fromJson(jo2.toString(), StudentBean.class); |
| 109 | alist.add(sb); | 106 | alist.add(sb); |
| 110 | } | 107 | } |
| 111 | loadList(); | 108 | loadList(); |
| 112 | } else { | 109 | } else { |
| 113 | 110 | ||
| 114 | } | 111 | } |
| 115 | } catch (Exception e) { | 112 | } catch (Exception e) { |
| 116 | e.printStackTrace(); | 113 | e.printStackTrace(); |
| 117 | } | 114 | } |
| 118 | } | 115 | } |
| 119 | 116 | ||
| 120 | @Override | 117 | @Override |
| 121 | public void onError(Throwable e) { | 118 | public void onError(Throwable e) { |
| 122 | 119 | ||
| 123 | } | 120 | } |
| 124 | 121 | ||
| 125 | @Override | 122 | @Override |
| 126 | public void onComplete() { | 123 | public void onComplete() { |
| 127 | 124 | ||
| 128 | } | 125 | } |
| 129 | }); | 126 | }); |
| 130 | } | 127 | } |
| 131 | 128 | ||
| 132 | public void loadList() { | 129 | public void loadList() { |
| 133 | StudentBean sb = new StudentBean(); | 130 | StudentBean sb = new StudentBean(); |
| 134 | sb.setNickName("添加学生"); | 131 | sb.setNickName("添加学生"); |
| 135 | alist.add(sb); | 132 | alist.add(sb); |
| 136 | String student = (String) SharedPreferencesUtil.getData("student", ""); | 133 | String student = (String) SharedPreferencesUtil.getData("student", ""); |
| 137 | try { | 134 | try { |
| 138 | StudentBean studentBean = new Gson().fromJson(student, StudentBean.class); | 135 | StudentBean studentBean = new Gson().fromJson(student, StudentBean.class); |
| 139 | for (int i = 0; i < alist.size(); i++) { | 136 | for (int i = 0; i < alist.size(); i++) { |
| 140 | if (studentBean.getStuId().equals(alist.get(i).getStuId())) { | 137 | if (studentBean.getStuId().equals(alist.get(i).getStuId())) { |
| 141 | select = i; | 138 | select = i; |
| 142 | break; | 139 | break; |
| 143 | } | 140 | } |
| 144 | } | 141 | } |
| 145 | } catch (Exception e) { | 142 | } catch (Exception e) { |
| 146 | 143 | ||
| 147 | } | 144 | } |
| 148 | BaseQuickAdapter adapter = new BaseQuickAdapter(R.layout.item_child_choose, alist) { | 145 | BaseQuickAdapter adapter = new BaseQuickAdapter(R.layout.item_child_choose, alist) { |
| 149 | @Override | 146 | @Override |
| 150 | protected void convert(@NonNull BaseViewHolder item, Object o) { | 147 | protected void convert(@NonNull BaseViewHolder item, Object o) { |
| 151 | StudentBean studentBean = alist.get(item.getAdapterPosition()); | 148 | StudentBean studentBean = alist.get(item.getAdapterPosition()); |
| 152 | item.setText(R.id.tv_name, studentBean.getNickName()); | 149 | item.setText(R.id.tv_name, studentBean.getNickName()); |
| 153 | if (TextUtils.isEmpty(studentBean.getStuId())) { | 150 | if (TextUtils.isEmpty(studentBean.getStuId())) { |
| 154 | item.setVisible(R.id.rl_add, true); | 151 | item.setVisible(R.id.rl_add, true); |
| 155 | item.getConvertView().setOnClickListener(new View.OnClickListener() { | 152 | item.getConvertView().setOnClickListener(new View.OnClickListener() { |
| 156 | @Override | 153 | @Override |
| 157 | public void onClick(View view) { | 154 | public void onClick(View view) { |
| 158 | startActivity(new Intent(ChooseActivity.this, AddStudentActivity.class)); | 155 | startActivity(new Intent(ChooseActivity.this, AddStudentActivity.class)); |
| 159 | } | 156 | } |
| 160 | }); | 157 | }); |
| 161 | } else { | 158 | } else { |
| 162 | item.setBackgroundRes(R.id.rl_child, select == item.getAdapterPosition() ? R.drawable.bg_solid_white_10_or : R.drawable.bg_solid_white_10); | 159 | item.setBackgroundRes(R.id.rl_child, select == item.getAdapterPosition() ? R.drawable.bg_solid_white_10_or : R.drawable.bg_solid_white_10); |
| 163 | item.setImageResource(R.id.iv_select, select == item.getAdapterPosition() ? R.mipmap.gx : R.mipmap.wsyq); | 160 | item.setImageResource(R.id.iv_select, select == item.getAdapterPosition() ? R.mipmap.gx : R.mipmap.wsyq); |
| 164 | item.setVisible(R.id.rl_add, false); | 161 | item.setVisible(R.id.rl_add, false); |
| 165 | if (TextUtils.isEmpty(studentBean.getPhoto())) { | 162 | if (TextUtils.isEmpty(studentBean.getPhoto())) { |
| 166 | item.setImageResource(R.id.iv_avatar, studentBean.getGender() == 0 ? R.mipmap.ic_avatar_male : R.mipmap.ic_avatar_female); | 163 | item.setImageResource(R.id.iv_avatar, studentBean.getGender() == 0 ? R.mipmap.ic_avatar_male : R.mipmap.ic_avatar_female); |
| 167 | } else { | 164 | } else { |
| 168 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(ChooseActivity.this, 45)); | 165 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(ChooseActivity.this, 45)); |
| 169 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); | 166 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); |
| 170 | Glide.with(ChooseActivity.this).load(studentBean.getPhoto()).apply(options).into((ImageView) item.getView(R.id.iv_avatar)); | 167 | Glide.with(ChooseActivity.this).load(studentBean.getPhoto()).apply(options).into((ImageView) item.getView(R.id.iv_avatar)); |
| 171 | } | 168 | } |
| 172 | item.setVisible(R.id.iv_vip, !"虚拟".equals(studentBean.getTeacherIdentity())); | 169 | item.setVisible(R.id.iv_vip, !"虚拟".equals(studentBean.getTeacherIdentity())); |
| 173 | item.getConvertView().setOnClickListener(new View.OnClickListener() { | 170 | item.getConvertView().setOnClickListener(new View.OnClickListener() { |
| 174 | @Override | 171 | @Override |
| 175 | public void onClick(View view) { | 172 | public void onClick(View view) { |
| 176 | select = item.getAdapterPosition(); | 173 | select = item.getAdapterPosition(); |
| 177 | notifyDataSetChanged(); | 174 | notifyDataSetChanged(); |
| 178 | } | 175 | } |
| 179 | }); | 176 | }); |
| 180 | } | 177 | } |
| 181 | } | 178 | } |
| 182 | }; | 179 | }; |
| 183 | recycle.setLayoutManager(new LinearLayoutManager(ChooseActivity.this, LinearLayoutManager.VERTICAL, false)); | 180 | recycle.setLayoutManager(new LinearLayoutManager(ChooseActivity.this, LinearLayoutManager.VERTICAL, false)); |
| 184 | recycle.setAdapter(adapter); | 181 | recycle.setAdapter(adapter); |
| 185 | } | 182 | } |
| 186 | 183 | ||
| 187 | @OnClick(R.id.tv_confirm) | 184 | @OnClick(R.id.tv_confirm) |
| 188 | public void confirm(View view) { | 185 | public void confirm(View view) { |
| 189 | if (alist.size() > 0 && alist.size() - 1 >= select && alist.get(select) != null) { | 186 | if (alist.size() > 0 && alist.size() - 1 >= select && alist.get(select) != null) { |
| 190 | StudentBean studentBean = alist.get(select); | 187 | StudentBean studentBean = alist.get(select); |
| 191 | if (studentBean.getStuId() != null) { | 188 | if (studentBean.getStuId() != null) { |
| 192 | Intent intent = new Intent(ChooseActivity.this, MainActivity.class); | 189 | Intent intent = new Intent(ChooseActivity.this, MainActivity.class); |
| 193 | SharedPreferencesUtil.putData("student", new Gson().toJson(studentBean)); | 190 | SharedPreferencesUtil.putData("student", new Gson().toJson(studentBean)); |
| 194 | startActivity(intent); | 191 | startActivity(intent); |
| 195 | finish(); | 192 | finish(); |
| 196 | } | 193 | } |
| 197 | } | 194 | } |
| 198 | } | 195 | } |
| 199 | } | 196 | } |
| 200 | 197 |
app/src/main/java/com/hjx/parent/EditStudentActivity.java
| 1 | package com.hjx.parent; | 1 | package com.hjx.parent; |
| 2 | 2 | ||
| 3 | import android.content.DialogInterface; | ||
| 3 | import android.content.Intent; | 4 | import android.content.Intent; |
| 4 | import android.graphics.Bitmap; | 5 | import android.graphics.Bitmap; |
| 5 | import android.graphics.Color; | 6 | import android.graphics.Color; |
| 6 | import android.net.Uri; | 7 | import android.net.Uri; |
| 7 | import android.os.Build; | 8 | import android.os.Build; |
| 8 | import android.os.Bundle; | 9 | import android.os.Bundle; |
| 9 | import android.os.Environment; | 10 | import android.os.Environment; |
| 10 | import android.provider.MediaStore; | 11 | import android.provider.MediaStore; |
| 11 | import android.text.TextUtils; | 12 | import android.text.TextUtils; |
| 12 | import android.util.Log; | 13 | import android.util.Log; |
| 13 | import android.view.LayoutInflater; | 14 | import android.view.LayoutInflater; |
| 14 | import android.view.View; | 15 | import android.view.View; |
| 15 | import android.widget.Button; | 16 | import android.widget.Button; |
| 16 | import android.widget.ImageView; | 17 | import android.widget.ImageView; |
| 18 | import android.widget.LinearLayout; | ||
| 19 | import android.widget.RelativeLayout; | ||
| 17 | import android.widget.TextView; | 20 | import android.widget.TextView; |
| 18 | import android.widget.Toast; | 21 | import android.widget.Toast; |
| 19 | 22 | ||
| 20 | import androidx.core.content.FileProvider; | 23 | import androidx.core.content.FileProvider; |
| 21 | 24 | ||
| 22 | import com.bumptech.glide.Glide; | 25 | import com.bumptech.glide.Glide; |
| 23 | import com.bumptech.glide.load.resource.bitmap.RoundedCorners; | 26 | import com.bumptech.glide.load.resource.bitmap.RoundedCorners; |
| 24 | import com.bumptech.glide.request.RequestOptions; | 27 | import com.bumptech.glide.request.RequestOptions; |
| 25 | import com.google.android.material.bottomsheet.BottomSheetDialog; | 28 | import com.google.android.material.bottomsheet.BottomSheetDialog; |
| 26 | import com.google.gson.Gson; | 29 | import com.google.gson.Gson; |
| 27 | import com.hjq.permissions.OnPermissionCallback; | 30 | import com.hjq.permissions.OnPermissionCallback; |
| 28 | import com.hjq.permissions.Permission; | 31 | import com.hjq.permissions.Permission; |
| 29 | import com.hjq.permissions.XXPermissions; | 32 | import com.hjq.permissions.XXPermissions; |
| 30 | import com.hjx.parent.bean.StudentBean; | 33 | import com.hjx.parent.bean.StudentBean; |
| 31 | import com.prws.common.base.BaseActivity; | 34 | import com.prws.common.base.BaseActivity; |
| 32 | import com.prws.common.base.BasePresenter; | 35 | import com.prws.common.base.BasePresenter; |
| 33 | import com.prws.common.bean.ResponseResult; | 36 | import com.prws.common.bean.ResponseResult; |
| 37 | import com.prws.common.bean.Teacher; | ||
| 34 | import com.prws.common.net.NetWorks; | 38 | import com.prws.common.net.NetWorks; |
| 35 | import com.prws.common.utils.LogUtil; | 39 | import com.prws.common.utils.LogUtil; |
| 36 | import com.prws.common.utils.ScreenUtils; | 40 | import com.prws.common.utils.ScreenUtils; |
| 37 | import com.prws.common.utils.SharedPreferencesUtil; | 41 | import com.prws.common.utils.SharedPreferencesUtil; |
| 38 | 42 | ||
| 39 | import org.json.JSONObject; | 43 | import org.json.JSONObject; |
| 40 | 44 | ||
| 41 | import java.io.File; | 45 | import java.io.File; |
| 42 | import java.io.FileOutputStream; | 46 | import java.io.FileOutputStream; |
| 43 | import java.io.IOException; | 47 | import java.io.IOException; |
| 44 | import java.util.HashMap; | 48 | import java.util.HashMap; |
| 45 | import java.util.List; | 49 | import java.util.List; |
| 46 | import java.util.Map; | 50 | import java.util.Map; |
| 47 | 51 | ||
| 48 | import butterknife.BindView; | 52 | import butterknife.BindView; |
| 49 | import butterknife.OnClick; | 53 | import butterknife.OnClick; |
| 50 | import io.reactivex.Observer; | 54 | import io.reactivex.Observer; |
| 51 | import io.reactivex.disposables.Disposable; | 55 | import io.reactivex.disposables.Disposable; |
| 52 | 56 | ||
| 53 | public class EditStudentActivity extends BaseActivity { | 57 | public class EditStudentActivity extends BaseActivity { |
| 54 | View view_2; | 58 | View view_2; |
| 55 | View view_3; | 59 | View view_3; |
| 56 | View view_4; | 60 | View view_4; |
| 57 | View view_5; | 61 | View view_5; |
| 58 | Button btn_next; | 62 | Button btn_next; |
| 59 | TextView tv_name, tv_sex, tv_nian, tv_shen; | 63 | TextView tv_name, tv_sex, tv_nian, tv_shen; |
| 60 | @BindView(R.id.iv_avatar) | 64 | @BindView(R.id.iv_avatar) |
| 61 | ImageView iv_avatar; | 65 | ImageView iv_avatar; |
| 62 | @BindView(R.id.tv_teacher) | 66 | @BindView(R.id.tv_teacher) |
| 63 | TextView tv_teacher; | 67 | TextView tv_teacher; |
| 64 | @BindView(R.id.iv_teacher) | 68 | @BindView(R.id.iv_teacher) |
| 65 | ImageView iv_teacher; | 69 | ImageView iv_teacher; |
| 70 | @BindView(R.id.rl_teacher) | ||
| 71 | RelativeLayout rl_teacher; | ||
| 72 | @BindView(R.id.tv_bind) | ||
| 73 | TextView tv_bind; | ||
| 74 | @BindView(R.id.view_6) | ||
| 75 | LinearLayout view_6; | ||
| 66 | private static int CAMERA_REQUEST_CODE = 343; | 76 | private static int CAMERA_REQUEST_CODE = 343; |
| 67 | private static int ALBUM_REQUEST_CODE = 456; | 77 | private static int ALBUM_REQUEST_CODE = 456; |
| 68 | private static int CROP_REQUEST_CODE = 234; | 78 | private static int CROP_REQUEST_CODE = 234; |
| 79 | |||
| 80 | private static int BIND_TEACHER_CODE = 345; | ||
| 69 | private File tempFile; | 81 | private File tempFile; |
| 70 | private String path; | 82 | private String path; |
| 71 | StudentBean studentBean; | 83 | StudentBean studentBean; |
| 84 | private Teacher teacher; | ||
| 72 | 85 | ||
| 73 | @Override | 86 | @Override |
| 74 | protected int layoutResId() { | 87 | protected int layoutResId() { |
| 75 | return R.layout.activity_edit_stu; | 88 | return R.layout.activity_edit_stu; |
| 76 | } | 89 | } |
| 77 | 90 | ||
| 78 | @Override | 91 | @Override |
| 79 | public Object getContract() { | 92 | public Object getContract() { |
| 80 | return null; | 93 | return null; |
| 81 | } | 94 | } |
| 82 | 95 | ||
| 83 | @Override | 96 | @Override |
| 84 | public BasePresenter getPresenter() { | 97 | public BasePresenter getPresenter() { |
| 85 | return null; | 98 | return null; |
| 86 | } | 99 | } |
| 87 | 100 | ||
| 88 | @Override | 101 | @Override |
| 89 | protected void initView() { | 102 | protected void initView() { |
| 90 | view_2 = findViewById(R.id.view_2); | 103 | view_2 = findViewById(R.id.view_2); |
| 91 | view_3 = findViewById(R.id.view_3); | 104 | view_3 = findViewById(R.id.view_3); |
| 92 | view_4 = findViewById(R.id.view_4); | 105 | view_4 = findViewById(R.id.view_4); |
| 93 | view_5 = findViewById(R.id.view_5); | 106 | view_5 = findViewById(R.id.view_5); |
| 94 | tv_name = findViewById(R.id.tv_name); | 107 | tv_name = findViewById(R.id.tv_name); |
| 95 | tv_sex = findViewById(R.id.tv_sex); | 108 | tv_sex = findViewById(R.id.tv_sex); |
| 96 | tv_nian = findViewById(R.id.tv_nian); | 109 | tv_nian = findViewById(R.id.tv_nian); |
| 97 | tv_shen = findViewById(R.id.tv_shen); | 110 | tv_shen = findViewById(R.id.tv_shen); |
| 98 | btn_next = findViewById(R.id.btn_next); | 111 | btn_next = findViewById(R.id.btn_next); |
| 99 | } | 112 | } |
| 100 | 113 | ||
| 101 | @Override | 114 | @Override |
| 102 | protected void onStart() { | 115 | protected void onStart() { |
| 103 | super.onStart(); | 116 | super.onStart(); |
| 104 | String name = (String) SharedPreferencesUtil.getData("setName", ""); | 117 | String name = (String) SharedPreferencesUtil.getData("setName", ""); |
| 105 | String sex = (String) SharedPreferencesUtil.getData("setSex", ""); | 118 | String sex = (String) SharedPreferencesUtil.getData("setSex", ""); |
| 106 | String nian = (String) SharedPreferencesUtil.getData("setNian", ""); | 119 | String nian = (String) SharedPreferencesUtil.getData("setNian", ""); |
| 107 | String shen = (String) SharedPreferencesUtil.getData("setShen", ""); | 120 | String shen = (String) SharedPreferencesUtil.getData("setShen", ""); |
| 108 | String xueq = (String) SharedPreferencesUtil.getData("setXueq", ""); | 121 | String xueq = (String) SharedPreferencesUtil.getData("setXueq", ""); |
| 109 | btn_next.setTextColor(Color.WHITE); | 122 | btn_next.setTextColor(Color.WHITE); |
| 110 | btn_next.setBackground(getResources().getDrawable(R.drawable.bg_solid_btn)); | 123 | btn_next.setBackground(getResources().getDrawable(R.drawable.bg_solid_btn)); |
| 111 | studentBean = new Gson().fromJson(getIntent().getStringExtra("student"), StudentBean.class); | 124 | studentBean = new Gson().fromJson(getIntent().getStringExtra("student"), StudentBean.class); |
| 112 | if (name != null && name.length() > 0) { | 125 | if (name != null && name.length() > 0) { |
| 113 | studentBean.setNickName(name); | 126 | studentBean.setNickName(name); |
| 114 | } | 127 | } |
| 115 | if (sex != null && sex.length() > 0) { | 128 | if (sex != null && sex.length() > 0) { |
| 116 | studentBean.setGender("男".equals(sex) ? 0 : 1); | 129 | studentBean.setGender("男".equals(sex) ? 0 : 1); |
| 117 | } | 130 | } |
| 118 | if (nian != null && nian.length() > 0) { | 131 | if (nian != null && nian.length() > 0) { |
| 119 | studentBean.setGrade(nian); | 132 | studentBean.setGrade(nian); |
| 120 | studentBean.setGradeId((Integer) SharedPreferencesUtil.getData("grade", 1)); | 133 | studentBean.setGradeId((Integer) SharedPreferencesUtil.getData("grade", 1)); |
| 121 | } | 134 | } |
| 122 | if (xueq != null && xueq.length() > 0) { | 135 | if (xueq != null && xueq.length() > 0) { |
| 123 | studentBean.setTerm(xueq); | 136 | studentBean.setTerm(xueq); |
| 124 | } | 137 | } |
| 125 | if (shen != null && shen.length() > 0) { | 138 | if (shen != null && shen.length() > 0) { |
| 126 | studentBean.setParentIdentity(shen); | 139 | studentBean.setParentIdentity(shen); |
| 127 | } | 140 | } |
| 128 | tv_name.setText(studentBean.getNickName()); | 141 | tv_name.setText(studentBean.getNickName()); |
| 129 | tv_nian.setText(studentBean.getGrade() + studentBean.getTerm()); | 142 | tv_nian.setText(studentBean.getGrade() + studentBean.getTerm()); |
| 130 | tv_sex.setText(studentBean.getGender() == 0 ? "男" : "女"); | 143 | tv_sex.setText(studentBean.getGender() == 0 ? "男" : "女"); |
| 131 | tv_shen.setText(studentBean.getParentIdentity()); | 144 | tv_shen.setText(studentBean.getParentIdentity()); |
| 132 | if (!TextUtils.isEmpty(studentBean.getPhoto())) { | 145 | if (!TextUtils.isEmpty(studentBean.getPhoto())) { |
| 133 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(this, 45)); | 146 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(this, 45)); |
| 134 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); | 147 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); |
| 135 | Glide.with(this).load(studentBean.getPhoto()).apply(options).into(iv_avatar); | 148 | Glide.with(this).load(studentBean.getPhoto()).apply(options).into(iv_avatar); |
| 136 | } else { | 149 | } else { |
| 137 | iv_avatar.setImageResource(studentBean.getGender() == 0 ? R.mipmap.ic_avatar_male : R.mipmap.ic_avatar_female); | 150 | iv_avatar.setImageResource(studentBean.getGender() == 0 ? R.mipmap.ic_avatar_male : R.mipmap.ic_avatar_female); |
| 138 | } | 151 | } |
| 139 | if (!"虚拟".equals(studentBean.getTeacherIdentity())) { | 152 | if (!"虚拟".equals(studentBean.getTeacherIdentity())) { |
| 153 | rl_teacher.setVisibility(View.VISIBLE); | ||
| 154 | tv_bind.setText("重新绑定"); | ||
| 140 | tv_teacher.setText(studentBean.getTeacherName()); | 155 | tv_teacher.setText(studentBean.getTeacherName()); |
| 141 | if (!TextUtils.isEmpty(studentBean.getTeacherAvatar())) { | 156 | if (!TextUtils.isEmpty(studentBean.getTeacherAvatar())) { |
| 142 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(this, 25)); | 157 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(this, 25)); |
| 143 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); | 158 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); |
| 144 | Glide.with(this).load(studentBean.getTeacherAvatar()).apply(options).into(iv_teacher); | 159 | Glide.with(this).load(studentBean.getTeacherAvatar()).apply(options).into(iv_teacher); |
| 145 | } else { | 160 | } else { |
| 146 | iv_teacher.setImageResource(studentBean.getSex() == 0 ? R.mipmap.ic_teacher_male : R.mipmap.ic_teacher_female); | 161 | iv_teacher.setImageResource(studentBean.getSex() == 0 ? R.mipmap.ic_teacher_male : R.mipmap.ic_teacher_female); |
| 147 | } | 162 | } |
| 148 | } else { | 163 | } else { |
| 149 | iv_teacher.setVisibility(View.GONE); | 164 | rl_teacher.setVisibility(View.GONE); |
| 165 | if ((studentBean.getState() != null && studentBean.getState() == 0)) { | ||
| 166 | tv_bind.setText("待通过"); | ||
| 167 | tv_bind.setTextColor(Color.parseColor("#FF3737")); | ||
| 168 | view_6.setEnabled(false); | ||
| 169 | } | ||
| 150 | } | 170 | } |
| 151 | 171 | ||
| 152 | } | 172 | } |
| 153 | 173 | ||
| 154 | @Override | 174 | @Override |
| 155 | protected void initListener() { | 175 | protected void initListener() { |
| 156 | view_2.setOnClickListener(view -> startActivity(NickActivity.class)); | 176 | view_2.setOnClickListener(view -> startActivity(NickActivity.class)); |
| 157 | view_3.setOnClickListener(view -> startActivity(SexActivity.class)); | 177 | view_3.setOnClickListener(view -> startActivity(SexActivity.class)); |
| 158 | view_4.setOnClickListener(view -> startActivity(NianActivity.class)); | 178 | view_4.setOnClickListener(view -> startActivity(NianActivity.class)); |
| 159 | view_5.setOnClickListener(view -> startActivity(ShenActivity.class)); | 179 | view_5.setOnClickListener(view -> startActivity(ShenActivity.class)); |
| 160 | findViewById(R.id.tv_cancel).setOnClickListener(view -> onBackPressed()); | 180 | findViewById(R.id.tv_cancel).setOnClickListener(view -> onBackPressed()); |
| 161 | btn_next.setOnClickListener(view -> { | 181 | btn_next.setOnClickListener(view -> { |
| 162 | editStudent(); | 182 | if (teacher != null || !"虚拟".equals(studentBean.getTeacherIdentity()) || (studentBean.getState() != null && studentBean.getState() == 0)) { |
| 183 | editStudent(); | ||
| 184 | } else { | ||
| 185 | showDialog("温馨提示", "您还未绑定老师,是否绑定?", "去绑定", "暂不绑定", new DialogInterface.OnClickListener() { | ||
| 186 | @Override | ||
| 187 | public void onClick(DialogInterface dialogInterface, int i) { | ||
| 188 | dialogInterface.dismiss(); | ||
| 189 | showDialog("温馨提示", "您暂未绑定老师,如需绑定老师\n" + "请联系400-800-3813", "确定", "", null, new DialogInterface.OnClickListener() { | ||
| 190 | @Override | ||
| 191 | public void onClick(DialogInterface dialogInterface, int i) { | ||
| 192 | editStudent(); | ||
| 193 | } | ||
| 194 | }); | ||
| 195 | } | ||
| 196 | }, new DialogInterface.OnClickListener() { | ||
| 197 | @Override | ||
| 198 | public void onClick(DialogInterface dialogInterface, int i) { | ||
| 199 | Intent intent = new Intent(EditStudentActivity.this, AddTeacherActivity.class); | ||
| 200 | startActivityForResult(intent, BIND_TEACHER_CODE); | ||
| 201 | } | ||
| 202 | }); | ||
| 203 | } | ||
| 163 | }); | 204 | }); |
| 164 | } | 205 | } |
| 165 | 206 | ||
| 207 | @OnClick(R.id.view_6) | ||
| 208 | public void toAddTeacher(View view) { | ||
| 209 | Intent intent = new Intent(EditStudentActivity.this, AddTeacherActivity.class); | ||
| 210 | startActivityForResult(intent, BIND_TEACHER_CODE); | ||
| 211 | } | ||
| 212 | |||
| 166 | public void editStudent() { | 213 | public void editStudent() { |
| 167 | Map map = new HashMap(); | 214 | Map map = new HashMap(); |
| 168 | map.put("nickName", studentBean.getNickName()); | 215 | map.put("nickName", studentBean.getNickName()); |
| 169 | map.put("gender", studentBean.getGender()); | 216 | map.put("gender", studentBean.getGender()); |
| 170 | map.put("gradeId", studentBean.getGradeId()); | 217 | map.put("gradeId", studentBean.getGradeId()); |
| 171 | map.put("parentIdentity", studentBean.getParentIdentity()); | 218 | map.put("parentIdentity", studentBean.getParentIdentity()); |
| 172 | map.put("term", studentBean.getTerm()); | 219 | map.put("term", studentBean.getTerm()); |
| 220 | if (teacher != null) { | ||
| 221 | map.put("teacherId", teacher.getId()); | ||
| 222 | } | ||
| 173 | map.put("stuId", studentBean.getStuId()); | 223 | map.put("stuId", studentBean.getStuId()); |
| 174 | NetWorks.editStudent(NetWorks.getMapRequestBody(map), new Observer<ResponseResult>() { | 224 | NetWorks.editStudent(NetWorks.getMapRequestBody(map), new Observer<ResponseResult>() { |
| 175 | @Override | 225 | @Override |
| 176 | public void onSubscribe(Disposable d) { | 226 | public void onSubscribe(Disposable d) { |
| 177 | 227 | ||
| 178 | } | 228 | } |
| 179 | 229 | ||
| 180 | @Override | 230 | @Override |
| 181 | public void onNext(ResponseResult responseResult) { | 231 | public void onNext(ResponseResult responseResult) { |
| 182 | try { | 232 | try { |
| 183 | boolean isSucceed = responseResult.getSuccess(); | 233 | boolean isSucceed = responseResult.getSuccess(); |
| 184 | if (isSucceed) { | 234 | if (isSucceed) { |
| 185 | finish(); | 235 | finish(); |
| 186 | } else { | 236 | } else { |
| 187 | Toast.makeText(EditStudentActivity.this, responseResult.getMsg(), Toast.LENGTH_SHORT).show(); | 237 | Toast.makeText(EditStudentActivity.this, responseResult.getMsg(), Toast.LENGTH_SHORT).show(); |
| 188 | } | 238 | } |
| 189 | } catch (Exception e) { | 239 | } catch (Exception e) { |
| 190 | 240 | ||
| 191 | } | 241 | } |
| 192 | } | 242 | } |
| 193 | 243 | ||
| 194 | @Override | 244 | @Override |
| 195 | public void onError(Throwable e) { | 245 | public void onError(Throwable e) { |
| 196 | 246 | ||
| 197 | } | 247 | } |
| 198 | 248 | ||
| 199 | @Override | 249 | @Override |
| 200 | public void onComplete() { | 250 | public void onComplete() { |
| 201 | 251 | ||
| 202 | } | 252 | } |
| 203 | }); | 253 | }); |
| 204 | } | 254 | } |
| 205 | 255 | ||
| 206 | @Override | 256 | @Override |
| 207 | protected void initData() { | 257 | protected void initData() { |
| 208 | 258 | ||
| 209 | } | 259 | } |
| 210 | 260 | ||
| 211 | @Override | 261 | @Override |
| 212 | public void onNetChanged(int netWorkState) { | 262 | public void onNetChanged(int netWorkState) { |
| 213 | 263 | ||
| 214 | } | 264 | } |
| 215 | 265 | ||
| 216 | private void cropPhoto(Uri uri) { | 266 | private void cropPhoto(Uri uri) { |
| 217 | Uri contentUri = Uri.fromFile(new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), System.currentTimeMillis() + ".jpg")); | 267 | Uri contentUri = Uri.fromFile(new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), System.currentTimeMillis() + ".jpg")); |
| 218 | Intent intent = new Intent("com.android.camera.action.CROP"); | 268 | Intent intent = new Intent("com.android.camera.action.CROP"); |
| 219 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { | 269 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { |
| 220 | //Android 7.0需要临时添加读取Url的权限, 添加此属性是为了解决:调用裁剪框时候提示:图片无法加载或者加载图片失败或者无法加载此图片 | 270 | //Android 7.0需要临时添加读取Url的权限, 添加此属性是为了解决:调用裁剪框时候提示:图片无法加载或者加载图片失败或者无法加载此图片 |
| 221 | intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION); | 271 | intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION); |
| 222 | } | 272 | } |
| 223 | intent.setDataAndType(uri, "image/*"); | 273 | intent.setDataAndType(uri, "image/*"); |
| 224 | intent.putExtra("crop", "true");//发送裁剪信号,去掉也能进行裁剪 | 274 | intent.putExtra("crop", "true");//发送裁剪信号,去掉也能进行裁剪 |
| 225 | intent.putExtra("scale", true);// 设置缩放 | 275 | intent.putExtra("scale", true);// 设置缩放 |
| 226 | intent.putExtra("scaleUpIfNeeded", true);// 去黑边 | 276 | intent.putExtra("scaleUpIfNeeded", true);// 去黑边 |
| 227 | intent.putExtra("aspectX", 1); | 277 | intent.putExtra("aspectX", 1); |
| 228 | intent.putExtra("aspectY", 1); | 278 | intent.putExtra("aspectY", 1); |
| 229 | //上述两个属性控制裁剪框的缩放比例。 | 279 | //上述两个属性控制裁剪框的缩放比例。 |
| 230 | //当用户用手拉伸裁剪框时候,裁剪框会按照上述比例缩放。 | 280 | //当用户用手拉伸裁剪框时候,裁剪框会按照上述比例缩放。 |
| 231 | intent.putExtra("outputX", 300);//属性控制裁剪完毕,保存的图片的大小格式。 | 281 | intent.putExtra("outputX", 300);//属性控制裁剪完毕,保存的图片的大小格式。 |
| 232 | intent.putExtra("outputY", 300);//你按照1:1的比例来裁剪的,如果最后成像是800*400,那么按照2:1的样式保存, | 282 | intent.putExtra("outputY", 300);//你按照1:1的比例来裁剪的,如果最后成像是800*400,那么按照2:1的样式保存, |
| 233 | intent.putExtra("outputFormat", Bitmap.CompressFormat.JPEG.toString());//输出裁剪文件的格式 | 283 | intent.putExtra("outputFormat", Bitmap.CompressFormat.JPEG.toString());//输出裁剪文件的格式 |
| 234 | intent.putExtra("return-data", true);//是否返回裁剪后图片的Bitmap | 284 | intent.putExtra("return-data", true);//是否返回裁剪后图片的Bitmap |
| 235 | intent.putExtra(MediaStore.EXTRA_OUTPUT, contentUri);//设置输出路径 | 285 | intent.putExtra(MediaStore.EXTRA_OUTPUT, contentUri);//设置输出路径 |
| 236 | startActivityForResult(intent, CROP_REQUEST_CODE); | 286 | startActivityForResult(intent, CROP_REQUEST_CODE); |
| 237 | } | 287 | } |
| 238 | 288 | ||
| 239 | @Override | 289 | @Override |
| 240 | protected void onActivityResult(int requestCode, int resultCode, Intent intent) { | 290 | protected void onActivityResult(int requestCode, int resultCode, Intent intent) { |
| 241 | super.onActivityResult(requestCode, resultCode, intent); | 291 | super.onActivityResult(requestCode, resultCode, intent); |
| 242 | if (requestCode == CAMERA_REQUEST_CODE) { | 292 | if (requestCode == CAMERA_REQUEST_CODE) { |
| 243 | if (resultCode == RESULT_OK) { | 293 | if (resultCode == RESULT_OK) { |
| 244 | //用相机返回的照片去调用剪裁也需要对Uri进行处理 | 294 | //用相机返回的照片去调用剪裁也需要对Uri进行处理 |
| 245 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { | 295 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { |
| 246 | Uri contentUri = FileProvider.getUriForFile(this, | 296 | Uri contentUri = FileProvider.getUriForFile(this, |
| 247 | this.getPackageName() + ".fileprovider", tempFile); | 297 | this.getPackageName() + ".fileprovider", tempFile); |
| 248 | cropPhoto(contentUri); | 298 | cropPhoto(contentUri); |
| 249 | } else { | 299 | } else { |
| 250 | cropPhoto(Uri.fromFile(tempFile)); | 300 | cropPhoto(Uri.fromFile(tempFile)); |
| 251 | } | 301 | } |
| 252 | } | 302 | } |
| 253 | } else if (requestCode == ALBUM_REQUEST_CODE) { | 303 | } else if (requestCode == ALBUM_REQUEST_CODE) { |
| 254 | if (resultCode == RESULT_OK) { | 304 | if (resultCode == RESULT_OK) { |
| 255 | Uri uri = intent.getData(); | 305 | Uri uri = intent.getData(); |
| 256 | cropPhoto(uri); | 306 | cropPhoto(uri); |
| 257 | } | 307 | } |
| 258 | } else if (requestCode == CROP_REQUEST_CODE) { | 308 | } else if (requestCode == CROP_REQUEST_CODE) { |
| 259 | if (intent == null) { | 309 | if (intent == null) { |
| 260 | return; | 310 | return; |
| 261 | } | 311 | } |
| 262 | Bundle bundle = intent.getExtras(); | 312 | Bundle bundle = intent.getExtras(); |
| 263 | if (bundle != null) { | 313 | if (bundle != null) { |
| 264 | //在这里获得了剪裁后的Bitmap对象,可以用于上传 | 314 | //在这里获得了剪裁后的Bitmap对象,可以用于上传 |
| 265 | Bitmap image = bundle.getParcelable("data"); | 315 | Bitmap image = bundle.getParcelable("data"); |
| 266 | //设置到ImageView上 | 316 | //设置到ImageView上 |
| 267 | //也可以进行一些保存、压缩等操作后上传 | 317 | //也可以进行一些保存、压缩等操作后上传 |
| 268 | File file = saveImage("head_output", image); | 318 | File file = saveImage("head_output", image); |
| 269 | uploadAvatar(file); | 319 | uploadAvatar(file); |
| 270 | // Log.d("dsadsadsa",path); | 320 | // Log.d("dsadsadsa",path); |
| 271 | } | 321 | } |
| 322 | } else if (requestCode == BIND_TEACHER_CODE && resultCode == 1000) { | ||
| 323 | String t = intent.getStringExtra("teacher"); | ||
| 324 | teacher = new Gson().fromJson(t, Teacher.class); | ||
| 325 | rl_teacher.setVisibility(View.VISIBLE); | ||
| 326 | tv_bind.setText("重新绑定"); | ||
| 327 | tv_teacher.setText(teacher.getUserName()); | ||
| 328 | if (!TextUtils.isEmpty(teacher.getPhoto())) { | ||
| 329 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(EditStudentActivity.this, 20)); | ||
| 330 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); | ||
| 331 | Glide.with(EditStudentActivity.this).load(teacher.getPhoto()).apply(options).into(iv_teacher); | ||
| 332 | } | ||
| 272 | } | 333 | } |
| 273 | } | 334 | } |
| 274 | 335 | ||
| 275 | private void uploadAvatar(File file) { | 336 | private void uploadAvatar(File file) { |
| 276 | NetWorks.uploadStudentAvatar(file, studentBean.getStuId(), new Observer<ResponseResult<Map<String, String>>>() { | 337 | NetWorks.uploadStudentAvatar(file, studentBean.getStuId(), new Observer<ResponseResult<Map<String, String>>>() { |
| 277 | @Override | 338 | @Override |
| 278 | public void onSubscribe(Disposable d) { | 339 | public void onSubscribe(Disposable d) { |
| 279 | 340 | ||
| 280 | } | 341 | } |
| 281 | 342 | ||
| 282 | @Override | 343 | @Override |
| 283 | public void onNext(ResponseResult<Map<String, String>> responseBody) { | 344 | public void onNext(ResponseResult<Map<String, String>> responseBody) { |
| 284 | if (responseBody.getData() != null && responseBody.getCode() == 200) { | 345 | if (responseBody.getData() != null && responseBody.getCode() == 200) { |
| 285 | String filePath = responseBody.getData().get("imageUrl"); | 346 | String filePath = responseBody.getData().get("imageUrl"); |
| 286 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(EditStudentActivity.this, 45)); | 347 | RoundedCorners roundedCorners = new RoundedCorners(ScreenUtils.dpToPx(EditStudentActivity.this, 45)); |
| 287 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); | 348 | RequestOptions options = RequestOptions.bitmapTransform(roundedCorners); |
| 288 | Glide.with(EditStudentActivity.this).load(filePath).apply(options).into(iv_avatar); | 349 | Glide.with(EditStudentActivity.this).load(filePath).apply(options).into(iv_avatar); |
| 289 | } | 350 | } |
| 290 | } | 351 | } |
| 291 | 352 | ||
| 292 | @Override | 353 | @Override |
| 293 | public void onError(Throwable e) { | 354 | public void onError(Throwable e) { |
| 294 | e.toString(); | 355 | e.toString(); |
| 295 | } | 356 | } |
| 296 | 357 | ||
| 297 | @Override | 358 | @Override |
| 298 | public void onComplete() { | 359 | public void onComplete() { |
| 299 | 360 | ||
| 300 | } | 361 | } |
| 301 | }); | 362 | }); |
| 302 | } | 363 | } |
| 303 | 364 | ||
| 304 | public File saveImage(String name, Bitmap bmp) { | 365 | public File saveImage(String name, Bitmap bmp) { |
| 305 | File appDir = new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES).getPath()); | 366 | File appDir = new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES).getPath()); |
| 306 | if (!appDir.exists()) { | 367 | if (!appDir.exists()) { |
| 307 | appDir.mkdir(); | 368 | appDir.mkdir(); |
| 308 | } | 369 | } |
| 309 | String fileName = name + ".jpg"; | 370 | String fileName = name + ".jpg"; |
| 310 | File file = new File(appDir, fileName); | 371 | File file = new File(appDir, fileName); |
| 311 | try { | 372 | try { |
| 312 | FileOutputStream fos = new FileOutputStream(file); | 373 | FileOutputStream fos = new FileOutputStream(file); |
| 313 | bmp.compress(Bitmap.CompressFormat.PNG, 100, fos); | 374 | bmp.compress(Bitmap.CompressFormat.PNG, 100, fos); |
| 314 | fos.flush(); | 375 | fos.flush(); |
| 315 | fos.close(); | 376 | fos.close(); |
| 316 | return file; | 377 | return file; |
| 317 | } catch (IOException e) { | 378 | } catch (IOException e) { |
| 318 | Log.d("dsadsadsa", e.getLocalizedMessage()); | 379 | Log.d("dsadsadsa", e.getLocalizedMessage()); |
| 319 | e.printStackTrace(); | 380 | e.printStackTrace(); |
| 320 | } | 381 | } |
| 321 | return null; | 382 | return null; |
| 322 | } | 383 | } |
| 323 | 384 | ||
| 324 | private void getPicFromCamera() { | 385 | private void getPicFromCamera() { |
| 325 | //用于保存调用相机拍照后所生成的文件 | 386 | //用于保存调用相机拍照后所生成的文件 |
| 326 | tempFile = new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), System.currentTimeMillis() + ".jpg"); | 387 | tempFile = new File(getExternalFilesDir(Environment.DIRECTORY_PICTURES), System.currentTimeMillis() + ".jpg"); |
| 327 | //跳转到调用系统相机 | 388 | //跳转到调用系统相机 |
| 328 | Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); | 389 | Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); |
| 329 | //判断版本 | 390 | //判断版本 |
| 330 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { //如果在Android7.0以上,使用FileProvider获取Uri | 391 | if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { //如果在Android7.0以上,使用FileProvider获取Uri |
| 331 | intent.setFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION); | 392 | intent.setFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION); |
| 332 | Uri contentUri = FileProvider.getUriForFile(this, | 393 | Uri contentUri = FileProvider.getUriForFile(this, |
| 333 | this.getPackageName() + ".fileprovider", tempFile); | 394 | this.getPackageName() + ".fileprovider", tempFile); |
| 334 | intent.putExtra(MediaStore.EXTRA_OUTPUT, contentUri); | 395 | intent.putExtra(MediaStore.EXTRA_OUTPUT, contentUri); |
| 335 | } else { //否则使用Uri.fromFile(file)方法获取Uri | 396 | } else { //否则使用Uri.fromFile(file)方法获取Uri |
| 336 | intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(tempFile)); | 397 | intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(tempFile)); |
| 337 | } | 398 | } |
| 338 | startActivityForResult(intent, CAMERA_REQUEST_CODE); | 399 | startActivityForResult(intent, CAMERA_REQUEST_CODE); |
| 339 | } | 400 | } |
| 340 | 401 | ||
| 341 | /** | 402 | /** |
| 342 | * 从相册获取图片 | 403 | * 从相册获取图片 |
| 343 | */ | 404 | */ |
| 344 | private void getPicFromAlbm() { | 405 | private void getPicFromAlbm() { |
| 345 | Intent photoPickerIntent = new Intent(Intent.ACTION_PICK); | 406 | Intent photoPickerIntent = new Intent(Intent.ACTION_PICK); |
| 346 | photoPickerIntent.setType("image/*"); | 407 | photoPickerIntent.setType("image/*"); |
| 347 | startActivityForResult(photoPickerIntent, ALBUM_REQUEST_CODE); | 408 | startActivityForResult(photoPickerIntent, ALBUM_REQUEST_CODE); |
| 348 | } | 409 | } |
| 349 | 410 | ||
| 350 | @Override | 411 | @Override |
| 351 | protected void onDestroy() { | 412 | protected void onDestroy() { |
| 352 | super.onDestroy(); | 413 | super.onDestroy(); |
| 353 | SharedPreferencesUtil.putData("setName", ""); | 414 | SharedPreferencesUtil.putData("setName", ""); |
| 354 | SharedPreferencesUtil.putData("setSex", ""); | 415 | SharedPreferencesUtil.putData("setSex", ""); |
| 355 | SharedPreferencesUtil.putData("setNian", ""); | 416 | SharedPreferencesUtil.putData("setNian", ""); |
| 356 | SharedPreferencesUtil.putData("setShen", ""); | 417 | SharedPreferencesUtil.putData("setShen", ""); |
| 357 | SharedPreferencesUtil.putData("setXueq", ""); | 418 | SharedPreferencesUtil.putData("setXueq", ""); |
| 358 | SharedPreferencesUtil.putData("grade", 0); | 419 | SharedPreferencesUtil.putData("grade", 0); |
| 359 | } | 420 | } |
| 360 | 421 | ||
| 361 | @OnClick(R.id.iv_avatar) | 422 | @OnClick(R.id.iv_avatar) |
| 362 | public void showButtonDialog(View view) { | 423 | public void showButtonDialog(View view) { |
| 363 | BottomSheetDialog dialog = new BottomSheetDialog(this, R.style.BottomSheetDialog); | 424 | BottomSheetDialog dialog = new BottomSheetDialog(this, R.style.BottomSheetDialog); |
| 364 | View bottomView = LayoutInflater.from(this).inflate(R.layout.bottom_sheet_layout, null); | 425 | View bottomView = LayoutInflater.from(this).inflate(R.layout.bottom_sheet_layout, null); |
| 365 | dialog.setContentView(bottomView); | 426 | dialog.setContentView(bottomView); |
| 366 | bottomView.findViewById(R.id.take_photo).setOnClickListener(new View.OnClickListener() { | 427 | bottomView.findViewById(R.id.take_photo).setOnClickListener(new View.OnClickListener() { |
| 367 | @Override | 428 | @Override |
| 368 | public void onClick(View view) { | 429 | public void onClick(View view) { |
| 369 | dialog.dismiss(); | 430 | dialog.dismiss(); |
| 370 | if (!XXPermissions.isGranted(EditStudentActivity.this, Permission.CAMERA)) { | 431 | if (!XXPermissions.isGranted(EditStudentActivity.this, Permission.CAMERA)) { |
| 371 | XXPermissions.with(EditStudentActivity.this) | 432 | XXPermissions.with(EditStudentActivity.this) |
| 372 | // 申请多个权限 | 433 | // 申请多个权限 |
| 373 | .permission(Permission.CAMERA) | 434 | .permission(Permission.CAMERA) |
| 374 | .request(new OnPermissionCallback() { | 435 | .request(new OnPermissionCallback() { |
| 375 | @Override | 436 | @Override |
| 376 | public void onGranted(List<String> permissions, boolean all) { | 437 | public void onGranted(List<String> permissions, boolean all) { |
| 377 | if (all) { | 438 | if (all) { |
| 378 | //开启扫码界面 | 439 | //开启扫码界面 |
| 379 | getPicFromCamera(); | 440 | getPicFromCamera(); |
| 380 | } else { | 441 | } else { |
| 381 | Toast.makeText(EditStudentActivity.this, "需要相机权限", Toast.LENGTH_SHORT).show(); | 442 | Toast.makeText(EditStudentActivity.this, "需要相机权限", Toast.LENGTH_SHORT).show(); |
| 382 | } | 443 | } |
| 383 | } | 444 | } |
| 384 | 445 | ||
| 385 | @Override | 446 | @Override |
| 386 | public void onDenied(List<String> permissions, boolean never) { | 447 | public void onDenied(List<String> permissions, boolean never) { |
| 387 | XXPermissions.startPermissionActivity(EditStudentActivity.this, permissions); | 448 | XXPermissions.startPermissionActivity(EditStudentActivity.this, permissions); |
| 388 | } | 449 | } |
| 389 | }); | 450 | }); |
| 390 | } else { | 451 | } else { |
| 391 | getPicFromCamera(); | 452 | getPicFromCamera(); |
| 392 | } | 453 | } |
| 393 | 454 | ||
| 394 | } | 455 | } |
| 395 | }); | 456 | }); |
| 396 | bottomView.findViewById(R.id.choose_photo).setOnClickListener(new View.OnClickListener() { | 457 | bottomView.findViewById(R.id.choose_photo).setOnClickListener(new View.OnClickListener() { |
| 397 | @Override | 458 | @Override |
| 398 | public void onClick(View view) { | 459 | public void onClick(View view) { |
| 399 | dialog.dismiss(); | 460 | dialog.dismiss(); |
| 400 | getPicFromAlbm(); | 461 | getPicFromAlbm(); |
| 401 | } | 462 | } |
| 402 | }); | 463 | }); |
| 403 | bottomView.findViewById(R.id.cancel).setOnClickListener(new View.OnClickListener() { | 464 | bottomView.findViewById(R.id.cancel).setOnClickListener(new View.OnClickListener() { |
| 404 | @Override | 465 | @Override |
| 405 | public void onClick(View view) { | 466 | public void onClick(View view) { |
| 406 | dialog.dismiss(); | 467 | dialog.dismiss(); |
| 407 | } | 468 | } |
| 408 | }); | 469 | }); |
| 409 | dialog.show(); | 470 | dialog.show(); |
| 410 | } | 471 | } |
| 411 | } | 472 | } |
| 412 | 473 |
app/src/main/java/com/hjx/parent/bean/StudentBean.java
| 1 | package com.hjx.parent.bean; | 1 | package com.hjx.parent.bean; |
| 2 | 2 | ||
| 3 | public class StudentBean { | 3 | public class StudentBean { |
| 4 | 4 | ||
| 5 | String stuId; | 5 | String stuId; |
| 6 | String stuName; | 6 | String stuName; |
| 7 | int gender; | 7 | int gender; |
| 8 | String term; | 8 | String term; |
| 9 | String account; | 9 | String account; |
| 10 | String nickName; | 10 | String nickName; |
| 11 | String address; | 11 | String address; |
| 12 | String phone; | 12 | String phone; |
| 13 | String photo; | 13 | String photo; |
| 14 | int fromType; | 14 | int fromType; |
| 15 | int gradeId; | 15 | int gradeId; |
| 16 | String oriSchool; | 16 | String oriSchool; |
| 17 | String parentPhone; | 17 | String parentPhone; |
| 18 | String parentIdentity; | 18 | String parentIdentity; |
| 19 | String teacherName; | 19 | String teacherName; |
| 20 | int teacherId; | 20 | int teacherId; |
| 21 | String teacherAvatar; | 21 | String teacherAvatar; |
| 22 | String grade; | 22 | String grade; |
| 23 | String teacherIdentity; | 23 | String teacherIdentity; |
| 24 | int sex; | 24 | int sex; |
| 25 | Integer state; | ||
| 25 | 26 | ||
| 27 | public void setState(Integer state) { | ||
| 28 | this.state = state; | ||
| 29 | } | ||
| 30 | |||
| 31 | public Integer getState() { | ||
| 32 | return state; | ||
| 33 | } | ||
| 26 | 34 | ||
| 27 | @Override | 35 | @Override |
| 28 | public String toString() { | 36 | public String toString() { |
| 29 | return "StudentBean{" + | 37 | return "StudentBean{" + |
| 30 | "stuId='" + stuId + '\'' + | 38 | "stuId='" + stuId + '\'' + |
| 31 | ", stuName='" + stuName + '\'' + | 39 | ", stuName='" + stuName + '\'' + |
| 32 | ", gender=" + gender + | 40 | ", gender=" + gender + |
| 33 | ", term='" + term + '\'' + | 41 | ", term='" + term + '\'' + |
| 34 | ", account='" + account + '\'' + | 42 | ", account='" + account + '\'' + |
| 35 | ", nickName='" + nickName + '\'' + | 43 | ", nickName='" + nickName + '\'' + |
| 36 | ", address='" + address + '\'' + | 44 | ", address='" + address + '\'' + |
| 37 | ", phone='" + phone + '\'' + | 45 | ", phone='" + phone + '\'' + |
| 38 | ", photo='" + photo + '\'' + | 46 | ", photo='" + photo + '\'' + |
| 39 | ", fromType=" + fromType + | 47 | ", fromType=" + fromType + |
| 40 | ", gradeId=" + gradeId + | 48 | ", gradeId=" + gradeId + |
| 41 | ", oriSchool='" + oriSchool + '\'' + | 49 | ", oriSchool='" + oriSchool + '\'' + |
| 42 | ", parentPhone='" + parentPhone + '\'' + | 50 | ", parentPhone='" + parentPhone + '\'' + |
| 43 | ", parentIdentity='" + parentIdentity + '\'' + | 51 | ", parentIdentity='" + parentIdentity + '\'' + |
| 44 | ", teacherName='" + teacherName + '\'' + | 52 | ", teacherName='" + teacherName + '\'' + |
| 45 | ", teacherId=" + teacherId + | 53 | ", teacherId=" + teacherId + |
| 46 | ", teacherAvatar=" + teacherAvatar + | 54 | ", teacherAvatar=" + teacherAvatar + |
| 47 | ", grade=" + grade + | 55 | ", grade=" + grade + |
| 48 | ", teacherIdentity=" + teacherIdentity + | 56 | ", teacherIdentity=" + teacherIdentity + |
| 49 | ", sex=" + sex + | 57 | ", sex=" + sex + |
| 58 | ", state=" + state + | ||
| 50 | '}'; | 59 | '}'; |
| 51 | } | 60 | } |
| 52 | 61 | ||
| 53 | public void setSex(int sex) { | 62 | public void setSex(int sex) { |
| 54 | this.sex = sex; | 63 | this.sex = sex; |
| 55 | } | 64 | } |
| 56 | 65 | ||
| 57 | public int getSex() { | 66 | public int getSex() { |
| 58 | return sex; | 67 | return sex; |
| 59 | } | 68 | } |
| 60 | 69 | ||
| 61 | public void setTeacherIdentity(String teacherIdentity) { | 70 | public void setTeacherIdentity(String teacherIdentity) { |
| 62 | this.teacherIdentity = teacherIdentity; | 71 | this.teacherIdentity = teacherIdentity; |
| 63 | } | 72 | } |
| 64 | 73 | ||
| 65 | public String getTeacherIdentity() { | 74 | public String getTeacherIdentity() { |
| 66 | return teacherIdentity; | 75 | return teacherIdentity; |
| 67 | } | 76 | } |
| 68 | 77 | ||
| 69 | public void setTeacherAvatar(String teacherAvatar) { | 78 | public void setTeacherAvatar(String teacherAvatar) { |
| 70 | this.teacherAvatar = teacherAvatar; | 79 | this.teacherAvatar = teacherAvatar; |
| 71 | } | 80 | } |
| 72 | 81 | ||
| 73 | public void setGrade(String grade) { | 82 | public void setGrade(String grade) { |
| 74 | this.grade = grade; | 83 | this.grade = grade; |
| 75 | } | 84 | } |
| 76 | 85 | ||
| 77 | public String getTeacherAvatar() { | 86 | public String getTeacherAvatar() { |
| 78 | return teacherAvatar; | 87 | return teacherAvatar; |
| 79 | } | 88 | } |
| 80 | 89 | ||
| 81 | public String getGrade() { | 90 | public String getGrade() { |
| 82 | return grade; | 91 | return grade; |
| 83 | } | 92 | } |
| 84 | 93 | ||
| 85 | public String getStuId() { | 94 | public String getStuId() { |
| 86 | return stuId; | 95 | return stuId; |
| 87 | } | 96 | } |
| 88 | 97 | ||
| 89 | public void setStuId(String stuId) { | 98 | public void setStuId(String stuId) { |
| 90 | this.stuId = stuId; | 99 | this.stuId = stuId; |
| 91 | } | 100 | } |
| 92 | 101 | ||
| 93 | public String getStuName() { | 102 | public String getStuName() { |
| 94 | return stuName; | 103 | return stuName; |
| 95 | } | 104 | } |
| 96 | 105 | ||
| 97 | public void setStuName(String stuName) { | 106 | public void setStuName(String stuName) { |
| 98 | this.stuName = stuName; | 107 | this.stuName = stuName; |
| 99 | } | 108 | } |
| 100 | 109 | ||
| 101 | public int getGender() { | 110 | public int getGender() { |
| 102 | return gender; | 111 | return gender; |
| 103 | } | 112 | } |
| 104 | 113 | ||
| 105 | public void setGender(int gender) { | 114 | public void setGender(int gender) { |
| 106 | this.gender = gender; | 115 | this.gender = gender; |
| 107 | } | 116 | } |
| 108 | 117 | ||
| 109 | public String getTerm() { | 118 | public String getTerm() { |
| 110 | return term; | 119 | return term; |
| 111 | } | 120 | } |
| 112 | 121 | ||
| 113 | public void setTerm(String term) { | 122 | public void setTerm(String term) { |
| 114 | this.term = term; | 123 | this.term = term; |
| 115 | } | 124 | } |
| 116 | 125 | ||
| 117 | public String getAccount() { | 126 | public String getAccount() { |
| 118 | return account; | 127 | return account; |
| 119 | } | 128 | } |
| 120 | 129 | ||
| 121 | public void setAccount(String account) { | 130 | public void setAccount(String account) { |
| 122 | this.account = account; | 131 | this.account = account; |
| 123 | } | 132 | } |
| 124 | 133 | ||
| 125 | public String getNickName() { | 134 | public String getNickName() { |
| 126 | return nickName; | 135 | return nickName; |
| 127 | } | 136 | } |
| 128 | 137 | ||
| 129 | public void setNickName(String nickName) { | 138 | public void setNickName(String nickName) { |
| 130 | this.nickName = nickName; | 139 | this.nickName = nickName; |
| 131 | } | 140 | } |
| 132 | 141 | ||
| 133 | public String getAddress() { | 142 | public String getAddress() { |
| 134 | return address; | 143 | return address; |
| 135 | } | 144 | } |
| 136 | 145 | ||
| 137 | public void setAddress(String address) { | 146 | public void setAddress(String address) { |
| 138 | this.address = address; | 147 | this.address = address; |
| 139 | } | 148 | } |
| 140 | 149 | ||
| 141 | public String getPhone() { | 150 | public String getPhone() { |
| 142 | return phone; | 151 | return phone; |
| 143 | } | 152 | } |
| 144 | 153 | ||
| 145 | public void setPhone(String phone) { | 154 | public void setPhone(String phone) { |
| 146 | this.phone = phone; | 155 | this.phone = phone; |
| 147 | } | 156 | } |
| 148 | 157 | ||
| 149 | public String getPhoto() { | 158 | public String getPhoto() { |
| 150 | return photo; | 159 | return photo; |
| 151 | } | 160 | } |
| 152 | 161 | ||
| 153 | public void setPhoto(String photo) { | 162 | public void setPhoto(String photo) { |
| 154 | this.photo = photo; | 163 | this.photo = photo; |
| 155 | } | 164 | } |
| 156 | 165 | ||
| 157 | public int getFromType() { | 166 | public int getFromType() { |
| 158 | return fromType; | 167 | return fromType; |
| 159 | } | 168 | } |
| 160 | 169 | ||
| 161 | public void setFromType(int fromType) { | 170 | public void setFromType(int fromType) { |
| 162 | this.fromType = fromType; | 171 | this.fromType = fromType; |
| 163 | } | 172 | } |
| 164 | 173 | ||
| 165 | public int getGradeId() { | 174 | public int getGradeId() { |
| 166 | return gradeId; | 175 | return gradeId; |
| 167 | } | 176 | } |
| 168 | 177 | ||
| 169 | public void setGradeId(int gradeId) { | 178 | public void setGradeId(int gradeId) { |
| 170 | this.gradeId = gradeId; | 179 | this.gradeId = gradeId; |
| 171 | } | 180 | } |
| 172 | 181 | ||
| 173 | public String getOriSchool() { | 182 | public String getOriSchool() { |
| 174 | return oriSchool; | 183 | return oriSchool; |
| 175 | } | 184 | } |
| 176 | 185 | ||
| 177 | public void setOriSchool(String oriSchool) { | 186 | public void setOriSchool(String oriSchool) { |
| 178 | this.oriSchool = oriSchool; | 187 | this.oriSchool = oriSchool; |
| 179 | } | 188 | } |
| 180 | 189 | ||
| 181 | public String getParentPhone() { | 190 | public String getParentPhone() { |
| 182 | return parentPhone; | 191 | return parentPhone; |
| 183 | } | 192 | } |
| 184 | 193 | ||
| 185 | public void setParentPhone(String parentPhone) { | 194 | public void setParentPhone(String parentPhone) { |
| 186 | this.parentPhone = parentPhone; | 195 | this.parentPhone = parentPhone; |
| 187 | } | 196 | } |
| 188 | 197 | ||
| 189 | public String getParentIdentity() { | 198 | public String getParentIdentity() { |
| 190 | return parentIdentity; | 199 | return parentIdentity; |
| 191 | } | 200 | } |
| 192 | 201 | ||
| 193 | public void setParentIdentity(String parentIdentity) { | 202 | public void setParentIdentity(String parentIdentity) { |
| 194 | this.parentIdentity = parentIdentity; | 203 | this.parentIdentity = parentIdentity; |
| 195 | } | 204 | } |
| 196 | 205 | ||
| 197 | public String getTeacherName() { | 206 | public String getTeacherName() { |
| 198 | return teacherName; | 207 | return teacherName; |
| 199 | } | 208 | } |
| 200 | 209 | ||
| 201 | public void setTeacherName(String teacherName) { | 210 | public void setTeacherName(String teacherName) { |
| 202 | this.teacherName = teacherName; | 211 | this.teacherName = teacherName; |
| 203 | } | 212 | } |
| 204 | 213 | ||
| 205 | public int getTeacherId() { | 214 | public int getTeacherId() { |
| 206 | return teacherId; | 215 | return teacherId; |
| 207 | } | 216 | } |
| 208 | 217 | ||
| 209 | public void setTeacherId(int teacherId) { | 218 | public void setTeacherId(int teacherId) { |
| 210 | this.teacherId = teacherId; | 219 | this.teacherId = teacherId; |
| 211 | } | 220 | } |
| 212 | } | 221 | } |
| 213 | 222 |
app/src/main/res/layout/activity_add_stu.xml
| 1 | <?xml version="1.0" encoding="utf-8"?> | 1 | <?xml version="1.0" encoding="utf-8"?> |
| 2 | <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | 2 | <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" |
| 3 | xmlns:app="http://schemas.android.com/apk/res-auto" | 3 | xmlns:app="http://schemas.android.com/apk/res-auto" |
| 4 | android:layout_width="match_parent" | 4 | android:layout_width="match_parent" |
| 5 | android:layout_height="match_parent" | 5 | android:layout_height="match_parent" |
| 6 | android:background="#F4F6F8"> | 6 | android:background="#F4F6F8"> |
| 7 | 7 | ||
| 8 | <View | 8 | <View |
| 9 | android:id="@+id/view_1" | 9 | android:id="@+id/view_1" |
| 10 | android:layout_width="match_parent" | 10 | android:layout_width="match_parent" |
| 11 | android:layout_height="44dp" | 11 | android:layout_height="44dp" |
| 12 | android:background="@android:color/white" | 12 | android:background="@android:color/white" |
| 13 | app:layout_constraintTop_toTopOf="parent" /> | 13 | app:layout_constraintTop_toTopOf="parent" /> |
| 14 | 14 | ||
| 15 | <TextView | 15 | <TextView |
| 16 | android:layout_width="wrap_content" | 16 | android:layout_width="wrap_content" |
| 17 | android:layout_height="wrap_content" | 17 | android:layout_height="wrap_content" |
| 18 | android:text="添加学生" | 18 | android:text="添加学生" |
| 19 | android:textColor="#333333" | 19 | android:textColor="#333333" |
| 20 | android:textSize="18dp" | 20 | android:textSize="18dp" |
| 21 | app:layout_constraintBottom_toBottomOf="@id/view_1" | 21 | app:layout_constraintBottom_toBottomOf="@id/view_1" |
| 22 | app:layout_constraintLeft_toLeftOf="@id/view_1" | 22 | app:layout_constraintLeft_toLeftOf="@id/view_1" |
| 23 | app:layout_constraintRight_toRightOf="@id/view_1" | 23 | app:layout_constraintRight_toRightOf="@id/view_1" |
| 24 | app:layout_constraintTop_toTopOf="@id/view_1" /> | 24 | app:layout_constraintTop_toTopOf="@id/view_1" /> |
| 25 | 25 | ||
| 26 | <TextView | 26 | <TextView |
| 27 | android:id="@+id/tv_cancel" | 27 | android:id="@+id/tv_cancel" |
| 28 | android:layout_width="wrap_content" | 28 | android:layout_width="wrap_content" |
| 29 | android:layout_height="wrap_content" | 29 | android:layout_height="wrap_content" |
| 30 | android:layout_marginLeft="15dp" | 30 | android:layout_marginLeft="15dp" |
| 31 | android:text="取消" | 31 | android:text="取消" |
| 32 | android:textColor="#666666" | 32 | android:textColor="#666666" |
| 33 | android:textSize="16dp" | 33 | android:textSize="16dp" |
| 34 | app:layout_constraintBottom_toBottomOf="@id/view_1" | 34 | app:layout_constraintBottom_toBottomOf="@id/view_1" |
| 35 | app:layout_constraintLeft_toLeftOf="@id/view_1" | 35 | app:layout_constraintLeft_toLeftOf="@id/view_1" |
| 36 | app:layout_constraintTop_toTopOf="@id/view_1" /> | 36 | app:layout_constraintTop_toTopOf="@id/view_1" /> |
| 37 | 37 | ||
| 38 | <RelativeLayout | 38 | <RelativeLayout |
| 39 | android:id="@+id/rl_avatar" | 39 | android:id="@+id/rl_avatar" |
| 40 | android:layout_width="75dp" | 40 | android:layout_width="75dp" |
| 41 | android:layout_height="75dp" | 41 | android:layout_height="75dp" |
| 42 | android:layout_marginTop="32dp" | 42 | android:layout_marginTop="32dp" |
| 43 | app:layout_constraintLeft_toLeftOf="parent" | 43 | app:layout_constraintLeft_toLeftOf="parent" |
| 44 | app:layout_constraintRight_toRightOf="parent" | 44 | app:layout_constraintRight_toRightOf="parent" |
| 45 | app:layout_constraintTop_toBottomOf="@id/view_1"> | 45 | app:layout_constraintTop_toBottomOf="@id/view_1"> |
| 46 | 46 | ||
| 47 | <ImageView | 47 | <ImageView |
| 48 | android:id="@+id/iv_avatar" | 48 | android:id="@+id/iv_avatar" |
| 49 | android:layout_width="match_parent" | 49 | android:layout_width="match_parent" |
| 50 | android:layout_height="match_parent" | 50 | android:layout_height="match_parent" |
| 51 | android:background="@mipmap/txz" /> | 51 | android:background="@mipmap/txz" /> |
| 52 | 52 | ||
| 53 | <ImageView | 53 | <ImageView |
| 54 | android:layout_width="20dp" | 54 | android:layout_width="20dp" |
| 55 | android:layout_height="20dp" | 55 | android:layout_height="20dp" |
| 56 | android:layout_alignParentRight="true" | 56 | android:layout_alignParentRight="true" |
| 57 | android:layout_alignParentBottom="true" | 57 | android:layout_alignParentBottom="true" |
| 58 | android:layout_marginBottom="5dp" | 58 | android:layout_marginBottom="5dp" |
| 59 | android:src="@mipmap/ic_edit" /> | 59 | android:src="@mipmap/ic_edit" /> |
| 60 | </RelativeLayout> | 60 | </RelativeLayout> |
| 61 | 61 | ||
| 62 | 62 | ||
| 63 | <View | 63 | <View |
| 64 | android:id="@+id/view_2" | 64 | android:id="@+id/view_2" |
| 65 | android:layout_width="match_parent" | 65 | android:layout_width="match_parent" |
| 66 | android:layout_height="50dp" | 66 | android:layout_height="50dp" |
| 67 | android:layout_marginLeft="15dp" | 67 | android:layout_marginLeft="15dp" |
| 68 | android:layout_marginTop="195dp" | 68 | android:layout_marginTop="195dp" |
| 69 | android:layout_marginRight="15dp" | 69 | android:layout_marginRight="15dp" |
| 70 | android:background="@drawable/bg_solid_white_10" | 70 | android:background="@drawable/bg_solid_white_10" |
| 71 | app:layout_constraintLeft_toLeftOf="parent" | 71 | app:layout_constraintLeft_toLeftOf="parent" |
| 72 | app:layout_constraintRight_toRightOf="parent" | 72 | app:layout_constraintRight_toRightOf="parent" |
| 73 | app:layout_constraintTop_toTopOf="parent" /> | 73 | app:layout_constraintTop_toTopOf="parent" /> |
| 74 | 74 | ||
| 75 | <TextView | 75 | <TextView |
| 76 | android:layout_width="wrap_content" | 76 | android:layout_width="wrap_content" |
| 77 | android:layout_height="wrap_content" | 77 | android:layout_height="wrap_content" |
| 78 | android:layout_marginLeft="15dp" | 78 | android:layout_marginLeft="15dp" |
| 79 | android:text="昵称" | 79 | android:text="昵称" |
| 80 | android:textColor="#666666" | 80 | android:textColor="#666666" |
| 81 | android:textSize="16dp" | 81 | android:textSize="16dp" |
| 82 | app:layout_constraintBottom_toBottomOf="@id/view_2" | 82 | app:layout_constraintBottom_toBottomOf="@id/view_2" |
| 83 | app:layout_constraintLeft_toLeftOf="@id/view_2" | 83 | app:layout_constraintLeft_toLeftOf="@id/view_2" |
| 84 | app:layout_constraintTop_toTopOf="@id/view_2" /> | 84 | app:layout_constraintTop_toTopOf="@id/view_2" /> |
| 85 | 85 | ||
| 86 | <ImageView | 86 | <ImageView |
| 87 | android:layout_width="5.5dp" | 87 | android:layout_width="5.5dp" |
| 88 | android:layout_height="9.5dp" | 88 | android:layout_height="9.5dp" |
| 89 | android:layout_marginRight="15dp" | 89 | android:layout_marginRight="15dp" |
| 90 | android:background="@mipmap/ycaj" | 90 | android:background="@mipmap/ycaj" |
| 91 | app:layout_constraintBottom_toBottomOf="@id/view_2" | 91 | app:layout_constraintBottom_toBottomOf="@id/view_2" |
| 92 | app:layout_constraintRight_toRightOf="@id/view_2" | 92 | app:layout_constraintRight_toRightOf="@id/view_2" |
| 93 | app:layout_constraintTop_toTopOf="@id/view_2" /> | 93 | app:layout_constraintTop_toTopOf="@id/view_2" /> |
| 94 | 94 | ||
| 95 | <TextView | 95 | <TextView |
| 96 | android:id="@+id/tv_name" | 96 | android:id="@+id/tv_name" |
| 97 | android:layout_width="wrap_content" | 97 | android:layout_width="wrap_content" |
| 98 | android:layout_height="wrap_content" | 98 | android:layout_height="wrap_content" |
| 99 | android:layout_marginRight="26dp" | 99 | android:layout_marginRight="26dp" |
| 100 | android:text="请输入" | 100 | android:text="请输入" |
| 101 | android:textColor="#999999" | 101 | android:textColor="#999999" |
| 102 | android:textSize="16dp" | 102 | android:textSize="16dp" |
| 103 | app:layout_constraintBottom_toBottomOf="@id/view_2" | 103 | app:layout_constraintBottom_toBottomOf="@id/view_2" |
| 104 | app:layout_constraintRight_toRightOf="@id/view_2" | 104 | app:layout_constraintRight_toRightOf="@id/view_2" |
| 105 | app:layout_constraintTop_toTopOf="@id/view_2" /> | 105 | app:layout_constraintTop_toTopOf="@id/view_2" /> |
| 106 | 106 | ||
| 107 | <View | 107 | <View |
| 108 | android:id="@+id/view_3" | 108 | android:id="@+id/view_3" |
| 109 | android:layout_width="match_parent" | 109 | android:layout_width="match_parent" |
| 110 | android:layout_height="50dp" | 110 | android:layout_height="50dp" |
| 111 | android:layout_marginLeft="15dp" | 111 | android:layout_marginLeft="15dp" |
| 112 | android:layout_marginTop="260dp" | 112 | android:layout_marginTop="260dp" |
| 113 | android:layout_marginRight="15dp" | 113 | android:layout_marginRight="15dp" |
| 114 | android:background="@drawable/bg_solid_white_10" | 114 | android:background="@drawable/bg_solid_white_10" |
| 115 | app:layout_constraintLeft_toLeftOf="parent" | 115 | app:layout_constraintLeft_toLeftOf="parent" |
| 116 | app:layout_constraintRight_toRightOf="parent" | 116 | app:layout_constraintRight_toRightOf="parent" |
| 117 | app:layout_constraintTop_toTopOf="parent" /> | 117 | app:layout_constraintTop_toTopOf="parent" /> |
| 118 | 118 | ||
| 119 | <TextView | 119 | <TextView |
| 120 | android:layout_width="wrap_content" | 120 | android:layout_width="wrap_content" |
| 121 | android:layout_height="wrap_content" | 121 | android:layout_height="wrap_content" |
| 122 | android:layout_marginLeft="15dp" | 122 | android:layout_marginLeft="15dp" |
| 123 | android:text="性别" | 123 | android:text="性别" |
| 124 | android:textColor="#666666" | 124 | android:textColor="#666666" |
| 125 | android:textSize="16dp" | 125 | android:textSize="16dp" |
| 126 | app:layout_constraintBottom_toBottomOf="@id/view_3" | 126 | app:layout_constraintBottom_toBottomOf="@id/view_3" |
| 127 | app:layout_constraintLeft_toLeftOf="@id/view_3" | 127 | app:layout_constraintLeft_toLeftOf="@id/view_3" |
| 128 | app:layout_constraintTop_toTopOf="@id/view_3" /> | 128 | app:layout_constraintTop_toTopOf="@id/view_3" /> |
| 129 | 129 | ||
| 130 | <ImageView | 130 | <ImageView |
| 131 | android:layout_width="5.5dp" | 131 | android:layout_width="5.5dp" |
| 132 | android:layout_height="9.5dp" | 132 | android:layout_height="9.5dp" |
| 133 | android:layout_marginRight="15dp" | 133 | android:layout_marginRight="15dp" |
| 134 | android:background="@mipmap/ycaj" | 134 | android:background="@mipmap/ycaj" |
| 135 | app:layout_constraintBottom_toBottomOf="@id/view_3" | 135 | app:layout_constraintBottom_toBottomOf="@id/view_3" |
| 136 | app:layout_constraintRight_toRightOf="@id/view_3" | 136 | app:layout_constraintRight_toRightOf="@id/view_3" |
| 137 | app:layout_constraintTop_toTopOf="@id/view_3" /> | 137 | app:layout_constraintTop_toTopOf="@id/view_3" /> |
| 138 | 138 | ||
| 139 | <TextView | 139 | <TextView |
| 140 | android:id="@+id/tv_sex" | 140 | android:id="@+id/tv_sex" |
| 141 | android:layout_width="wrap_content" | 141 | android:layout_width="wrap_content" |
| 142 | android:layout_height="wrap_content" | 142 | android:layout_height="wrap_content" |
| 143 | android:layout_marginRight="26dp" | 143 | android:layout_marginRight="26dp" |
| 144 | android:text="请选择" | 144 | android:text="请选择" |
| 145 | android:textColor="#999999" | 145 | android:textColor="#999999" |
| 146 | android:textSize="16dp" | 146 | android:textSize="16dp" |
| 147 | app:layout_constraintBottom_toBottomOf="@id/view_3" | 147 | app:layout_constraintBottom_toBottomOf="@id/view_3" |
| 148 | app:layout_constraintRight_toRightOf="@id/view_3" | 148 | app:layout_constraintRight_toRightOf="@id/view_3" |
| 149 | app:layout_constraintTop_toTopOf="@id/view_3" /> | 149 | app:layout_constraintTop_toTopOf="@id/view_3" /> |
| 150 | 150 | ||
| 151 | <View | 151 | <View |
| 152 | android:id="@+id/view_4" | 152 | android:id="@+id/view_4" |
| 153 | android:layout_width="match_parent" | 153 | android:layout_width="match_parent" |
| 154 | android:layout_height="50dp" | 154 | android:layout_height="50dp" |
| 155 | android:layout_marginLeft="15dp" | 155 | android:layout_marginLeft="15dp" |
| 156 | android:layout_marginTop="325dp" | 156 | android:layout_marginTop="325dp" |
| 157 | android:layout_marginRight="15dp" | 157 | android:layout_marginRight="15dp" |
| 158 | android:background="@drawable/bg_solid_white_10" | 158 | android:background="@drawable/bg_solid_white_10" |
| 159 | app:layout_constraintLeft_toLeftOf="parent" | 159 | app:layout_constraintLeft_toLeftOf="parent" |
| 160 | app:layout_constraintRight_toRightOf="parent" | 160 | app:layout_constraintRight_toRightOf="parent" |
| 161 | app:layout_constraintTop_toTopOf="parent" | 161 | app:layout_constraintTop_toTopOf="parent" /> |
| 162 | |||
| 163 | /> | ||
| 164 | 162 | ||
| 165 | <TextView | 163 | <TextView |
| 166 | android:layout_width="wrap_content" | 164 | android:layout_width="wrap_content" |
| 167 | android:layout_height="wrap_content" | 165 | android:layout_height="wrap_content" |
| 168 | android:layout_marginLeft="15dp" | 166 | android:layout_marginLeft="15dp" |
| 169 | android:text="年级" | 167 | android:text="年级" |
| 170 | android:textColor="#666666" | 168 | android:textColor="#666666" |
| 171 | android:textSize="16dp" | 169 | android:textSize="16dp" |
| 172 | app:layout_constraintBottom_toBottomOf="@id/view_4" | 170 | app:layout_constraintBottom_toBottomOf="@id/view_4" |
| 173 | app:layout_constraintLeft_toLeftOf="@id/view_4" | 171 | app:layout_constraintLeft_toLeftOf="@id/view_4" |
| 174 | app:layout_constraintTop_toTopOf="@id/view_4" /> | 172 | app:layout_constraintTop_toTopOf="@id/view_4" /> |
| 175 | 173 | ||
| 176 | <ImageView | 174 | <ImageView |
| 177 | android:layout_width="5.5dp" | 175 | android:layout_width="5.5dp" |
| 178 | android:layout_height="9.5dp" | 176 | android:layout_height="9.5dp" |
| 179 | android:layout_marginRight="15dp" | 177 | android:layout_marginRight="15dp" |
| 180 | android:background="@mipmap/ycaj" | 178 | android:background="@mipmap/ycaj" |
| 181 | app:layout_constraintBottom_toBottomOf="@id/view_4" | 179 | app:layout_constraintBottom_toBottomOf="@id/view_4" |
| 182 | app:layout_constraintRight_toRightOf="@id/view_4" | 180 | app:layout_constraintRight_toRightOf="@id/view_4" |
| 183 | app:layout_constraintTop_toTopOf="@id/view_4" /> | 181 | app:layout_constraintTop_toTopOf="@id/view_4" /> |
| 184 | 182 | ||
| 185 | <TextView | 183 | <TextView |
| 186 | android:id="@+id/tv_nian" | 184 | android:id="@+id/tv_nian" |
| 187 | android:layout_width="wrap_content" | 185 | android:layout_width="wrap_content" |
| 188 | android:layout_height="wrap_content" | 186 | android:layout_height="wrap_content" |
| 189 | android:layout_marginRight="26dp" | 187 | android:layout_marginRight="26dp" |
| 190 | android:text="请选择" | 188 | android:text="请选择" |
| 191 | android:textColor="#999999" | 189 | android:textColor="#999999" |
| 192 | android:textSize="16dp" | 190 | android:textSize="16dp" |
| 193 | app:layout_constraintBottom_toBottomOf="@id/view_4" | 191 | app:layout_constraintBottom_toBottomOf="@id/view_4" |
| 194 | app:layout_constraintRight_toRightOf="@id/view_4" | 192 | app:layout_constraintRight_toRightOf="@id/view_4" |
| 195 | app:layout_constraintTop_toTopOf="@id/view_4" /> | 193 | app:layout_constraintTop_toTopOf="@id/view_4" /> |
| 196 | 194 | ||
| 197 | <View | 195 | <View |
| 198 | android:id="@+id/view_5" | 196 | android:id="@+id/view_5" |
| 199 | android:layout_width="match_parent" | 197 | android:layout_width="match_parent" |
| 200 | android:layout_height="50dp" | 198 | android:layout_height="50dp" |
| 201 | android:layout_marginLeft="15dp" | 199 | android:layout_marginLeft="15dp" |
| 202 | android:layout_marginTop="390dp" | 200 | android:layout_marginTop="390dp" |
| 203 | android:layout_marginRight="15dp" | 201 | android:layout_marginRight="15dp" |
| 204 | android:background="@drawable/bg_solid_white_10" | 202 | android:background="@drawable/bg_solid_white_10" |
| 205 | app:layout_constraintLeft_toLeftOf="parent" | 203 | app:layout_constraintLeft_toLeftOf="parent" |
| 206 | app:layout_constraintRight_toRightOf="parent" | 204 | app:layout_constraintRight_toRightOf="parent" |
| 207 | app:layout_constraintTop_toTopOf="parent" | 205 | app:layout_constraintTop_toTopOf="parent" /> |
| 208 | 206 | ||
| 209 | /> | 207 | <LinearLayout |
| 208 | android:id="@+id/view_6" | ||
| 209 | android:layout_width="match_parent" | ||
| 210 | android:layout_height="wrap_content" | ||
| 211 | android:layout_marginLeft="15dp" | ||
| 212 | android:layout_marginTop="460dp" | ||
| 213 | android:layout_marginRight="15dp" | ||
| 214 | android:background="@drawable/bg_solid_white_10" | ||
| 215 | android:orientation="vertical" | ||
| 216 | app:layout_constraintLeft_toLeftOf="parent" | ||
| 217 | app:layout_constraintRight_toRightOf="parent" | ||
| 218 | app:layout_constraintTop_toTopOf="parent"> | ||
| 210 | 219 | ||
| 211 | <TextView | 220 | <RelativeLayout |
| 221 | android:layout_width="match_parent" | ||
| 222 | android:layout_height="50dp"> | ||
| 223 | |||
| 224 | <ImageView | ||
| 225 | android:layout_width="15dp" | ||
| 226 | android:layout_height="15dp" | ||
| 227 | android:layout_centerVertical="true" | ||
| 228 | android:layout_marginRight="5dp" | ||
| 229 | android:layout_toLeftOf="@+id/tv_bind" | ||
| 230 | android:src="@mipmap/ic_bind_teacher" /> | ||
| 231 | |||
| 232 | <TextView | ||
| 233 | android:id="@+id/tv_bind" | ||
| 234 | android:layout_width="wrap_content" | ||
| 235 | android:layout_height="wrap_content" | ||
| 236 | android:layout_alignParentRight="true" | ||
| 237 | android:layout_centerVertical="true" | ||
| 238 | android:layout_marginRight="15dp" | ||
| 239 | android:text="去绑定" | ||
| 240 | android:textColor="#999999" | ||
| 241 | android:textSize="16dp" /> | ||
| 242 | |||
| 243 | <TextView | ||
| 244 | android:layout_width="wrap_content" | ||
| 245 | android:layout_height="wrap_content" | ||
| 246 | android:layout_centerVertical="true" | ||
| 247 | android:layout_marginLeft="15dp" | ||
| 248 | android:text="我的老师" | ||
| 249 | android:textColor="#666666" | ||
| 250 | android:textSize="16dp" /> | ||
| 251 | </RelativeLayout> | ||
| 252 | |||
| 253 | <RelativeLayout | ||
| 254 | android:id="@+id/rl_teacher" | ||
| 255 | android:layout_width="match_parent" | ||
| 256 | android:layout_height="35dp" | ||
| 257 | android:layout_marginBottom="15dp" | ||
| 258 | android:visibility="gone"> | ||
| 212 | 259 | ||
| 260 | <ImageView | ||
| 261 | android:id="@+id/iv_teacher" | ||
| 262 | android:layout_width="35dp" | ||
| 263 | android:layout_height="35dp" | ||
| 264 | android:layout_marginLeft="15dp" | ||
| 265 | android:src="@mipmap/ic_teacher_male" /> | ||
| 266 | |||
| 267 | <TextView | ||
| 268 | android:id="@+id/tv_teacher" | ||
| 269 | android:layout_width="wrap_content" | ||
| 270 | android:layout_height="wrap_content" | ||
| 271 | android:layout_alignParentRight="true" | ||
| 272 | android:layout_centerVertical="true" | ||
| 273 | android:layout_marginRight="15dp" | ||
| 274 | android:textColor="#999999" | ||
| 275 | android:textSize="16dp" /> | ||
| 276 | </RelativeLayout> | ||
| 277 | </LinearLayout> | ||
| 278 | |||
| 279 | <TextView | ||
| 213 | android:layout_width="wrap_content" | 280 | android:layout_width="wrap_content" |
| 214 | android:layout_height="wrap_content" | 281 | android:layout_height="wrap_content" |
| 215 | android:layout_marginLeft="15dp" | 282 | android:layout_marginLeft="15dp" |
| 216 | android:text="家长身份" | 283 | android:text="家长身份" |
| 217 | android:textColor="#666666" | 284 | android:textColor="#666666" |
| 218 | android:textSize="16dp" | 285 | android:textSize="16dp" |
| 219 | app:layout_constraintBottom_toBottomOf="@id/view_5" | 286 | app:layout_constraintBottom_toBottomOf="@id/view_5" |
| 220 | app:layout_constraintLeft_toLeftOf="@id/view_5" | 287 | app:layout_constraintLeft_toLeftOf="@id/view_5" |
| 221 | app:layout_constraintTop_toTopOf="@id/view_5" /> | 288 | app:layout_constraintTop_toTopOf="@id/view_5" /> |
| 222 | 289 | ||
| 290 | |||
| 223 | <TextView | 291 | <TextView |
| 224 | android:id="@+id/tv_shen" | 292 | android:id="@+id/tv_shen" |
| 225 | android:layout_width="wrap_content" | 293 | android:layout_width="wrap_content" |
| 226 | android:layout_height="wrap_content" | 294 | android:layout_height="wrap_content" |
| 227 | android:layout_marginRight="26dp" | 295 | android:layout_marginRight="26dp" |
| 228 | android:text="请选择" | 296 | android:text="请选择" |
| 229 | android:textColor="#999999" | 297 | android:textColor="#999999" |
| 230 | android:textSize="16dp" | 298 | android:textSize="16dp" |
| 231 | app:layout_constraintBottom_toBottomOf="@id/view_5" | 299 | app:layout_constraintBottom_toBottomOf="@id/view_5" |
| 232 | app:layout_constraintRight_toRightOf="@id/view_5" | 300 | app:layout_constraintRight_toRightOf="@id/view_5" |
| 233 | app:layout_constraintTop_toTopOf="@id/view_5" /> | 301 | app:layout_constraintTop_toTopOf="@id/view_5" /> |
| 234 | 302 | ||
| 235 | <ImageView | 303 | <ImageView |
| 236 | android:layout_width="5.5dp" | 304 | android:layout_width="5.5dp" |
| 237 | android:layout_height="9.5dp" | 305 | android:layout_height="9.5dp" |
| 238 | android:layout_marginRight="15dp" | 306 | android:layout_marginRight="15dp" |
| 239 | android:background="@mipmap/ycaj" | 307 | android:background="@mipmap/ycaj" |
| 240 | app:layout_constraintBottom_toBottomOf="@id/view_5" | 308 | app:layout_constraintBottom_toBottomOf="@id/view_5" |
| 241 | app:layout_constraintRight_toRightOf="@id/view_5" | 309 | app:layout_constraintRight_toRightOf="@id/view_5" |
| 242 | app:layout_constraintTop_toTopOf="@id/view_5" /> | 310 | app:layout_constraintTop_toTopOf="@id/view_5" /> |
| 243 | 311 | ||
| 244 | |||
| 245 | <Button | 312 | <Button |
| 246 | android:id="@+id/btn_next" | 313 | android:id="@+id/btn_next" |
| 247 | android:layout_width="180dp" | 314 | android:layout_width="180dp" |
| 248 | android:layout_height="40dp" | 315 | android:layout_height="40dp" |
| 249 | android:layout_marginTop="500dp" | 316 | android:layout_marginTop="700dp" |
| 250 | android:background="@drawable/bg_solid_btn_grad" | 317 | android:background="@drawable/bg_solid_btn_grad" |
| 251 | android:text="确认" | 318 | android:text="确认" |
| 252 | android:textColor="#999999" | 319 | android:textColor="#999999" |
| 253 | android:textSize="16dp" | 320 | android:textSize="16dp" |
| 254 | app:layout_constraintLeft_toLeftOf="parent" | 321 | app:layout_constraintLeft_toLeftOf="parent" |
| 255 | app:layout_constraintRight_toRightOf="parent" | 322 | app:layout_constraintRight_toRightOf="parent" |
| 256 | app:layout_constraintTop_toTopOf="parent" /> | 323 | app:layout_constraintTop_toTopOf="parent" /> |
app/src/main/res/layout/activity_add_teacher.xml
| File was created | 1 | <?xml version="1.0" encoding="utf-8"?> | |
| 2 | <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | xmlns:app="http://schemas.android.com/apk/res-auto" | ||
| 4 | android:layout_width="match_parent" | ||
| 5 | android:layout_height="match_parent" | ||
| 6 | android:background="#F4F6F8"> | ||
| 7 | |||
| 8 | <View | ||
| 9 | android:id="@+id/view_1" | ||
| 10 | android:layout_width="match_parent" | ||
| 11 | android:layout_height="44dp" | ||
| 12 | android:background="@android:color/white" | ||
| 13 | app:layout_constraintTop_toTopOf="parent" /> | ||
| 14 | |||
| 15 | <TextView | ||
| 16 | android:layout_width="wrap_content" | ||
| 17 | android:layout_height="wrap_content" | ||
| 18 | android:text="绑定老师" | ||
| 19 | android:textColor="#333333" | ||
| 20 | android:textSize="18dp" | ||
| 21 | app:layout_constraintBottom_toBottomOf="@id/view_1" | ||
| 22 | app:layout_constraintLeft_toLeftOf="@id/view_1" | ||
| 23 | app:layout_constraintRight_toRightOf="@id/view_1" | ||
| 24 | app:layout_constraintTop_toTopOf="@id/view_1" /> | ||
| 25 | |||
| 26 | <TextView | ||
| 27 | android:id="@+id/tv_cancel" | ||
| 28 | android:layout_width="wrap_content" | ||
| 29 | android:layout_height="wrap_content" | ||
| 30 | android:layout_marginLeft="15dp" | ||
| 31 | android:text="取消" | ||
| 32 | android:textColor="#666666" | ||
| 33 | android:textSize="16dp" | ||
| 34 | app:layout_constraintBottom_toBottomOf="@id/view_1" | ||
| 35 | app:layout_constraintLeft_toLeftOf="@id/view_1" | ||
| 36 | app:layout_constraintTop_toTopOf="@id/view_1" /> | ||
| 37 | |||
| 38 | <View | ||
| 39 | android:id="@+id/view_3" | ||
| 40 | android:layout_width="match_parent" | ||
| 41 | android:layout_height="50dp" | ||
| 42 | android:layout_marginLeft="15dp" | ||
| 43 | android:layout_marginTop="109dp" | ||
| 44 | android:layout_marginRight="15dp" | ||
| 45 | android:background="@drawable/bg_solid_white_10" | ||
| 46 | app:layout_constraintLeft_toLeftOf="parent" | ||
| 47 | app:layout_constraintRight_toRightOf="parent" | ||
| 48 | app:layout_constraintTop_toTopOf="parent" /> | ||
| 49 | |||
| 50 | <EditText | ||
| 51 | android:id="@+id/et_1" | ||
| 52 | android:layout_width="0dp" | ||
| 53 | android:layout_height="0dp" | ||
| 54 | android:layout_marginLeft="5dp" | ||
| 55 | android:layout_marginRight="5dp" | ||
| 56 | android:inputType="phone" | ||
| 57 | android:maxLength="11" | ||
| 58 | android:textColor="#333333" | ||
| 59 | android:textColorHint="#999999" | ||
| 60 | android:textSize="16dp" | ||
| 61 | app:layout_constraintBottom_toBottomOf="@+id/view_3" | ||
| 62 | app:layout_constraintLeft_toLeftOf="@+id/view_3" | ||
| 63 | app:layout_constraintRight_toRightOf="@+id/view_3" | ||
| 64 | app:layout_constraintTop_toTopOf="@+id/view_3" /> | ||
| 65 | |||
| 66 | <TextView | ||
| 67 | android:layout_width="wrap_content" | ||
| 68 | android:layout_height="wrap_content" | ||
| 69 | android:layout_marginLeft="15dp" | ||
| 70 | android:layout_marginBottom="15dp" | ||
| 71 | android:text="请输入手机号" | ||
| 72 | android:textColor="#666666" | ||
| 73 | app:layout_constraintBottom_toTopOf="@id/et_1" | ||
| 74 | app:layout_constraintLeft_toLeftOf="parent" /> | ||
| 75 | |||
| 76 | <RelativeLayout | ||
| 77 | android:id="@+id/rl_teacher" | ||
| 78 | android:layout_width="match_parent" | ||
| 79 | android:layout_height="60dp" | ||
| 80 | android:layout_marginLeft="15dp" | ||
| 81 | android:layout_marginTop="25dp" | ||
| 82 | android:layout_marginRight="15dp" | ||
| 83 | android:background="@drawable/bg_solid_white_10" | ||
| 84 | android:visibility="gone" | ||
| 85 | app:layout_constraintTop_toBottomOf="@+id/et_1"> | ||
| 86 | |||
| 87 | <ImageView | ||
| 88 | android:id="@+id/iv_teacher" | ||
| 89 | android:layout_width="35dp" | ||
| 90 | android:layout_height="35dp" | ||
| 91 | android:layout_marginLeft="15dp" | ||
| 92 | android:layout_centerVertical="true" | ||
| 93 | android:src="@mipmap/ic_teacher_male" /> | ||
| 94 | |||
| 95 | <TextView | ||
| 96 | android:id="@+id/tv_teacher" | ||
| 97 | android:layout_width="wrap_content" | ||
| 98 | android:layout_height="wrap_content" | ||
| 99 | android:layout_alignParentRight="true" | ||
| 100 | android:layout_centerVertical="true" | ||
| 101 | android:layout_marginRight="15dp" | ||
| 102 | android:textColor="#333333" | ||
| 103 | android:textSize="16dp" /> | ||
| 104 | </RelativeLayout> | ||
| 105 | |||
| 106 | <Button | ||
| 107 | android:id="@+id/btn_next" | ||
| 108 | android:layout_width="180dp" | ||
| 109 | android:layout_height="40dp" | ||
| 110 | android:layout_marginTop="560dp" | ||
| 111 | android:background="@drawable/bg_solid_btn_grad" | ||
| 112 | android:text="申请绑定" | ||
| 113 | android:textColor="#999999" | ||
| 114 | android:textSize="16dp" | ||
| 115 | app:layout_constraintLeft_toLeftOf="parent" | ||
| 116 | app:layout_constraintRight_toRightOf="parent" | ||
| 117 | app:layout_constraintTop_toTopOf="parent" /> | ||
| 118 | </androidx.constraintlayout.widget.ConstraintLayout> |
app/src/main/res/layout/activity_edit_stu.xml
| 1 | <?xml version="1.0" encoding="utf-8"?> | 1 | <?xml version="1.0" encoding="utf-8"?> |
| 2 | <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" | 2 | <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" |
| 3 | xmlns:app="http://schemas.android.com/apk/res-auto" | 3 | xmlns:app="http://schemas.android.com/apk/res-auto" |
| 4 | android:layout_width="match_parent" | 4 | android:layout_width="match_parent" |
| 5 | android:layout_height="match_parent" | 5 | android:layout_height="match_parent" |
| 6 | android:background="#F4F6F8"> | 6 | android:background="#F4F6F8"> |
| 7 | 7 | ||
| 8 | <View | 8 | <View |
| 9 | android:id="@+id/view_1" | 9 | android:id="@+id/view_1" |
| 10 | android:layout_width="match_parent" | 10 | android:layout_width="match_parent" |
| 11 | android:layout_height="44dp" | 11 | android:layout_height="44dp" |
| 12 | android:background="@android:color/white" | 12 | android:background="@android:color/white" |
| 13 | app:layout_constraintTop_toTopOf="parent" /> | 13 | app:layout_constraintTop_toTopOf="parent" /> |
| 14 | 14 | ||
| 15 | <TextView | 15 | <TextView |
| 16 | android:layout_width="wrap_content" | 16 | android:layout_width="wrap_content" |
| 17 | android:layout_height="wrap_content" | 17 | android:layout_height="wrap_content" |
| 18 | android:text="编辑学生" | 18 | android:text="编辑学生" |
| 19 | android:textColor="#333333" | 19 | android:textColor="#333333" |
| 20 | android:textSize="18dp" | 20 | android:textSize="18dp" |
| 21 | app:layout_constraintBottom_toBottomOf="@id/view_1" | 21 | app:layout_constraintBottom_toBottomOf="@id/view_1" |
| 22 | app:layout_constraintLeft_toLeftOf="@id/view_1" | 22 | app:layout_constraintLeft_toLeftOf="@id/view_1" |
| 23 | app:layout_constraintRight_toRightOf="@id/view_1" | 23 | app:layout_constraintRight_toRightOf="@id/view_1" |
| 24 | app:layout_constraintTop_toTopOf="@id/view_1" /> | 24 | app:layout_constraintTop_toTopOf="@id/view_1" /> |
| 25 | 25 | ||
| 26 | <TextView | 26 | <TextView |
| 27 | android:id="@+id/tv_cancel" | 27 | android:id="@+id/tv_cancel" |
| 28 | android:layout_width="wrap_content" | 28 | android:layout_width="wrap_content" |
| 29 | android:layout_height="wrap_content" | 29 | android:layout_height="wrap_content" |
| 30 | android:layout_marginLeft="15dp" | 30 | android:layout_marginLeft="15dp" |
| 31 | android:text="取消" | 31 | android:text="取消" |
| 32 | android:textColor="#666666" | 32 | android:textColor="#666666" |
| 33 | android:textSize="16dp" | 33 | android:textSize="16dp" |
| 34 | app:layout_constraintBottom_toBottomOf="@id/view_1" | 34 | app:layout_constraintBottom_toBottomOf="@id/view_1" |
| 35 | app:layout_constraintLeft_toLeftOf="@id/view_1" | 35 | app:layout_constraintLeft_toLeftOf="@id/view_1" |
| 36 | app:layout_constraintTop_toTopOf="@id/view_1" /> | 36 | app:layout_constraintTop_toTopOf="@id/view_1" /> |
| 37 | 37 | ||
| 38 | <RelativeLayout | 38 | <RelativeLayout |
| 39 | android:id="@+id/rl_avatar" | 39 | android:id="@+id/rl_avatar" |
| 40 | android:layout_width="75dp" | 40 | android:layout_width="75dp" |
| 41 | android:layout_height="75dp" | 41 | android:layout_height="75dp" |
| 42 | android:layout_marginTop="32dp" | 42 | android:layout_marginTop="32dp" |
| 43 | app:layout_constraintLeft_toLeftOf="parent" | 43 | app:layout_constraintLeft_toLeftOf="parent" |
| 44 | app:layout_constraintRight_toRightOf="parent" | 44 | app:layout_constraintRight_toRightOf="parent" |
| 45 | app:layout_constraintTop_toBottomOf="@id/view_1"> | 45 | app:layout_constraintTop_toBottomOf="@id/view_1"> |
| 46 | 46 | ||
| 47 | <ImageView | 47 | <ImageView |
| 48 | android:id="@+id/iv_avatar" | 48 | android:id="@+id/iv_avatar" |
| 49 | android:layout_width="match_parent" | 49 | android:layout_width="match_parent" |
| 50 | android:layout_height="match_parent" | 50 | android:layout_height="match_parent" |
| 51 | android:background="@mipmap/txz" /> | 51 | android:background="@mipmap/txz" /> |
| 52 | 52 | ||
| 53 | <ImageView | 53 | <ImageView |
| 54 | android:layout_width="20dp" | 54 | android:layout_width="20dp" |
| 55 | android:layout_height="20dp" | 55 | android:layout_height="20dp" |
| 56 | android:layout_alignParentRight="true" | 56 | android:layout_alignParentRight="true" |
| 57 | android:layout_alignParentBottom="true" | 57 | android:layout_alignParentBottom="true" |
| 58 | android:layout_marginBottom="5dp" | 58 | android:layout_marginBottom="5dp" |
| 59 | android:src="@mipmap/ic_edit" /> | 59 | android:src="@mipmap/ic_edit" /> |
| 60 | </RelativeLayout> | 60 | </RelativeLayout> |
| 61 | 61 | ||
| 62 | 62 | ||
| 63 | <View | 63 | <View |
| 64 | android:id="@+id/view_2" | 64 | android:id="@+id/view_2" |
| 65 | android:layout_width="match_parent" | 65 | android:layout_width="match_parent" |
| 66 | android:layout_marginLeft="15dp" | 66 | android:layout_marginLeft="15dp" |
| 67 | android:layout_marginRight="15dp" | 67 | android:layout_marginRight="15dp" |
| 68 | android:layout_height="50dp" | 68 | android:layout_height="50dp" |
| 69 | android:layout_marginTop="195dp" | 69 | android:layout_marginTop="195dp" |
| 70 | android:background="@drawable/bg_solid_white_10" | 70 | android:background="@drawable/bg_solid_white_10" |
| 71 | app:layout_constraintLeft_toLeftOf="parent" | 71 | app:layout_constraintLeft_toLeftOf="parent" |
| 72 | app:layout_constraintRight_toRightOf="parent" | 72 | app:layout_constraintRight_toRightOf="parent" |
| 73 | app:layout_constraintTop_toTopOf="parent" /> | 73 | app:layout_constraintTop_toTopOf="parent" /> |
| 74 | 74 | ||
| 75 | <TextView | 75 | <TextView |
| 76 | android:layout_width="wrap_content" | 76 | android:layout_width="wrap_content" |
| 77 | android:layout_height="wrap_content" | 77 | android:layout_height="wrap_content" |
| 78 | android:layout_marginLeft="15dp" | 78 | android:layout_marginLeft="15dp" |
| 79 | android:text="昵称" | 79 | android:text="昵称" |
| 80 | android:textColor="#666666" | 80 | android:textColor="#666666" |
| 81 | android:textSize="16dp" | 81 | android:textSize="16dp" |
| 82 | app:layout_constraintBottom_toBottomOf="@id/view_2" | 82 | app:layout_constraintBottom_toBottomOf="@id/view_2" |
| 83 | app:layout_constraintLeft_toLeftOf="@id/view_2" | 83 | app:layout_constraintLeft_toLeftOf="@id/view_2" |
| 84 | app:layout_constraintTop_toTopOf="@id/view_2" /> | 84 | app:layout_constraintTop_toTopOf="@id/view_2" /> |
| 85 | 85 | ||
| 86 | <ImageView | 86 | <ImageView |
| 87 | android:layout_width="5.5dp" | 87 | android:layout_width="5.5dp" |
| 88 | android:layout_height="9.5dp" | 88 | android:layout_height="9.5dp" |
| 89 | android:layout_marginRight="15dp" | 89 | android:layout_marginRight="15dp" |
| 90 | android:background="@mipmap/ycaj" | 90 | android:background="@mipmap/ycaj" |
| 91 | app:layout_constraintBottom_toBottomOf="@id/view_2" | 91 | app:layout_constraintBottom_toBottomOf="@id/view_2" |
| 92 | app:layout_constraintRight_toRightOf="@id/view_2" | 92 | app:layout_constraintRight_toRightOf="@id/view_2" |
| 93 | app:layout_constraintTop_toTopOf="@id/view_2" /> | 93 | app:layout_constraintTop_toTopOf="@id/view_2" /> |
| 94 | 94 | ||
| 95 | <TextView | 95 | <TextView |
| 96 | android:id="@+id/tv_name" | 96 | android:id="@+id/tv_name" |
| 97 | android:layout_width="wrap_content" | 97 | android:layout_width="wrap_content" |
| 98 | android:layout_height="wrap_content" | 98 | android:layout_height="wrap_content" |
| 99 | android:layout_marginRight="26dp" | 99 | android:layout_marginRight="26dp" |
| 100 | android:text="请输入" | 100 | android:text="请输入" |
| 101 | android:textColor="#333333" | 101 | android:textColor="#333333" |
| 102 | android:textSize="16dp" | 102 | android:textSize="16dp" |
| 103 | app:layout_constraintBottom_toBottomOf="@id/view_2" | 103 | app:layout_constraintBottom_toBottomOf="@id/view_2" |
| 104 | app:layout_constraintRight_toRightOf="@id/view_2" | 104 | app:layout_constraintRight_toRightOf="@id/view_2" |
| 105 | app:layout_constraintTop_toTopOf="@id/view_2" /> | 105 | app:layout_constraintTop_toTopOf="@id/view_2" /> |
| 106 | 106 | ||
| 107 | <View | 107 | <View |
| 108 | android:id="@+id/view_3" | 108 | android:id="@+id/view_3" |
| 109 | android:layout_width="match_parent" | 109 | android:layout_width="match_parent" |
| 110 | android:layout_marginLeft="15dp" | 110 | android:layout_marginLeft="15dp" |
| 111 | android:layout_marginRight="15dp" | 111 | android:layout_marginRight="15dp" |
| 112 | android:layout_height="50dp" | 112 | android:layout_height="50dp" |
| 113 | android:layout_marginTop="260dp" | 113 | android:layout_marginTop="260dp" |
| 114 | android:background="@drawable/bg_solid_white_10" | 114 | android:background="@drawable/bg_solid_white_10" |
| 115 | app:layout_constraintLeft_toLeftOf="parent" | 115 | app:layout_constraintLeft_toLeftOf="parent" |
| 116 | app:layout_constraintRight_toRightOf="parent" | 116 | app:layout_constraintRight_toRightOf="parent" |
| 117 | app:layout_constraintTop_toTopOf="parent" /> | 117 | app:layout_constraintTop_toTopOf="parent" /> |
| 118 | 118 | ||
| 119 | <TextView | 119 | <TextView |
| 120 | android:layout_width="wrap_content" | 120 | android:layout_width="wrap_content" |
| 121 | android:layout_height="wrap_content" | 121 | android:layout_height="wrap_content" |
| 122 | android:layout_marginLeft="15dp" | 122 | android:layout_marginLeft="15dp" |
| 123 | android:text="性别" | 123 | android:text="性别" |
| 124 | android:textColor="#666666" | 124 | android:textColor="#666666" |
| 125 | android:textSize="16dp" | 125 | android:textSize="16dp" |
| 126 | app:layout_constraintBottom_toBottomOf="@id/view_3" | 126 | app:layout_constraintBottom_toBottomOf="@id/view_3" |
| 127 | app:layout_constraintLeft_toLeftOf="@id/view_3" | 127 | app:layout_constraintLeft_toLeftOf="@id/view_3" |
| 128 | app:layout_constraintTop_toTopOf="@id/view_3" /> | 128 | app:layout_constraintTop_toTopOf="@id/view_3" /> |
| 129 | 129 | ||
| 130 | <ImageView | 130 | <ImageView |
| 131 | android:layout_width="5.5dp" | 131 | android:layout_width="5.5dp" |
| 132 | android:layout_height="9.5dp" | 132 | android:layout_height="9.5dp" |
| 133 | android:layout_marginRight="15dp" | 133 | android:layout_marginRight="15dp" |
| 134 | android:background="@mipmap/ycaj" | 134 | android:background="@mipmap/ycaj" |
| 135 | app:layout_constraintBottom_toBottomOf="@id/view_3" | 135 | app:layout_constraintBottom_toBottomOf="@id/view_3" |
| 136 | app:layout_constraintRight_toRightOf="@id/view_3" | 136 | app:layout_constraintRight_toRightOf="@id/view_3" |
| 137 | app:layout_constraintTop_toTopOf="@id/view_3" /> | 137 | app:layout_constraintTop_toTopOf="@id/view_3" /> |
| 138 | 138 | ||
| 139 | <TextView | 139 | <TextView |
| 140 | android:id="@+id/tv_sex" | 140 | android:id="@+id/tv_sex" |
| 141 | android:layout_width="wrap_content" | 141 | android:layout_width="wrap_content" |
| 142 | android:layout_height="wrap_content" | 142 | android:layout_height="wrap_content" |
| 143 | android:layout_marginRight="26dp" | 143 | android:layout_marginRight="26dp" |
| 144 | android:text="请选择" | 144 | android:text="请选择" |
| 145 | android:textColor="#333333" | 145 | android:textColor="#333333" |
| 146 | android:textSize="16dp" | 146 | android:textSize="16dp" |
| 147 | app:layout_constraintBottom_toBottomOf="@id/view_3" | 147 | app:layout_constraintBottom_toBottomOf="@id/view_3" |
| 148 | app:layout_constraintRight_toRightOf="@id/view_3" | 148 | app:layout_constraintRight_toRightOf="@id/view_3" |
| 149 | app:layout_constraintTop_toTopOf="@id/view_3" /> | 149 | app:layout_constraintTop_toTopOf="@id/view_3" /> |
| 150 | 150 | ||
| 151 | <View | 151 | <View |
| 152 | android:id="@+id/view_4" | 152 | android:id="@+id/view_4" |
| 153 | android:layout_width="match_parent" | 153 | android:layout_width="match_parent" |
| 154 | android:layout_marginLeft="15dp" | 154 | android:layout_marginLeft="15dp" |
| 155 | android:layout_marginRight="15dp" | 155 | android:layout_marginRight="15dp" |
| 156 | android:layout_height="50dp" | 156 | android:layout_height="50dp" |
| 157 | android:layout_marginTop="325dp" | 157 | android:layout_marginTop="325dp" |
| 158 | android:background="@drawable/bg_solid_white_10" | 158 | android:background="@drawable/bg_solid_white_10" |
| 159 | app:layout_constraintLeft_toLeftOf="parent" | 159 | app:layout_constraintLeft_toLeftOf="parent" |
| 160 | app:layout_constraintRight_toRightOf="parent" | 160 | app:layout_constraintRight_toRightOf="parent" |
| 161 | app:layout_constraintTop_toTopOf="parent" | 161 | app:layout_constraintTop_toTopOf="parent" |
| 162 | 162 | ||
| 163 | /> | 163 | /> |
| 164 | 164 | ||
| 165 | <TextView | 165 | <TextView |
| 166 | android:layout_width="wrap_content" | 166 | android:layout_width="wrap_content" |
| 167 | android:layout_height="wrap_content" | 167 | android:layout_height="wrap_content" |
| 168 | android:layout_marginLeft="15dp" | 168 | android:layout_marginLeft="15dp" |
| 169 | android:text="年级" | 169 | android:text="年级" |
| 170 | android:textColor="#666666" | 170 | android:textColor="#666666" |
| 171 | android:textSize="16dp" | 171 | android:textSize="16dp" |
| 172 | app:layout_constraintBottom_toBottomOf="@id/view_4" | 172 | app:layout_constraintBottom_toBottomOf="@id/view_4" |
| 173 | app:layout_constraintLeft_toLeftOf="@id/view_4" | 173 | app:layout_constraintLeft_toLeftOf="@id/view_4" |
| 174 | app:layout_constraintTop_toTopOf="@id/view_4" /> | 174 | app:layout_constraintTop_toTopOf="@id/view_4" /> |
| 175 | 175 | ||
| 176 | <ImageView | 176 | <ImageView |
| 177 | android:layout_width="5.5dp" | 177 | android:layout_width="5.5dp" |
| 178 | android:layout_height="9.5dp" | 178 | android:layout_height="9.5dp" |
| 179 | android:layout_marginRight="15dp" | 179 | android:layout_marginRight="15dp" |
| 180 | android:background="@mipmap/ycaj" | 180 | android:background="@mipmap/ycaj" |
| 181 | app:layout_constraintBottom_toBottomOf="@id/view_4" | 181 | app:layout_constraintBottom_toBottomOf="@id/view_4" |
| 182 | app:layout_constraintRight_toRightOf="@id/view_4" | 182 | app:layout_constraintRight_toRightOf="@id/view_4" |
| 183 | app:layout_constraintTop_toTopOf="@id/view_4" /> | 183 | app:layout_constraintTop_toTopOf="@id/view_4" /> |
| 184 | 184 | ||
| 185 | <TextView | 185 | <TextView |
| 186 | android:id="@+id/tv_nian" | 186 | android:id="@+id/tv_nian" |
| 187 | android:layout_width="wrap_content" | 187 | android:layout_width="wrap_content" |
| 188 | android:layout_height="wrap_content" | 188 | android:layout_height="wrap_content" |
| 189 | android:layout_marginRight="26dp" | 189 | android:layout_marginRight="26dp" |
| 190 | android:text="请选择" | 190 | android:text="请选择" |
| 191 | android:textColor="#333333" | 191 | android:textColor="#333333" |
| 192 | android:textSize="16dp" | 192 | android:textSize="16dp" |
| 193 | app:layout_constraintBottom_toBottomOf="@id/view_4" | 193 | app:layout_constraintBottom_toBottomOf="@id/view_4" |
| 194 | app:layout_constraintRight_toRightOf="@id/view_4" | 194 | app:layout_constraintRight_toRightOf="@id/view_4" |
| 195 | app:layout_constraintTop_toTopOf="@id/view_4" /> | 195 | app:layout_constraintTop_toTopOf="@id/view_4" /> |
| 196 | 196 | ||
| 197 | <View | 197 | <View |
| 198 | android:id="@+id/view_5" | 198 | android:id="@+id/view_5" |
| 199 | android:layout_width="match_parent" | 199 | android:layout_width="match_parent" |
| 200 | android:layout_marginLeft="15dp" | 200 | android:layout_marginLeft="15dp" |
| 201 | android:layout_marginRight="15dp" | 201 | android:layout_marginRight="15dp" |
| 202 | android:layout_height="50dp" | 202 | android:layout_height="50dp" |
| 203 | android:layout_marginTop="390dp" | 203 | android:layout_marginTop="390dp" |
| 204 | android:background="@drawable/bg_solid_white_10" | 204 | android:background="@drawable/bg_solid_white_10" |
| 205 | app:layout_constraintLeft_toLeftOf="parent" | 205 | app:layout_constraintLeft_toLeftOf="parent" |
| 206 | app:layout_constraintRight_toRightOf="parent" | 206 | app:layout_constraintRight_toRightOf="parent" |
| 207 | app:layout_constraintTop_toTopOf="parent" | 207 | app:layout_constraintTop_toTopOf="parent" |
| 208 | 208 | ||
| 209 | /> | 209 | /> |
| 210 | 210 | ||
| 211 | <TextView | 211 | <TextView |
| 212 | 212 | ||
| 213 | android:layout_width="wrap_content" | 213 | android:layout_width="wrap_content" |
| 214 | android:layout_height="wrap_content" | 214 | android:layout_height="wrap_content" |
| 215 | android:layout_marginLeft="15dp" | 215 | android:layout_marginLeft="15dp" |
| 216 | android:text="家长身份" | 216 | android:text="家长身份" |
| 217 | android:textColor="#666666" | 217 | android:textColor="#666666" |
| 218 | android:textSize="16dp" | 218 | android:textSize="16dp" |
| 219 | app:layout_constraintBottom_toBottomOf="@id/view_5" | 219 | app:layout_constraintBottom_toBottomOf="@id/view_5" |
| 220 | app:layout_constraintLeft_toLeftOf="@id/view_5" | 220 | app:layout_constraintLeft_toLeftOf="@id/view_5" |
| 221 | app:layout_constraintTop_toTopOf="@id/view_5" /> | 221 | app:layout_constraintTop_toTopOf="@id/view_5" /> |
| 222 | 222 | ||
| 223 | <TextView | 223 | <TextView |
| 224 | android:id="@+id/tv_shen" | 224 | android:id="@+id/tv_shen" |
| 225 | android:layout_width="wrap_content" | 225 | android:layout_width="wrap_content" |
| 226 | android:layout_height="wrap_content" | 226 | android:layout_height="wrap_content" |
| 227 | android:layout_marginRight="26dp" | 227 | android:layout_marginRight="26dp" |
| 228 | android:text="请选择" | 228 | android:text="请选择" |
| 229 | android:textColor="#333333" | 229 | android:textColor="#333333" |
| 230 | android:textSize="16dp" | 230 | android:textSize="16dp" |
| 231 | app:layout_constraintBottom_toBottomOf="@id/view_5" | 231 | app:layout_constraintBottom_toBottomOf="@id/view_5" |
| 232 | app:layout_constraintRight_toRightOf="@id/view_5" | 232 | app:layout_constraintRight_toRightOf="@id/view_5" |
| 233 | app:layout_constraintTop_toTopOf="@id/view_5" /> | 233 | app:layout_constraintTop_toTopOf="@id/view_5" /> |
| 234 | 234 | ||
| 235 | <ImageView | 235 | <ImageView |
| 236 | android:layout_width="5.5dp" | 236 | android:layout_width="5.5dp" |
| 237 | android:layout_height="9.5dp" | 237 | android:layout_height="9.5dp" |
| 238 | android:layout_marginRight="15dp" | 238 | android:layout_marginRight="15dp" |
| 239 | android:background="@mipmap/ycaj" | 239 | android:background="@mipmap/ycaj" |
| 240 | app:layout_constraintBottom_toBottomOf="@id/view_5" | 240 | app:layout_constraintBottom_toBottomOf="@id/view_5" |
| 241 | app:layout_constraintRight_toRightOf="@id/view_5" | 241 | app:layout_constraintRight_toRightOf="@id/view_5" |
| 242 | app:layout_constraintTop_toTopOf="@id/view_5" /> | 242 | app:layout_constraintTop_toTopOf="@id/view_5" /> |
| 243 | 243 | ||
| 244 | <View | 244 | <LinearLayout |
| 245 | android:id="@+id/view_6" | 245 | android:id="@+id/view_6" |
| 246 | android:layout_width="match_parent" | 246 | android:layout_width="match_parent" |
| 247 | android:layout_height="wrap_content" | ||
| 247 | android:layout_marginLeft="15dp" | 248 | android:layout_marginLeft="15dp" |
| 249 | android:layout_marginTop="460dp" | ||
| 248 | android:layout_marginRight="15dp" | 250 | android:layout_marginRight="15dp" |
| 249 | android:layout_height="50dp" | ||
| 250 | android:layout_marginTop="455dp" | ||
| 251 | android:background="@drawable/bg_solid_white_10" | 251 | android:background="@drawable/bg_solid_white_10" |
| 252 | android:orientation="vertical" | ||
| 252 | app:layout_constraintLeft_toLeftOf="parent" | 253 | app:layout_constraintLeft_toLeftOf="parent" |
| 253 | app:layout_constraintRight_toRightOf="parent" | 254 | app:layout_constraintRight_toRightOf="parent" |
| 254 | app:layout_constraintTop_toTopOf="parent" | 255 | app:layout_constraintTop_toTopOf="parent"> |
| 255 | |||
| 256 | /> | ||
| 257 | 256 | ||
| 258 | <TextView | 257 | <RelativeLayout |
| 259 | android:layout_width="wrap_content" | 258 | android:layout_width="match_parent" |
| 260 | android:layout_height="wrap_content" | 259 | android:layout_height="50dp"> |
| 261 | android:layout_marginLeft="15dp" | 260 | |
| 262 | android:text="绑定老师" | 261 | <ImageView |
| 263 | android:textColor="#666666" | 262 | android:layout_width="15dp" |
| 264 | android:textSize="16dp" | 263 | android:layout_height="15dp" |
| 265 | app:layout_constraintBottom_toBottomOf="@id/view_6" | 264 | android:layout_centerVertical="true" |
| 266 | app:layout_constraintLeft_toLeftOf="@id/view_6" | 265 | android:layout_marginRight="5dp" |
| 267 | app:layout_constraintTop_toTopOf="@id/view_6" /> | 266 | android:layout_toLeftOf="@+id/tv_bind" |
| 268 | 267 | android:src="@mipmap/ic_bind_teacher" /> | |
| 269 | <ImageView | 268 | |
| 270 | android:id="@+id/iv_teacher" | 269 | <TextView |
| 271 | android:layout_width="28dp" | 270 | android:id="@+id/tv_bind" |
| 272 | android:layout_height="28dp" | 271 | android:layout_width="wrap_content" |
| 273 | android:layout_marginRight="10dp" | 272 | android:layout_height="wrap_content" |
| 274 | app:layout_constraintBottom_toBottomOf="@id/view_6" | 273 | android:layout_alignParentRight="true" |
| 275 | app:layout_constraintRight_toLeftOf="@+id/tv_teacher" | 274 | android:layout_centerVertical="true" |
| 276 | app:layout_constraintTop_toTopOf="@id/view_6" /> | 275 | android:layout_marginRight="15dp" |
| 277 | 276 | android:text="去绑定" | |
| 278 | <TextView | 277 | android:textColor="#333333" |
| 279 | android:id="@+id/tv_teacher" | 278 | android:textSize="16dp" /> |
| 280 | android:layout_width="wrap_content" | 279 | |
| 281 | android:layout_height="wrap_content" | 280 | <TextView |
| 282 | android:layout_marginRight="15dp" | 281 | android:layout_width="wrap_content" |
| 283 | android:text="未绑定" | 282 | android:layout_height="wrap_content" |
| 284 | android:textColor="#333333" | 283 | android:layout_centerVertical="true" |
| 285 | android:textSize="16dp" | 284 | android:layout_marginLeft="15dp" |
| 286 | app:layout_constraintBottom_toBottomOf="@id/view_6" | 285 | android:text="我的老师" |
| 287 | app:layout_constraintRight_toRightOf="@id/view_6" | 286 | android:textColor="#666666" |
| 288 | app:layout_constraintTop_toTopOf="@id/view_6" /> | 287 | android:textSize="16dp" /> |
| 288 | </RelativeLayout> | ||
| 289 | |||
| 290 | <RelativeLayout | ||
| 291 | android:id="@+id/rl_teacher" | ||
| 292 | android:layout_width="match_parent" | ||
| 293 | android:layout_height="35dp" | ||
| 294 | android:layout_marginBottom="15dp" | ||
| 295 | android:visibility="gone"> | ||
| 296 | |||
| 297 | <ImageView | ||
| 298 | android:id="@+id/iv_teacher" | ||
| 299 | android:layout_width="35dp" | ||
| 300 | android:layout_height="35dp" | ||
| 301 | android:layout_marginLeft="15dp" | ||
| 302 | android:src="@mipmap/ic_teacher_male" /> | ||
| 303 | |||
| 304 | <TextView | ||
| 305 | android:id="@+id/tv_teacher" | ||
| 306 | android:layout_width="wrap_content" | ||
| 307 | android:layout_height="wrap_content" | ||
| 308 | android:layout_alignParentRight="true" | ||
| 309 | android:layout_centerVertical="true" | ||
| 310 | android:layout_marginRight="15dp" | ||
| 311 | android:textColor="#999999" | ||
| 312 | android:textSize="16dp" /> | ||
| 313 | </RelativeLayout> | ||
| 314 | </LinearLayout> | ||
| 289 | 315 | ||
| 290 | 316 | ||
| 291 | <Button | 317 | <Button |
| 292 | android:id="@+id/btn_next" | 318 | android:id="@+id/btn_next" |
| 293 | android:layout_width="180dp" | 319 | android:layout_width="180dp" |
| 294 | android:layout_height="40dp" | 320 | android:layout_height="40dp" |
| 295 | android:layout_marginTop="570dp" | 321 | android:layout_marginTop="570dp" |
| 296 | android:background="@drawable/bg_solid_btn_grad" | 322 | android:background="@drawable/bg_solid_btn_grad" |
| 297 | android:text="确认" | 323 | android:text="确认" |
| 298 | android:textColor="#999999" | 324 | android:textColor="#999999" |
| 299 | android:textSize="16dp" | 325 | android:textSize="16dp" |
| 300 | app:layout_constraintLeft_toLeftOf="parent" | 326 | app:layout_constraintLeft_toLeftOf="parent" |
| 301 | app:layout_constraintRight_toRightOf="parent" | 327 | app:layout_constraintRight_toRightOf="parent" |
app/src/main/res/mipmap-hdpi/ic_bind_teacher.png
3.07 KB
libs/common/src/main/java/com/prws/common/base/BaseActivity.java
| 1 | package com.prws.common.base; | 1 | package com.prws.common.base; |
| 2 | 2 | ||
| 3 | 3 | ||
| 4 | import android.app.Activity; | 4 | import android.app.Activity; |
| 5 | import android.app.AlertDialog; | ||
| 5 | import android.content.Context; | 6 | import android.content.Context; |
| 7 | import android.content.DialogInterface; | ||
| 6 | import android.content.Intent; | 8 | import android.content.Intent; |
| 7 | import android.os.Bundle; | 9 | import android.os.Bundle; |
| 8 | import android.os.IBinder; | 10 | import android.os.IBinder; |
| 11 | import android.text.TextUtils; | ||
| 9 | import android.util.Log; | 12 | import android.util.Log; |
| 10 | import android.view.MotionEvent; | 13 | import android.view.MotionEvent; |
| 11 | import android.view.View; | 14 | import android.view.View; |
| 12 | import android.view.Window; | 15 | import android.view.Window; |
| 13 | import android.view.WindowManager; | 16 | import android.view.WindowManager; |
| 14 | import android.view.inputmethod.InputMethodManager; | 17 | import android.view.inputmethod.InputMethodManager; |
| 15 | import android.widget.EditText; | 18 | import android.widget.EditText; |
| 19 | import android.widget.Toast; | ||
| 16 | 20 | ||
| 17 | import androidx.annotation.IdRes; | 21 | import androidx.annotation.IdRes; |
| 18 | import androidx.annotation.Nullable; | 22 | import androidx.annotation.Nullable; |
| 19 | import androidx.appcompat.app.AppCompatActivity; | 23 | import androidx.appcompat.app.AppCompatActivity; |
| 20 | import androidx.fragment.app.Fragment; | 24 | import androidx.fragment.app.Fragment; |
| 21 | import androidx.fragment.app.FragmentTransaction; | 25 | import androidx.fragment.app.FragmentTransaction; |
| 22 | import androidx.lifecycle.Lifecycle; | 26 | import androidx.lifecycle.Lifecycle; |
| 23 | 27 | ||
| 24 | import com.developer.wang.utils.PermissionUtils; | 28 | import com.developer.wang.utils.PermissionUtils; |
| 25 | import com.prws.common.R; | 29 | import com.prws.common.R; |
| 26 | import com.prws.common.net.INetEvent; | 30 | import com.prws.common.net.INetEvent; |
| 27 | import com.prws.common.utils.LogUtil; | 31 | import com.prws.common.utils.LogUtil; |
| 28 | import com.prws.common.utils.ScreenUtils; | 32 | import com.prws.common.utils.ScreenUtils; |
| 33 | import com.prws.common.utils.SharedPreferencesUtil; | ||
| 29 | import com.prws.common.view.LoadingView; | 34 | import com.prws.common.view.LoadingView; |
| 30 | 35 | ||
| 31 | import org.simple.eventbus.EventBus; | 36 | import org.simple.eventbus.EventBus; |
| 32 | 37 | ||
| 33 | import java.util.ArrayList; | 38 | import java.util.ArrayList; |
| 34 | import java.util.List; | 39 | import java.util.List; |
| 35 | 40 | ||
| 36 | import butterknife.ButterKnife; | 41 | import butterknife.ButterKnife; |
| 37 | import io.reactivex.disposables.CompositeDisposable; | 42 | import io.reactivex.disposables.CompositeDisposable; |
| 38 | import io.reactivex.disposables.Disposable; | 43 | import io.reactivex.disposables.Disposable; |
| 39 | 44 | ||
| 40 | 45 | ||
| 41 | /** | 46 | /** |
| 42 | * @author 描述:BaseActivity | 47 | * @author 描述:BaseActivity |
| 43 | */ | 48 | */ |
| 44 | public abstract class BaseActivity<P extends BasePresenter, CONTRACT> extends AppCompatActivity implements INetEvent, BaseView { | 49 | public abstract class BaseActivity<P extends BasePresenter, CONTRACT> extends AppCompatActivity implements INetEvent, BaseView { |
| 45 | 50 | ||
| 46 | 51 | ||
| 47 | private LoadingView loading; | 52 | private LoadingView loading; |
| 48 | 53 | ||
| 49 | public static INetEvent mINetEvent; | 54 | public static INetEvent mINetEvent; |
| 50 | protected final String TAG = getClass().getSimpleName(); | 55 | protected final String TAG = getClass().getSimpleName(); |
| 51 | private CompositeDisposable mCompositeDisposable; | 56 | private CompositeDisposable mCompositeDisposable; |
| 52 | protected P p; | 57 | protected P p; |
| 53 | 58 | ||
| 54 | /** | 59 | /** |
| 55 | * 获取布局文件 | 60 | * 获取布局文件 |
| 56 | * | 61 | * |
| 57 | * @return | 62 | * @return |
| 58 | */ | 63 | */ |
| 59 | protected abstract int layoutResId(); | 64 | protected abstract int layoutResId(); |
| 60 | 65 | ||
| 61 | /** | 66 | /** |
| 62 | * 让P层做相应需求 | 67 | * 让P层做相应需求 |
| 63 | */ | 68 | */ |
| 64 | public abstract CONTRACT getContract(); | 69 | public abstract CONTRACT getContract(); |
| 65 | 70 | ||
| 66 | /** | 71 | /** |
| 67 | * 子类获取具体契约 | 72 | * 子类获取具体契约 |
| 68 | */ | 73 | */ |
| 69 | public abstract P getPresenter(); | 74 | public abstract P getPresenter(); |
| 70 | 75 | ||
| 71 | @Override | 76 | @Override |
| 72 | protected void onCreate(@Nullable Bundle savedInstanceState) { | 77 | protected void onCreate(@Nullable Bundle savedInstanceState) { |
| 73 | super.onCreate(savedInstanceState); | 78 | super.onCreate(savedInstanceState); |
| 74 | setNetEvent(); | 79 | setNetEvent(); |
| 75 | initPresenter(); | 80 | initPresenter(); |
| 76 | // setWindow(); | 81 | // setWindow(); |
| 77 | setContentView(layoutResId()); | 82 | setContentView(layoutResId()); |
| 78 | ButterKnife.bind(this); | 83 | ButterKnife.bind(this); |
| 79 | registerEventBus(); | 84 | registerEventBus(); |
| 80 | initView(); | 85 | initView(); |
| 81 | initListener(); | 86 | initListener(); |
| 82 | initData(); | 87 | initData(); |
| 83 | 88 | ||
| 84 | } | 89 | } |
| 85 | 90 | ||
| 86 | 91 | ||
| 87 | @Override | 92 | @Override |
| 88 | protected void onResume() { | 93 | protected void onResume() { |
| 89 | super.onResume(); | 94 | super.onResume(); |
| 90 | } | 95 | } |
| 91 | 96 | ||
| 92 | protected abstract void initView(); | 97 | protected abstract void initView(); |
| 93 | 98 | ||
| 94 | protected abstract void initListener(); | 99 | protected abstract void initListener(); |
| 95 | 100 | ||
| 96 | protected abstract void initData(); | 101 | protected abstract void initData(); |
| 97 | 102 | ||
| 98 | 103 | ||
| 99 | private void setNetEvent() { | 104 | private void setNetEvent() { |
| 100 | mINetEvent = this; | 105 | mINetEvent = this; |
| 101 | } | 106 | } |
| 102 | 107 | ||
| 103 | private void initPresenter() { | 108 | private void initPresenter() { |
| 104 | p = getPresenter(); | 109 | p = getPresenter(); |
| 105 | if (p != null) | 110 | if (p != null) |
| 106 | p.bindView(this); | 111 | p.bindView(this); |
| 107 | } | 112 | } |
| 108 | 113 | ||
| 114 | public void showDialog(String title, String message, String confirm, String cancel, DialogInterface.OnClickListener cancelListener, DialogInterface.OnClickListener listener) { | ||
| 115 | AlertDialog.Builder builder = new AlertDialog.Builder(this, android.R.style.Theme_DeviceDefault_Light_Dialog_Alert); | ||
| 116 | builder.setTitle(title); | ||
| 117 | builder.setMessage(message); | ||
| 118 | builder.setCancelable(false); | ||
| 119 | if (!TextUtils.isEmpty(cancel)) { | ||
| 120 | builder.setNegativeButton(cancel, cancelListener); | ||
| 121 | } | ||
| 122 | builder.setPositiveButton(confirm, listener); | ||
| 123 | builder.show(); | ||
| 124 | } | ||
| 125 | |||
| 109 | private void setWindow() { | 126 | private void setWindow() { |
| 110 | Window window = getWindow(); | 127 | Window window = getWindow(); |
| 111 | WindowManager.LayoutParams params = window.getAttributes(); | 128 | WindowManager.LayoutParams params = window.getAttributes(); |
| 112 | params.systemUiVisibility = View.SYSTEM_UI_FLAG_FULLSCREEN | 129 | params.systemUiVisibility = View.SYSTEM_UI_FLAG_FULLSCREEN |
| 113 | ; | 130 | ; |
| 114 | window.setAttributes(params); | 131 | window.setAttributes(params); |
| 115 | } | 132 | } |
| 116 | 133 | ||
| 117 | 134 | ||
| 118 | |||
| 119 | |||
| 120 | private void addNavigationBar() { | 135 | private void addNavigationBar() { |
| 121 | //判断是否有浮窗权限 | 136 | //判断是否有浮窗权限 |
| 122 | if (PermissionUtils.requestWindowManager(this)) { | 137 | if (PermissionUtils.requestWindowManager(this)) { |
| 123 | //开启浮窗 | 138 | //开启浮窗 |
| 124 | // openFloatWindow(); | 139 | // openFloatWindow(); |
| 125 | } else { | 140 | } else { |
| 126 | showAlertDialogOfFloatWindow(); | 141 | showAlertDialogOfFloatWindow(); |
| 127 | } | 142 | } |
| 128 | } | 143 | } |
| 129 | 144 | ||
| 130 | // public void openFloatWindow() { | 145 | // public void openFloatWindow() { |
| 131 | // if (FloatWindow.get("navigation") == null) { | 146 | // if (FloatWindow.get("navigation") == null) { |
| 132 | // NavigationBarView navigationBarView = new NavigationBarView(this); | 147 | // NavigationBarView navigationBarView = new NavigationBarView(this); |
| 133 | // FloatWindow.with(CommonApplication.getAppContext()) | 148 | // FloatWindow.with(CommonApplication.getAppContext()) |
| 134 | // .setView(navigationBarView) | 149 | // .setView(navigationBarView) |
| 135 | // .setWidth(Screen.width, 1) | 150 | // .setWidth(Screen.width, 1) |
| 136 | // .setHeight(WindowManager.LayoutParams.WRAP_CONTENT) | 151 | // .setHeight(WindowManager.LayoutParams.WRAP_CONTENT) |
| 137 | // .setX(0) | 152 | // .setX(0) |
| 138 | // .setY(0) | 153 | // .setY(0) |
| 139 | // .setMoveType(MoveType.inactive) | 154 | // .setMoveType(MoveType.inactive) |
| 140 | // .setDesktopShow(false) | 155 | // .setDesktopShow(false) |
| 141 | // .setTag("navigation") | 156 | // .setTag("navigation") |
| 142 | // .build(); | 157 | // .build(); |
| 143 | // } | 158 | // } |
| 144 | // if (!FloatWindow.get("navigation").isShowing()) | 159 | // if (!FloatWindow.get("navigation").isShowing()) |
| 145 | // FloatWindow.get("navigation").show(); | 160 | // FloatWindow.get("navigation").show(); |
| 146 | // | 161 | // |
| 147 | // } | 162 | // } |
| 148 | 163 | ||
| 149 | 164 | ||
| 150 | |||
| 151 | public void showAlertDialogOfFloatWindow() { | 165 | public void showAlertDialogOfFloatWindow() { |
| 152 | //弹窗提示用户开启权限 | 166 | //弹窗提示用户开启权限 |
| 153 | // new AlertDialog(this).builder().setTitle(getString(R.string.need_permission)) | 167 | // new AlertDialog(this).builder().setTitle(getString(R.string.need_permission)) |
| 154 | // .setMsg(getString(R.string.need_permission_window)) | 168 | // .setMsg(getString(R.string.need_permission_window)) |
| 155 | // .setPositiveButton(getString(R.string.open), new View.OnClickListener() { | 169 | // .setPositiveButton(getString(R.string.open), new View.OnClickListener() { |
| 156 | // @Override | 170 | // @Override |
| 157 | // public void onClick(View v) { | 171 | // public void onClick(View v) { |
| 158 | // Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION); | 172 | // Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION); |
| 159 | // intent.setData(Uri.parse("package:" + getPackageName())); | 173 | // intent.setData(Uri.parse("package:" + getPackageName())); |
| 160 | // startActivity(intent); | 174 | // startActivity(intent); |
| 161 | // } | 175 | // } |
| 162 | // }).setNegativeButton(getString(R.string.cancel), new View.OnClickListener() { | 176 | // }).setNegativeButton(getString(R.string.cancel), new View.OnClickListener() { |
| 163 | // @Override | 177 | // @Override |
| 164 | // public void onClick(View v) { | 178 | // public void onClick(View v) { |
| 165 | // } | 179 | // } |
| 166 | // }).show(); | 180 | // }).show(); |
| 167 | LogUtil.toast("请开启浮窗权限"); | 181 | LogUtil.toast("请开启浮窗权限"); |
| 168 | } | 182 | } |
| 169 | 183 | ||
| 170 | 184 | ||
| 171 | public void showLoading(String title) { | 185 | public void showLoading(String title) { |
| 172 | synchronized (this) { | 186 | synchronized (this) { |
| 173 | if (loading != null || !isLiving(this)) return; | 187 | if (loading != null || !isLiving(this)) return; |
| 174 | runOnUiThread(() -> { | 188 | runOnUiThread(() -> { |
| 175 | loading = new LoadingView(this, R.style.CustomDialog, title); | 189 | loading = new LoadingView(this, R.style.CustomDialog, title); |
| 176 | loading.show(); | 190 | loading.show(); |
| 177 | ScreenUtils.hideBottomUIMenu(this); | 191 | ScreenUtils.hideBottomUIMenu(this); |
| 178 | ScreenUtils.hideDialogBottomUIMenu(loading); | 192 | ScreenUtils.hideDialogBottomUIMenu(loading); |
| 179 | }); | 193 | }); |
| 180 | } | 194 | } |
| 181 | } | 195 | } |
| 182 | 196 | ||
| 183 | 197 | ||
| 184 | public void setCanAble(boolean canAble) { | 198 | public void setCanAble(boolean canAble) { |
| 185 | if (loading != null) | 199 | if (loading != null) |
| 186 | loading.setCancelable(canAble); | 200 | loading.setCancelable(canAble); |
| 187 | 201 | ||
| 188 | } | 202 | } |
| 189 | 203 | ||
| 190 | public boolean isShowLoading() { | 204 | public boolean isShowLoading() { |
| 191 | if (loading == null) return false; | 205 | if (loading == null) return false; |
| 192 | return loading.isShowing(); | 206 | return loading.isShowing(); |
| 193 | } | 207 | } |
| 194 | 208 | ||
| 195 | public void dismissLoading() { | 209 | public void dismissLoading() { |
| 196 | runOnUiThread(() -> { | 210 | runOnUiThread(() -> { |
| 197 | if (loading == null || loading.isShowing() == false || !isLiving(this)) { | 211 | if (loading == null || loading.isShowing() == false || !isLiving(this)) { |
| 198 | Log.w(TAG, "loading == null" + | 212 | Log.w(TAG, "loading == null" + |
| 199 | " || loading.isShowing() == false >> return;"); | 213 | " || loading.isShowing() == false >> return;"); |
| 200 | return; | 214 | return; |
| 201 | } | 215 | } |
| 202 | loading.dismiss(); | 216 | loading.dismiss(); |
| 203 | loading = null; | 217 | loading = null; |
| 204 | 218 | ||
| 205 | }); | 219 | }); |
| 206 | } | 220 | } |
| 207 | 221 | ||
| 208 | 222 | ||
| 209 | private static boolean isLiving(Activity activity) { | 223 | private static boolean isLiving(Activity activity) { |
| 210 | 224 | ||
| 211 | if (activity == null) { | 225 | if (activity == null) { |
| 212 | Log.d("wisely", "activity == null"); | 226 | Log.d("wisely", "activity == null"); |
| 213 | return false; | 227 | return false; |
| 214 | } | 228 | } |
| 215 | 229 | ||
| 216 | if (activity.isFinishing()) { | 230 | if (activity.isFinishing()) { |
| 217 | Log.d("wisely", "activity is finishing"); | 231 | Log.d("wisely", "activity is finishing"); |
| 218 | return false; | 232 | return false; |
| 219 | } | 233 | } |
| 220 | 234 | ||
| 221 | return true; | 235 | return true; |
| 222 | } | 236 | } |
| 223 | 237 | ||
| 224 | 238 | ||
| 225 | /** | 239 | /** |
| 226 | * 是否需要弹窗提示更新 | 240 | * 是否需要弹窗提示更新 |
| 227 | */ | 241 | */ |
| 228 | protected void isNeedGetVersionUpdate() { | 242 | protected void isNeedGetVersionUpdate() { |
| 229 | // View view = findViewById(R.id.view_loading); | 243 | // View view = findViewById(R.id.view_loading); |
| 230 | //如果显示正在下载的页面,则不弹出更新弹窗 | 244 | //如果显示正在下载的页面,则不弹出更新弹窗 |
| 231 | // if (null == view || view.getVisibility() == View.VISIBLE) return; | 245 | // if (null == view || view.getVisibility() == View.VISIBLE) return; |
| 232 | // UpdateUtils.getVersion(this); | 246 | // UpdateUtils.getVersion(this); |
| 233 | } | 247 | } |
| 234 | 248 | ||
| 235 | 249 | ||
| 236 | /** | 250 | /** |
| 237 | * 全局检测网络广播的回调 处理网络变化 | 251 | * 全局检测网络广播的回调 处理网络变化 |
| 238 | * 注:在程序第一次启动的时候,没网并不会回调,需要自己在启动页面,或者主页自己再判断一次 | 252 | * 注:在程序第一次启动的时候,没网并不会回调,需要自己在启动页面,或者主页自己再判断一次 |
| 239 | * | 253 | * |
| 240 | * @param netWorkState 网络状态 -1:没网络 0:移动网络 1:WiFi网络 | 254 | * @param netWorkState 网络状态 -1:没网络 0:移动网络 1:WiFi网络 |
| 241 | */ | 255 | */ |
| 242 | public abstract void onNetChanged(int netWorkState); | 256 | public abstract void onNetChanged(int netWorkState); |
| 243 | 257 | ||
| 244 | @Override | 258 | @Override |
| 245 | public void onNetChange(int netWorkState) { | 259 | public void onNetChange(int netWorkState) { |
| 246 | onNetChanged(netWorkState); | 260 | onNetChanged(netWorkState); |
| 247 | } | 261 | } |
| 248 | 262 | ||
| 249 | @Override | 263 | @Override |
| 250 | protected void onDestroy() { | 264 | protected void onDestroy() { |
| 251 | super.onDestroy(); | 265 | super.onDestroy(); |
| 252 | unSubscribe(); | 266 | unSubscribe(); |
| 253 | cleanFragment(); | 267 | cleanFragment(); |
| 254 | unregisterEventBus(); | 268 | unregisterEventBus(); |
| 255 | if (p != null) { | 269 | if (p != null) { |
| 256 | p.onBindView(); | 270 | p.onBindView(); |
| 257 | p.cancelAllRequest(); | 271 | p.cancelAllRequest(); |
| 258 | } | 272 | } |
| 259 | } | 273 | } |
| 260 | 274 | ||
| 261 | @Override | 275 | @Override |
| 262 | protected void onPause() { | 276 | protected void onPause() { |
| 263 | super.onPause(); | 277 | super.onPause(); |
| 264 | 278 | ||
| 265 | } | 279 | } |
| 266 | 280 | ||
| 267 | private void registerEventBus(){ | 281 | private void registerEventBus() { |
| 268 | EventBus.getDefault().register(this); | 282 | EventBus.getDefault().register(this); |
| 269 | } | 283 | } |
| 270 | 284 | ||
| 271 | private void unregisterEventBus(){ | 285 | private void unregisterEventBus() { |
| 272 | EventBus.getDefault().unregister(this); | 286 | EventBus.getDefault().unregister(this); |
| 273 | } | 287 | } |
| 274 | 288 | ||
| 275 | public void showErrorToast() { | 289 | public void showErrorToast() { |
| 276 | // LogUtil.toast(MainApplication.getAppContext(), getString(R.string.service_error)); | 290 | // LogUtil.toast(MainApplication.getAppContext(), getString(R.string.service_error)); |
| 277 | } | 291 | } |
| 278 | 292 | ||
| 293 | public void showToast(String s) { | ||
| 294 | Toast.makeText(getApplicationContext(), s, Toast.LENGTH_SHORT).show(); | ||
| 295 | } | ||
| 296 | |||
| 279 | private void unSubscribe() { | 297 | private void unSubscribe() { |
| 280 | if (mCompositeDisposable != null) { | 298 | if (mCompositeDisposable != null) { |
| 281 | mCompositeDisposable.clear(); | 299 | mCompositeDisposable.clear(); |
| 282 | } | 300 | } |
| 283 | } | 301 | } |
| 284 | 302 | ||
| 285 | protected void addSubscribe(Disposable disposable) { | 303 | protected void addSubscribe(Disposable disposable) { |
| 286 | if (mCompositeDisposable == null) { | 304 | if (mCompositeDisposable == null) { |
| 287 | mCompositeDisposable = new CompositeDisposable(); | 305 | mCompositeDisposable = new CompositeDisposable(); |
| 288 | } | 306 | } |
| 289 | mCompositeDisposable.add(disposable); | 307 | mCompositeDisposable.add(disposable); |
| 290 | } | 308 | } |
| 291 | 309 | ||
| 292 | protected void startActivity(Class clazz) { | 310 | protected void startActivity(Class clazz) { |
| 293 | startActivity(new Intent(this, clazz)); | 311 | startActivity(new Intent(this, clazz)); |
| 294 | } | 312 | } |
| 295 | 313 | ||
| 296 | /******************** 处理fragment *******************************/ | 314 | /******************** 处理fragment *******************************/ |
| 297 | List<Fragment> fragmentList = new ArrayList<>(); | 315 | List<Fragment> fragmentList = new ArrayList<>(); |
| 298 | 316 | ||
| 299 | protected void showFragment(Fragment fragment, @IdRes int id) { | 317 | protected void showFragment(Fragment fragment, @IdRes int id) { |
| 300 | FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction(); | 318 | FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction(); |
| 301 | 319 | ||
| 302 | if (!fragmentList.contains(fragment)) { | 320 | if (!fragmentList.contains(fragment)) { |
| 303 | fragmentList.add(fragment); | 321 | fragmentList.add(fragment); |
| 304 | fragmentTransaction.add(id, fragment, fragment.getClass().getSimpleName()).setMaxLifecycle(fragment, Lifecycle.State.RESUMED); | 322 | fragmentTransaction.add(id, fragment, fragment.getClass().getSimpleName()).setMaxLifecycle(fragment, Lifecycle.State.RESUMED); |
| 305 | } | 323 | } |
| 306 | 324 | ||
| 307 | fragmentTransaction.show(fragment).setMaxLifecycle(fragment, Lifecycle.State.RESUMED); | 325 | fragmentTransaction.show(fragment).setMaxLifecycle(fragment, Lifecycle.State.RESUMED); |
| 308 | 326 | ||
| 309 | for (Fragment fragment1 : fragmentList) { | 327 | for (Fragment fragment1 : fragmentList) { |
| 310 | if (fragment1 != fragment) { | 328 | if (fragment1 != fragment) { |
| 311 | fragmentTransaction.hide(fragment1).setMaxLifecycle(fragment1, Lifecycle.State.STARTED); | 329 | fragmentTransaction.hide(fragment1).setMaxLifecycle(fragment1, Lifecycle.State.STARTED); |
| 312 | } | 330 | } |
| 313 | } | 331 | } |
| 314 | 332 | ||
| 315 | fragmentTransaction.commitAllowingStateLoss(); | 333 | fragmentTransaction.commitAllowingStateLoss(); |
| 316 | 334 | ||
| 317 | } | 335 | } |
| 318 | 336 | ||
| 319 | protected void cleanFragment() { | 337 | protected void cleanFragment() { |
| 320 | FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction(); | 338 | FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction(); |
| 321 | if (fragmentList.size() > 0) { | 339 | if (fragmentList.size() > 0) { |
| 322 | for (Fragment fragment : fragmentList) { | 340 | for (Fragment fragment : fragmentList) { |
| 323 | fragmentTransaction.remove(fragment); | 341 | fragmentTransaction.remove(fragment); |
| 324 | } | 342 | } |
| 325 | try { | 343 | try { |
| 326 | fragmentTransaction.commitNowAllowingStateLoss(); | 344 | fragmentTransaction.commitNowAllowingStateLoss(); |
| 327 | }catch (Exception e){e.printStackTrace();} | 345 | } catch (Exception e) { |
| 346 | e.printStackTrace(); | ||
| 347 | } | ||
| 328 | } | 348 | } |
| 329 | fragmentList.clear(); | 349 | fragmentList.clear(); |
| 330 | } | 350 | } |
| 331 | 351 | ||
| 332 | //************************* 用于隐藏键盘 ***************************************// | 352 | //************************* 用于隐藏键盘 ***************************************// |
| 333 | @Override | 353 | @Override |
| 334 | public boolean dispatchTouchEvent(MotionEvent ev) { | 354 | public boolean dispatchTouchEvent(MotionEvent ev) { |
| 335 | if (ev.getAction() == MotionEvent.ACTION_DOWN){ | 355 | if (ev.getAction() == MotionEvent.ACTION_DOWN) { |
| 336 | 356 | ||
| 337 | View v = getCurrentFocus(); | 357 | View v = getCurrentFocus(); |
| 338 | if (isShouldHideInput(v,ev)){ | 358 | if (isShouldHideInput(v, ev)) { |
| 339 | hideSoftInput(v.getWindowToken()); | 359 | hideSoftInput(v.getWindowToken()); |
| 340 | } | 360 | } |
| 341 | } | 361 | } |
| 342 | return super.dispatchTouchEvent(ev); | 362 | return super.dispatchTouchEvent(ev); |
| 343 | } | 363 | } |
| 344 | private boolean isShouldHideInput(View v,MotionEvent event){ | 364 | |
| 345 | if(v !=null&&(v instanceof EditText)){ | 365 | private boolean isShouldHideInput(View v, MotionEvent event) { |
| 346 | int[] l ={0,0}; | 366 | if (v != null && (v instanceof EditText)) { |
| 367 | int[] l = {0, 0}; | ||
| 347 | v.getLocationInWindow(l); | 368 | v.getLocationInWindow(l); |
| 348 | int left = l[0], top = l[1], bottom = top + v.getHeight(), right = left | 369 | int left = l[0], top = l[1], bottom = top + v.getHeight(), right = left |
| 349 | + v.getWidth(); | 370 | + v.getWidth(); |
| 350 | if(event.getX()> left &&event.getX()< right | 371 | if (event.getX() > left && event.getX() < right |
| 351 | &&event.getY()> top &&event.getY()< bottom){ | 372 | && event.getY() > top && event.getY() < bottom) { |
| 352 | // 点击EditText的事件,忽略它。 | 373 | // 点击EditText的事件,忽略它。 |
| 353 | return false; | 374 | return false; |
| 354 | }else{ | 375 | } else { |
| 355 | return true; | 376 | return true; |
| 356 | } | 377 | } |
| 357 | } | 378 | } |
| 358 | 379 | ||
| 359 | return false; | 380 | return false; |
| 360 | } | 381 | } |
| 361 | 382 | ||
| 362 | /** | 383 | /** |
| 363 | * 多种隐藏软件盘方法的其中一种 | 384 | * 多种隐藏软件盘方法的其中一种 |
| 364 | * | 385 | * |
| 365 | * @param token | 386 | * @param token |
| 366 | */ | 387 | */ |
| 367 | private void hideSoftInput(IBinder token){ | 388 | private void hideSoftInput(IBinder token) { |
| 368 | LogUtil.i(TAG,"隐藏键盘"); | 389 | LogUtil.i(TAG, "隐藏键盘"); |
| 369 | if(token !=null){ | 390 | if (token != null) { |
| 370 | InputMethodManager im =(InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE); | 391 | InputMethodManager im = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE); |
| 371 | im.hideSoftInputFromWindow(token, | 392 | im.hideSoftInputFromWindow(token, |
| 372 | InputMethodManager.HIDE_NOT_ALWAYS); | 393 | InputMethodManager.HIDE_NOT_ALWAYS); |
| 373 | } | 394 | } |
| 374 | } | 395 | } |
| 375 | 396 | ||
| 376 | //************************* 用于隐藏键盘 end***************************************// | 397 | //************************* 用于隐藏键盘 end***************************************// |
| 377 | 398 |
libs/common/src/main/java/com/prws/common/bean/Teacher.java
| File was created | 1 | package com.prws.common.bean; | |
| 2 | |||
| 3 | public class Teacher { | ||
| 4 | private Integer id; | ||
| 5 | private String userName; | ||
| 6 | private String account; | ||
| 7 | private String nickName; | ||
| 8 | private String phone; | ||
| 9 | private String mail; | ||
| 10 | private String identity; | ||
| 11 | private String photo; | ||
| 12 | private String qrCode; | ||
| 13 | private Integer sex; | ||
| 14 | |||
| 15 | public Integer getId() { | ||
| 16 | return id; | ||
| 17 | } | ||
| 18 | |||
| 19 | public void setId(Integer id) { | ||
| 20 | this.id = id; | ||
| 21 | } | ||
| 22 | |||
| 23 | public String getUserName() { | ||
| 24 | return userName; | ||
| 25 | } | ||
| 26 | |||
| 27 | public void setUserName(String userName) { | ||
| 28 | this.userName = userName; | ||
| 29 | } | ||
| 30 | |||
| 31 | public String getAccount() { | ||
| 32 | return account; | ||
| 33 | } | ||
| 34 | |||
| 35 | public void setAccount(String account) { | ||
| 36 | this.account = account; | ||
| 37 | } | ||
| 38 | |||
| 39 | public String getNickName() { | ||
| 40 | return nickName; | ||
| 41 | } | ||
| 42 | |||
| 43 | public void setNickName(String nickName) { | ||
| 44 | this.nickName = nickName; | ||
| 45 | } | ||
| 46 | |||
| 47 | public String getPhone() { | ||
| 48 | return phone; | ||
| 49 | } | ||
| 50 | |||
| 51 | public void setPhone(String phone) { | ||
| 52 | this.phone = phone; | ||
| 53 | } | ||
| 54 | |||
| 55 | public String getMail() { | ||
| 56 | return mail; | ||
| 57 | } | ||
| 58 | |||
| 59 | public void setMail(String mail) { | ||
| 60 | this.mail = mail; | ||
| 61 | } | ||
| 62 | |||
| 63 | public String getIdentity() { | ||
| 64 | return identity; | ||
| 65 | } | ||
| 66 | |||
| 67 | public void setIdentity(String identity) { | ||
| 68 | this.identity = identity; | ||
| 69 | } | ||
| 70 | |||
| 71 | public String getPhoto() { | ||
| 72 | return photo; | ||
| 73 | } | ||
| 74 | |||
| 75 | public void setPhoto(String photo) { | ||
| 76 | this.photo = photo; | ||
| 77 | } | ||
| 78 | |||
| 79 | public String getQrCode() { | ||
| 80 | return qrCode; | ||
| 81 | } | ||
| 82 | |||
| 83 | public void setQrCode(String qrCode) { | ||
| 84 | this.qrCode = qrCode; | ||
| 85 | } | ||
| 86 | |||
| 87 | public Integer getSex() { | ||
| 88 | return sex; | ||
| 89 | } | ||
| 90 | |||
| 91 | public void setSex(Integer sex) { | ||
| 92 | this.sex = sex; | ||
| 93 | } | ||
| 94 | } | ||
| 95 |
libs/common/src/main/java/com/prws/common/net/NetWorks.java
| 1 | package com.prws.common.net; | 1 | package com.prws.common.net; |
| 2 | 2 | ||
| 3 | 3 | ||
| 4 | import com.google.gson.Gson; | 4 | import com.google.gson.Gson; |
| 5 | import com.prws.common.BuildConfig; | 5 | import com.prws.common.BuildConfig; |
| 6 | import com.prws.common.bean.BaseEntity; | 6 | import com.prws.common.bean.BaseEntity; |
| 7 | import com.prws.common.bean.GradeAndSubject; | 7 | import com.prws.common.bean.GradeAndSubject; |
| 8 | import com.prws.common.bean.ResponseResult; | 8 | import com.prws.common.bean.ResponseResult; |
| 9 | import com.prws.common.bean.ScheduleBean; | 9 | import com.prws.common.bean.ScheduleBean; |
| 10 | import com.prws.common.bean.Teacher; | ||
| 10 | import com.prws.common.utils.SharedPreferencesUtil; | 11 | import com.prws.common.utils.SharedPreferencesUtil; |
| 11 | 12 | ||
| 12 | import java.io.File; | 13 | import java.io.File; |
| 13 | import java.util.HashMap; | 14 | import java.util.HashMap; |
| 14 | import java.util.List; | 15 | import java.util.List; |
| 15 | import java.util.Map; | 16 | import java.util.Map; |
| 16 | 17 | ||
| 17 | import io.reactivex.Observable; | 18 | import io.reactivex.Observable; |
| 18 | import io.reactivex.Observer; | 19 | import io.reactivex.Observer; |
| 19 | import io.reactivex.android.schedulers.AndroidSchedulers; | 20 | import io.reactivex.android.schedulers.AndroidSchedulers; |
| 20 | import io.reactivex.schedulers.Schedulers; | 21 | import io.reactivex.schedulers.Schedulers; |
| 21 | import okhttp3.MediaType; | 22 | import okhttp3.MediaType; |
| 22 | import okhttp3.MultipartBody; | 23 | import okhttp3.MultipartBody; |
| 23 | import okhttp3.RequestBody; | 24 | import okhttp3.RequestBody; |
| 24 | import okhttp3.ResponseBody; | 25 | import okhttp3.ResponseBody; |
| 25 | import retrofit2.Call; | 26 | import retrofit2.Call; |
| 26 | import retrofit2.Callback; | 27 | import retrofit2.Callback; |
| 27 | import retrofit2.http.Body; | 28 | import retrofit2.http.Body; |
| 28 | import retrofit2.http.DELETE; | 29 | import retrofit2.http.DELETE; |
| 29 | import retrofit2.http.FieldMap; | 30 | import retrofit2.http.FieldMap; |
| 30 | import retrofit2.http.FormUrlEncoded; | 31 | import retrofit2.http.FormUrlEncoded; |
| 31 | import retrofit2.http.GET; | 32 | import retrofit2.http.GET; |
| 32 | import retrofit2.http.Header; | 33 | import retrofit2.http.Header; |
| 33 | import retrofit2.http.Headers; | 34 | import retrofit2.http.Headers; |
| 34 | import retrofit2.http.Multipart; | 35 | import retrofit2.http.Multipart; |
| 35 | import retrofit2.http.POST; | 36 | import retrofit2.http.POST; |
| 36 | import retrofit2.http.Part; | 37 | import retrofit2.http.Part; |
| 37 | import retrofit2.http.PartMap; | 38 | import retrofit2.http.PartMap; |
| 38 | import retrofit2.http.Path; | 39 | import retrofit2.http.Path; |
| 39 | import retrofit2.http.Query; | 40 | import retrofit2.http.Query; |
| 40 | import retrofit2.http.QueryMap; | 41 | import retrofit2.http.QueryMap; |
| 41 | import retrofit2.http.Streaming; | 42 | import retrofit2.http.Streaming; |
| 42 | import retrofit2.http.Url; | 43 | import retrofit2.http.Url; |
| 43 | 44 | ||
| 44 | /** | 45 | /** |
| 45 | * 类名称:NetWorks | 46 | * 类名称:NetWorks |
| 46 | * 创建人: | 47 | * 创建人: |
| 47 | * <p> | 48 | * <p> |
| 48 | * 类描述:网络请求的操作类 | 49 | * 类描述:网络请求的操作类 |
| 49 | */ | 50 | */ |
| 50 | public class NetWorks extends RetrofitUtils { | 51 | public class NetWorks extends RetrofitUtils { |
| 51 | //服务器路径 | 52 | //服务器路径 |
| 52 | public static final NetService service_url = getMachineRetrofit(BuildConfig.SERVER_URL).create(NetService.class); | 53 | public static final NetService service_url = getMachineRetrofit(BuildConfig.SERVER_URL).create(NetService.class); |
| 53 | 54 | ||
| 54 | //设缓存有效期为1天 | 55 | //设缓存有效期为1天 |
| 55 | protected static final long CACHE_STALE_SEC = 60 * 60 * 24 * 1; | 56 | protected static final long CACHE_STALE_SEC = 60 * 60 * 24 * 1; |
| 56 | //查询缓存的Cache-Control设置,使用缓存 | 57 | //查询缓存的Cache-Control设置,使用缓存 |
| 57 | protected static final String CACHE_CONTROL_CACHE = "only-if-cached, max-stale=" + CACHE_STALE_SEC; | 58 | protected static final String CACHE_CONTROL_CACHE = "only-if-cached, max-stale=" + CACHE_STALE_SEC; |
| 58 | //查询网络的Cache-Control设置。不使用缓存 | 59 | //查询网络的Cache-Control设置。不使用缓存 |
| 59 | protected static final String CACHE_CONTROL_NETWORK = "max-age=0"; | 60 | protected static final String CACHE_CONTROL_NETWORK = "max-age=0"; |
| 60 | 61 | ||
| 61 | 62 | ||
| 62 | private interface NetService { | 63 | private interface NetService { |
| 63 | 64 | ||
| 64 | 65 | ||
| 65 | @GET("/api/v1/user/logout") | 66 | @GET("/api/v1/user/logout") |
| 66 | Observable<ResponseBody> logout(); | 67 | Observable<ResponseBody> logout(); |
| 67 | 68 | ||
| 68 | @Multipart | 69 | @Multipart |
| 69 | @POST("/api/v1/user/upLoadAvatar") | 70 | @POST("/api/v1/user/upLoadAvatar") |
| 70 | Observable<ResponseBody> upLoadAvatar(@Header("Authorization") String token, @Part List<MultipartBody.Part> partLis); | 71 | Observable<ResponseBody> upLoadAvatar(@Header("Authorization") String token, @Part List<MultipartBody.Part> partLis); |
| 71 | 72 | ||
| 72 | 73 | ||
| 73 | @Headers("Content-Type: application/json") | 74 | @Headers("Content-Type: application/json") |
| 74 | @POST("/api/v1/user/editUser") | 75 | @POST("/api/v1/user/editUser") |
| 75 | Observable<ResponseBody> editUser(@Header("Authorization") String token, @Body RequestBody body); | 76 | Observable<ResponseBody> editUser(@Header("Authorization") String token, @Body RequestBody body); |
| 76 | 77 | ||
| 77 | @Headers("Content-Type: application/json") | 78 | @Headers("Content-Type: application/json") |
| 78 | @POST("/api/v1/user/changePassword") | 79 | @POST("/api/v1/user/changePassword") |
| 79 | Observable<ResponseBody> changePassword(@Header("Authorization") String token, @Body RequestBody body); | 80 | Observable<ResponseBody> changePassword(@Header("Authorization") String token, @Body RequestBody body); |
| 80 | 81 | ||
| 81 | 82 | ||
| 82 | @GET("/api/v1/user/searchById") | 83 | @GET("/api/v1/user/searchById") |
| 83 | Observable<ResponseBody> searchById(@Header("Authorization") String token, @Query("userId") String userId); | 84 | Observable<ResponseBody> searchById(@Header("Authorization") String token, @Query("userId") String userId); |
| 84 | 85 | ||
| 85 | 86 | ||
| 86 | @Headers("Content-Type: application/json") | 87 | @Headers("Content-Type: application/json") |
| 87 | @POST("/api/v1/auth/login") | 88 | @POST("/api/v1/auth/login") |
| 88 | Observable<ResponseBody> login(@Body RequestBody body); | 89 | Observable<ResponseBody> login(@Body RequestBody body); |
| 89 | 90 | ||
| 90 | @GET("/api/v1/resource/listGradeAndSubject") | 91 | @GET("/api/v1/resource/listGradeAndSubject") |
| 91 | Observable<ResponseResult<List<GradeAndSubject>>> listGradeAndSubject(@Header("Authorization") String token); | 92 | Observable<ResponseResult<List<GradeAndSubject>>> listGradeAndSubject(@Header("Authorization") String token); |
| 92 | 93 | ||
| 93 | 94 | ||
| 94 | @GET("/api/v1/manager/generalQrCode") | 95 | @GET("/api/v1/manager/generalQrCode") |
| 95 | Observable<ResponseBody> generalQrCode(); | 96 | Observable<ResponseBody> generalQrCode(); |
| 96 | 97 | ||
| 97 | @GET("/api/v1/parent/scanAndLogin?") | 98 | @GET("/api/v1/parent/scanAndLogin?") |
| 98 | Observable<ResponseBody> scanAndLogin(@Header("Authorization") String token, @Query("code") String code); | 99 | Observable<ResponseBody> scanAndLogin(@Header("Authorization") String token, @Query("code") String code); |
| 99 | 100 | ||
| 100 | @GET("/api/v1/parent/getChildrenList") | 101 | @GET("/api/v1/parent/getChildrenList") |
| 101 | Observable<ResponseBody> getChildrenList(@Header("Authorization") String token); | 102 | Observable<ResponseBody> getChildrenList(@Header("Authorization") String token); |
| 102 | 103 | ||
| 103 | 104 | ||
| 104 | @Headers("Content-Type: application/json") | 105 | @Headers("Content-Type: application/json") |
| 105 | @POST("/api/v1/parent/registerParent") | 106 | @POST("/api/v1/parent/registerParent") |
| 106 | Observable<ResponseBody> registerParent(@Body RequestBody body); | 107 | Observable<ResponseBody> registerParent(@Body RequestBody body); |
| 107 | 108 | ||
| 108 | 109 | ||
| 109 | @GET("/api/v1/parent/listChildren") | 110 | @GET("/api/v1/parent/listChildren") |
| 110 | Observable<ResponseBody> listChildren(@Header("Authorization") String token); | 111 | Observable<ResponseBody> listChildren(@Header("Authorization") String token); |
| 111 | 112 | ||
| 112 | 113 | ||
| 113 | @Headers("Content-Type: application/json") | 114 | @Headers("Content-Type: application/json") |
| 114 | @POST("/api/v1/parent/registerStudent") | 115 | @POST("/api/v1/parent/registerStudent") |
| 115 | Observable<ResponseBody> registerStudent(@Header("Authorization") String token, @Body RequestBody body); | 116 | Observable<ResponseBody> registerStudent(@Header("Authorization") String token, @Body RequestBody body); |
| 116 | 117 | ||
| 117 | @Headers("Content-Type: application/json") | 118 | @Headers("Content-Type: application/json") |
| 118 | @POST("/api/v1/parent/bindTeacher") | 119 | @POST("/api/v1/parent/bindTeacher") |
| 119 | Observable<ResponseBody> bindTeacher(@Header("Authorization") String token, @Body RequestBody body); | 120 | Observable<ResponseBody> bindTeacher(@Header("Authorization") String token, @Body RequestBody body); |
| 120 | 121 | ||
| 121 | @Multipart | 122 | @Multipart |
| 122 | @POST("/api/v1/user/upLoadAvatar") | 123 | @POST("/api/v1/user/upLoadAvatar") |
| 123 | Observable<ResponseResult<Map<String, String>>> uploadAvatar(@Header("Authorization") String token, @Part() MultipartBody.Part file); | 124 | Observable<ResponseResult<Map<String, String>>> uploadAvatar(@Header("Authorization") String token, @Part() MultipartBody.Part file); |
| 124 | 125 | ||
| 125 | 126 | ||
| 126 | @Multipart | 127 | @Multipart |
| 127 | @POST("/api/v1/student/editStudentAvatar") | 128 | @POST("/api/v1/student/editStudentAvatar") |
| 128 | Observable<ResponseResult<Map<String, String>>> uploadAvatar(@Header("Authorization") String token, @Part() MultipartBody.Part file, @PartMap Map<String, Object> map); | 129 | Observable<ResponseResult<Map<String, String>>> uploadAvatar(@Header("Authorization") String token, @Part() MultipartBody.Part file, @PartMap Map<String, Object> map); |
| 129 | 130 | ||
| 130 | @Headers("Content-Type: application/json") | 131 | @Headers("Content-Type: application/json") |
| 131 | @POST("/api/v1/parent/editChild") | 132 | @POST("/api/v1/parent/editChild") |
| 132 | Observable<ResponseResult> editStudent(@Header("Authorization") String token, @Body RequestBody body); | 133 | Observable<ResponseResult> editStudent(@Header("Authorization") String token, @Body RequestBody body); |
| 133 | 134 | ||
| 134 | @GET("/api/v1/student/getStudyPlanForThisWeek") | 135 | @GET("/api/v1/student/getStudyPlanForThisWeek") |
| 135 | Observable<ResponseResult<ScheduleBean>> getWeekPlan(@Header("Authorization") String token, @Query("stuId") String stuId); | 136 | Observable<ResponseResult<ScheduleBean>> getWeekPlan(@Header("Authorization") String token, @Query("stuId") String stuId); |
| 137 | |||
| 138 | @GET("api/v1/parent/searchTeacher") | ||
| 139 | Observable<ResponseResult<Teacher>> searchTeacher(@Header("Authorization") String token, @Query("phone") String phone); | ||
| 136 | } | 140 | } |
| 137 | 141 | ||
| 138 | 142 | ||
| 139 | public static String getHeader() { | 143 | public static String getHeader() { |
| 140 | return (String) SharedPreferencesUtil.getData("token", ""); | 144 | return (String) SharedPreferencesUtil.getData("token", ""); |
| 141 | } | 145 | } |
| 142 | 146 | ||
| 147 | public static void searchTeacher(String phone, Observer<ResponseResult<Teacher>> observer) { | ||
| 148 | setSubscribe(service_url.searchTeacher(getHeader(), phone), observer); | ||
| 149 | } | ||
| 150 | |||
| 143 | public static void logout(Observer<ResponseBody> observer) { | 151 | public static void logout(Observer<ResponseBody> observer) { |
| 144 | setSubscribe(service_url.logout(), observer); | 152 | setSubscribe(service_url.logout(), observer); |
| 145 | } | 153 | } |
| 146 | 154 | ||
| 147 | public static void editStudent(RequestBody body, Observer<ResponseResult> observable) { | 155 | public static void editStudent(RequestBody body, Observer<ResponseResult> observable) { |
| 148 | setSubscribe(service_url.editStudent(getHeader(), body), observable); | 156 | setSubscribe(service_url.editStudent(getHeader(), body), observable); |
| 149 | } | 157 | } |
| 150 | 158 | ||
| 151 | public static void getWeekPlan(String id, Observer<ResponseResult<ScheduleBean>> observer) { | 159 | public static void getWeekPlan(String id, Observer<ResponseResult<ScheduleBean>> observer) { |
| 152 | setSubscribe(service_url.getWeekPlan(getHeader(), id), observer); | 160 | setSubscribe(service_url.getWeekPlan(getHeader(), id), observer); |
| 153 | } | 161 | } |
| 154 | 162 | ||
| 155 | public static void uploadStudentAvatar(File file, String stuId, Observer<ResponseResult<Map<String, String>>> observer) { | 163 | public static void uploadStudentAvatar(File file, String stuId, Observer<ResponseResult<Map<String, String>>> observer) { |
| 156 | RequestBody requestBody = RequestBody.create(MediaType.parse("multipart/form-data"), file); | 164 | RequestBody requestBody = RequestBody.create(MediaType.parse("multipart/form-data"), file); |
| 157 | MultipartBody.Part part = MultipartBody.Part.createFormData("file", file.getName(), requestBody); | 165 | MultipartBody.Part part = MultipartBody.Part.createFormData("file", file.getName(), requestBody); |
| 158 | Map<String, Object> map = new HashMap<>(); | 166 | Map<String, Object> map = new HashMap<>(); |
| 159 | map.put("stuId", stuId); | 167 | map.put("stuId", stuId); |
| 160 | setSubscribe(service_url.uploadAvatar(getHeader(), part, map), observer); | 168 | setSubscribe(service_url.uploadAvatar(getHeader(), part, map), observer); |
| 161 | } | 169 | } |
| 162 | 170 | ||
| 163 | public static void uploadAvatar(File file, Observer<ResponseResult<Map<String, String>>> observer) { | 171 | public static void uploadAvatar(File file, Observer<ResponseResult<Map<String, String>>> observer) { |
| 164 | RequestBody requestBody = RequestBody.create(MediaType.parse("multipart/form-data"), file); | 172 | RequestBody requestBody = RequestBody.create(MediaType.parse("multipart/form-data"), file); |
| 165 | MultipartBody.Part part = MultipartBody.Part.createFormData("file", file.getName(), requestBody); | 173 | MultipartBody.Part part = MultipartBody.Part.createFormData("file", file.getName(), requestBody); |
| 166 | setSubscribe(service_url.uploadAvatar(getHeader(), part), observer); | 174 | setSubscribe(service_url.uploadAvatar(getHeader(), part), observer); |
| 167 | } | 175 | } |
| 168 | 176 | ||
| 169 | public static void upLoadAvatar(List<MultipartBody.Part> partLis, Observer<ResponseBody> observer) { | 177 | public static void upLoadAvatar(List<MultipartBody.Part> partLis, Observer<ResponseBody> observer) { |
| 170 | setSubscribe(service_url.upLoadAvatar(getHeader(), partLis), observer); | 178 | setSubscribe(service_url.upLoadAvatar(getHeader(), partLis), observer); |
| 171 | } | 179 | } |
| 172 | 180 | ||
| 173 | 181 | ||
| 174 | public static void editUser(RequestBody body, Observer<ResponseBody> observer) { | 182 | public static void editUser(RequestBody body, Observer<ResponseBody> observer) { |
| 175 | setSubscribe(service_url.editUser(getHeader(), body), observer); | 183 | setSubscribe(service_url.editUser(getHeader(), body), observer); |
| 176 | } | 184 | } |
| 177 | 185 | ||
| 178 | public static void changePassword(RequestBody body, Observer<ResponseBody> observer) { | 186 | public static void changePassword(RequestBody body, Observer<ResponseBody> observer) { |
| 179 | setSubscribe(service_url.changePassword(getHeader(), body), observer); | 187 | setSubscribe(service_url.changePassword(getHeader(), body), observer); |
| 180 | } | 188 | } |
| 181 | 189 | ||
| 182 | 190 | ||
| 183 | public static void searchById(String userId, Observer<ResponseBody> observer) { | 191 | public static void searchById(String userId, Observer<ResponseBody> observer) { |
| 184 | setSubscribe(service_url.searchById(getHeader(), userId), observer); | 192 | setSubscribe(service_url.searchById(getHeader(), userId), observer); |
| 185 | } | 193 | } |
| 186 | 194 | ||
| 187 | 195 | ||
| 188 | public static void login(RequestBody body, Observer<ResponseBody> observer) { | 196 | public static void login(RequestBody body, Observer<ResponseBody> observer) { |
| 189 | setSubscribe(service_url.login(body), observer); | 197 | setSubscribe(service_url.login(body), observer); |
| 190 | } | 198 | } |
| 191 | 199 | ||
| 192 | public static void listGradeAndSubject(Observer<ResponseResult<List<GradeAndSubject>>> observer) { | 200 | public static void listGradeAndSubject(Observer<ResponseResult<List<GradeAndSubject>>> observer) { |
| 193 | setSubscribe(service_url.listGradeAndSubject(getHeader()), observer); | 201 | setSubscribe(service_url.listGradeAndSubject(getHeader()), observer); |
| 194 | } | 202 | } |
| 195 | 203 | ||
| 196 | 204 | ||
| 197 | public static void scanAndLogin(String code, Observer<ResponseBody> observer) { | 205 | public static void scanAndLogin(String code, Observer<ResponseBody> observer) { |
| 198 | setSubscribe(service_url.scanAndLogin(getHeader(), code), observer); | 206 | setSubscribe(service_url.scanAndLogin(getHeader(), code), observer); |
| 199 | } | 207 | } |
| 200 | 208 | ||
| 201 | public static void getChildrenList(Observer<ResponseBody> observer) { | 209 | public static void getChildrenList(Observer<ResponseBody> observer) { |
| 202 | setSubscribe(service_url.getChildrenList(getHeader()), observer); | 210 | setSubscribe(service_url.getChildrenList(getHeader()), observer); |
| 203 | } | 211 | } |
| 204 | 212 | ||
| 205 | 213 | ||
| 206 | public static void registerParent(RequestBody body, Observer<ResponseBody> observer) { | 214 | public static void registerParent(RequestBody body, Observer<ResponseBody> observer) { |
| 207 | setSubscribe(service_url.registerParent(body), observer); | 215 | setSubscribe(service_url.registerParent(body), observer); |
| 208 | } | 216 | } |
| 209 | 217 | ||
| 210 | 218 | ||
| 211 | public static void listChildren(Observer<ResponseBody> observer) { | 219 | public static void listChildren(Observer<ResponseBody> observer) { |
| 212 | setSubscribe(service_url.listChildren(getHeader()), observer); | 220 | setSubscribe(service_url.listChildren(getHeader()), observer); |
| 213 | } | 221 | } |
| 214 | 222 | ||
| 215 | 223 | ||
| 216 | public static void registerStudent(RequestBody body, Observer<ResponseBody> observer) { | 224 | public static void registerStudent(RequestBody body, Observer<ResponseBody> observer) { |
| 217 | setSubscribe(service_url.registerStudent(getHeader(), body), observer); | 225 | setSubscribe(service_url.registerStudent(getHeader(), body), observer); |
| 218 | } | 226 | } |
| 219 | 227 | ||
| 220 | public static void bindTeacher(RequestBody body, Observer<ResponseBody> observer) { | 228 | public static void bindTeacher(RequestBody body, Observer<ResponseBody> observer) { |
| 221 | setSubscribe(service_url.bindTeacher(getHeader(), body), observer); | 229 | setSubscribe(service_url.bindTeacher(getHeader(), body), observer); |
| 222 | } | 230 | } |
| 223 | 231 | ||
| 224 | 232 | ||
| 225 | public static RequestBody getMapRequestBody(Map map) { | 233 | public static RequestBody getMapRequestBody(Map map) { |
| 226 | return RequestBody.create(MediaType.parse("text/plain"), new Gson().toJson(map)); | 234 | return RequestBody.create(MediaType.parse("text/plain"), new Gson().toJson(map)); |
| 227 | } | 235 | } |
| 228 | 236 | ||
| 229 | public static RequestBody getArrayRequestBody(List list) { | 237 | public static RequestBody getArrayRequestBody(List list) { |
| 230 | return RequestBody.create(MediaType.parse("text/plain"), new Gson().toJson(list)); | 238 | return RequestBody.create(MediaType.parse("text/plain"), new Gson().toJson(list)); |
| 231 | } | 239 | } |
| 232 | 240 | ||
| 233 | public static RequestBody getFileRequestBody(File file) { | 241 | public static RequestBody getFileRequestBody(File file) { |
| 234 | return RequestBody.create(MediaType.parse("application/octet-stream"), file); | 242 | return RequestBody.create(MediaType.parse("application/octet-stream"), file); |
| 235 | } | 243 | } |
| 236 | 244 | ||
| 237 | public static RequestBody getFileRequestBody(byte[] bytes) { | 245 | public static RequestBody getFileRequestBody(byte[] bytes) { |
| 238 | return RequestBody.create(MediaType.parse("multipart/form-data"), bytes); | 246 | return RequestBody.create(MediaType.parse("multipart/form-data"), bytes); |
| 239 | } | 247 | } |
| 240 | 248 | ||
| 241 | public static RequestBody getObjectRequestBody(Object obj) { | 249 | public static RequestBody getObjectRequestBody(Object obj) { |
| 242 | return RequestBody.create(MediaType.parse("text/plain"), new Gson().toJson(obj)); | 250 | return RequestBody.create(MediaType.parse("text/plain"), new Gson().toJson(obj)); |
| 243 | } | 251 | } |
| 244 | 252 | ||
| 245 | public static RequestBody getStringRequestBody(String str) { | 253 | public static RequestBody getStringRequestBody(String str) { |
| 246 | return RequestBody.create(MediaType.parse("text/plain"), str); | 254 | return RequestBody.create(MediaType.parse("text/plain"), str); |
| 247 | } | 255 | } |
| 248 | 256 | ||
| 249 | /** | 257 | /** |
| 250 | * 插入观察者 | 258 | * 插入观察者 |
| 251 | * | 259 | * |
| 252 | * @param observable | 260 | * @param observable |
| 253 | * @param observer | 261 | * @param observer |
| 254 | * @param <T> | 262 | * @param <T> |
| 255 | */ | 263 | */ |
| 256 | public static <T> void setSubscribe(Observable<T> observable, Observer<T> observer) { | 264 | public static <T> void setSubscribe(Observable<T> observable, Observer<T> observer) { |
| 257 | observable.subscribeOn(Schedulers.io())//子线程访问网络 | 265 | observable.subscribeOn(Schedulers.io())//子线程访问网络 |
| 258 | .observeOn(AndroidSchedulers.mainThread())//回调到主线程 | 266 | .observeOn(AndroidSchedulers.mainThread())//回调到主线程 |
| 259 | .subscribe(observer); | 267 | .subscribe(observer); |
| 260 | } | 268 | } |
| 261 | 269 | ||
| 262 | } | 270 | } |
| 263 | 271 |