完成所在地区的弹窗
This commit is contained in:
parent
3242c4861d
commit
a2304731c3
1
.gitignore
vendored
1
.gitignore
vendored
@ -13,3 +13,4 @@
|
||||
/captures
|
||||
.externalNativeBuild
|
||||
.cxx
|
||||
app/release/
|
116
.idea/codeStyles/Project.xml
generated
116
.idea/codeStyles/Project.xml
generated
@ -1,116 +0,0 @@
|
||||
<component name="ProjectCodeStyleConfiguration">
|
||||
<code_scheme name="Project" version="173">
|
||||
<codeStyleSettings language="XML">
|
||||
<indentOptions>
|
||||
<option name="CONTINUATION_INDENT_SIZE" value="4" />
|
||||
</indentOptions>
|
||||
<arrangement>
|
||||
<rules>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>xmlns:android</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>^$</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
</rule>
|
||||
</section>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>xmlns:.*</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>^$</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
<order>BY_NAME</order>
|
||||
</rule>
|
||||
</section>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>.*:id</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>http://schemas.android.com/apk/res/android</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
</rule>
|
||||
</section>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>.*:name</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>http://schemas.android.com/apk/res/android</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
</rule>
|
||||
</section>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>name</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>^$</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
</rule>
|
||||
</section>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>style</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>^$</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
</rule>
|
||||
</section>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>.*</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>^$</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
<order>BY_NAME</order>
|
||||
</rule>
|
||||
</section>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>.*</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>http://schemas.android.com/apk/res/android</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
<order>ANDROID_ATTRIBUTE_ORDER</order>
|
||||
</rule>
|
||||
</section>
|
||||
<section>
|
||||
<rule>
|
||||
<match>
|
||||
<AND>
|
||||
<NAME>.*</NAME>
|
||||
<XML_ATTRIBUTE />
|
||||
<XML_NAMESPACE>.*</XML_NAMESPACE>
|
||||
</AND>
|
||||
</match>
|
||||
<order>BY_NAME</order>
|
||||
</rule>
|
||||
</section>
|
||||
</rules>
|
||||
</arrangement>
|
||||
</codeStyleSettings>
|
||||
</code_scheme>
|
||||
</component>
|
22
.idea/gradle.xml
generated
22
.idea/gradle.xml
generated
@ -1,22 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="GradleMigrationSettings" migrationVersion="1" />
|
||||
<component name="GradleSettings">
|
||||
<option name="linkedExternalProjectsSettings">
|
||||
<GradleProjectSettings>
|
||||
<option name="testRunner" value="PLATFORM" />
|
||||
<option name="distributionType" value="DEFAULT_WRAPPED" />
|
||||
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
||||
<option name="gradleJvm" value="1.8" />
|
||||
<option name="modules">
|
||||
<set>
|
||||
<option value="$PROJECT_DIR$" />
|
||||
<option value="$PROJECT_DIR$/app" />
|
||||
<option value="$PROJECT_DIR$/xrecyclerview" />
|
||||
</set>
|
||||
</option>
|
||||
<option name="resolveModulePerSourceSet" value="false" />
|
||||
</GradleProjectSettings>
|
||||
</option>
|
||||
</component>
|
||||
</project>
|
35
.idea/jarRepositories.xml
generated
35
.idea/jarRepositories.xml
generated
@ -1,35 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="RemoteRepositoriesConfiguration">
|
||||
<remote-repository>
|
||||
<option name="id" value="central" />
|
||||
<option name="name" value="Maven Central repository" />
|
||||
<option name="url" value="https://repo1.maven.org/maven2" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="jboss.community" />
|
||||
<option name="name" value="JBoss Community repository" />
|
||||
<option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="BintrayJCenter" />
|
||||
<option name="name" value="BintrayJCenter" />
|
||||
<option name="url" value="https://jcenter.bintray.com/" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="Google" />
|
||||
<option name="name" value="Google" />
|
||||
<option name="url" value="https://dl.google.com/dl/android/maven2/" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="maven" />
|
||||
<option name="name" value="maven" />
|
||||
<option name="url" value="http://maven.aliyun.com/nexus/content/groups/public/" />
|
||||
</remote-repository>
|
||||
<remote-repository>
|
||||
<option name="id" value="maven" />
|
||||
<option name="name" value="maven" />
|
||||
<option name="url" value="https://jitpack.io" />
|
||||
</remote-repository>
|
||||
</component>
|
||||
</project>
|
9
.idea/misc.xml
generated
9
.idea/misc.xml
generated
@ -1,9 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" project-jdk-name="1.8" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/build/classes" />
|
||||
</component>
|
||||
<component name="ProjectType">
|
||||
<option name="id" value="Android" />
|
||||
</component>
|
||||
</project>
|
12
.idea/runConfigurations.xml
generated
12
.idea/runConfigurations.xml
generated
@ -1,12 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="RunConfigurationProducerService">
|
||||
<option name="ignoredProducers">
|
||||
<set>
|
||||
<option value="org.jetbrains.plugins.gradle.execution.test.runner.AllInPackageGradleConfigurationProducer" />
|
||||
<option value="org.jetbrains.plugins.gradle.execution.test.runner.TestClassGradleConfigurationProducer" />
|
||||
<option value="org.jetbrains.plugins.gradle.execution.test.runner.TestMethodGradleConfigurationProducer" />
|
||||
</set>
|
||||
</option>
|
||||
</component>
|
||||
</project>
|
6
.idea/vcs.xml
generated
6
.idea/vcs.xml
generated
@ -1,6 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="Git" />
|
||||
</component>
|
||||
</project>
|
@ -6,7 +6,7 @@ android {
|
||||
// ndkVersion '23.0.7123448'
|
||||
|
||||
defaultConfig {
|
||||
applicationId "com.example.myapplication"
|
||||
applicationId "com.navinfo.outdoor"
|
||||
minSdkVersion 23
|
||||
targetSdkVersion 30
|
||||
versionCode 1
|
||||
@ -21,6 +21,7 @@ android {
|
||||
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
|
||||
}
|
||||
}
|
||||
|
||||
compileOptions {
|
||||
sourceCompatibility JavaVersion.VERSION_1_8
|
||||
targetCompatibility JavaVersion.VERSION_1_8
|
||||
@ -65,6 +66,9 @@ dependencies {
|
||||
implementation 'org.greenrobot:eventbus:3.1.1'
|
||||
//三级选择
|
||||
implementation 'com.airsaid.library:pickerview:1.0.3'
|
||||
//省市区 https://github.com/Bigkoo/Android-PickerView
|
||||
compile 'com.contrarywind:Android-PickerView:4.1.6'
|
||||
implementation 'com.contrarywind:Android-PickerView:4.1.8'
|
||||
/* //加载html
|
||||
implementation 'com.github.sendtion:XRichText:1.9.4'*/
|
||||
//加载图片的依赖包
|
||||
@ -74,4 +78,5 @@ dependencies {
|
||||
//xRecyclerview下拉刷新控件
|
||||
implementation project(':xrecyclerview')
|
||||
|
||||
|
||||
}
|
@ -33,6 +33,7 @@
|
||||
<activity android:name="com.navinfo.outdoor.activity.WebActivity"></activity>
|
||||
<activity android:name="com.navinfo.outdoor.activity.FragmentManagement"></activity>
|
||||
<activity android:name="com.navinfo.outdoor.activity.ImageShowActivity"></activity>
|
||||
<activity android:name="com.navinfo.outdoor.activity.UserActivity"></activity>
|
||||
</application>
|
||||
|
||||
</manifest>
|
13493
app/src/main/assets/prov_city_county.json
Normal file
13493
app/src/main/assets/prov_city_county.json
Normal file
File diff suppressed because it is too large
Load Diff
5354
app/src/main/assets/province.json
Normal file
5354
app/src/main/assets/province.json
Normal file
File diff suppressed because it is too large
Load Diff
@ -29,7 +29,6 @@ import com.navinfo.outdoor.fragment.TaskPrefectureFragment;
|
||||
import com.navinfo.outdoor.fragment.RegisterFragment;
|
||||
import com.navinfo.outdoor.fragment.TreasureFragment;
|
||||
import com.navinfo.outdoor.fragment.UserAttestationFragment;
|
||||
import com.navinfo.outdoor.fragment.UserDataFragment;
|
||||
import com.navinfo.outdoor.fragment.WithdrawFragment;
|
||||
import com.gyf.immersionbar.ImmersionBar;
|
||||
import com.navinfo.outdoor.fragment.WithdrawalRecordFragment;
|
||||
@ -61,7 +60,7 @@ public class FragmentManagement extends BaseActivity {
|
||||
private TaskExWebFragment taskExWebFragment;//发现-任务说明点击Item进入Web页面的fragment -13
|
||||
private CapacityMeasurementFragment capacityMeasurementFragment;//发现-能力测评item点击跳转web的fragment -14
|
||||
private WithdrawFragment withdrawFragment;//我的-提现的fragment -15
|
||||
private UserDataFragment userDataFragment;//我的-用户资料的fragment -16
|
||||
private IssueWebFragment issueWebFragment;//我的-常见问题-web的fragment -16
|
||||
private GradeFragment gradeFragment;//我的-我的等级的fragment -17
|
||||
private PrivilegeFragment privilegeFragment;//我的-我的特权的fragment -18
|
||||
private MapDownloadFragment mapDownloadFragment;//我的-地图下载的fragment -19
|
||||
@ -72,7 +71,7 @@ public class FragmentManagement extends BaseActivity {
|
||||
private GatheringFragment gatheringFragment;//我的-用户资料-收款信息的fragment -24
|
||||
private UserAttestationFragment userAttestationFragment;//我的-用户资料-实名认证的fragment -25
|
||||
private WithdrawalRecordFragment withdrawalRecordFragment;//我的-提现-提现记录的fragment -26
|
||||
private IssueWebFragment issueWebFragment;//我的-常见问题-web的fragment -27
|
||||
|
||||
|
||||
|
||||
@Override
|
||||
@ -123,8 +122,8 @@ public class FragmentManagement extends BaseActivity {
|
||||
fragmentTransaction.hide(capacityMeasurementFragment);
|
||||
if (withdrawFragment != null)//我的-提现的fragment -15
|
||||
fragmentTransaction.hide(withdrawFragment);
|
||||
if (userDataFragment != null)//我的-用户资料的fragment -16
|
||||
fragmentTransaction.hide(userDataFragment);
|
||||
if (issueWebFragment!=null)//我的-常见问题-web的fragment -27
|
||||
fragmentTransaction.hide(issueWebFragment);
|
||||
if (gradeFragment != null)//我的-我的等级的fragment -17
|
||||
fragmentTransaction.hide(gradeFragment);
|
||||
if (privilegeFragment != null)//我的-我的特权的fragment -18
|
||||
@ -145,8 +144,7 @@ public class FragmentManagement extends BaseActivity {
|
||||
fragmentTransaction.hide(userAttestationFragment);
|
||||
if (withdrawalRecordFragment!=null)
|
||||
fragmentTransaction.hide(withdrawalRecordFragment);
|
||||
if (issueWebFragment!=null)//我的-常见问题-web的fragment -27
|
||||
fragmentTransaction.hide(issueWebFragment);
|
||||
|
||||
|
||||
|
||||
}
|
||||
@ -278,12 +276,12 @@ public class FragmentManagement extends BaseActivity {
|
||||
fragmentTransaction.show(withdrawFragment);
|
||||
}
|
||||
break;
|
||||
case 16://我的-用户资料的fragment
|
||||
if (userDataFragment == null) {
|
||||
userDataFragment = new UserDataFragment();
|
||||
fragmentTransaction.add(R.id.frame_layout, userDataFragment);
|
||||
case 16://我的-常见问题-web的fragment
|
||||
if (issueWebFragment == null) {
|
||||
issueWebFragment = new IssueWebFragment();
|
||||
fragmentTransaction.add(R.id.frame_layout, issueWebFragment);
|
||||
} else {
|
||||
fragmentTransaction.show(userDataFragment);
|
||||
fragmentTransaction.show(issueWebFragment);
|
||||
}
|
||||
break;
|
||||
case 17://我的-我的等级的fragment
|
||||
@ -366,14 +364,6 @@ public class FragmentManagement extends BaseActivity {
|
||||
fragmentTransaction.show(withdrawalRecordFragment);
|
||||
}
|
||||
break;
|
||||
case 27://我的-常见问题-web的fragment
|
||||
if (issueWebFragment == null) {
|
||||
issueWebFragment = new IssueWebFragment();
|
||||
fragmentTransaction.add(R.id.frame_layout, issueWebFragment);
|
||||
} else {
|
||||
fragmentTransaction.show(issueWebFragment);
|
||||
}
|
||||
break;
|
||||
}
|
||||
fragmentTransaction.commit();
|
||||
}
|
||||
@ -428,7 +418,7 @@ public class FragmentManagement extends BaseActivity {
|
||||
withdrawFragment.onActivityResult(requestCode, resultCode, data);
|
||||
break;
|
||||
case 16:
|
||||
userDataFragment.onActivityResult(requestCode, resultCode, data);
|
||||
issueWebFragment.onActivityResult(requestCode, resultCode, data);
|
||||
break;
|
||||
case 17:
|
||||
gradeFragment.onActivityResult(requestCode, resultCode, data);
|
||||
@ -460,9 +450,6 @@ public class FragmentManagement extends BaseActivity {
|
||||
case 26:
|
||||
withdrawalRecordFragment.onActivityResult(requestCode,resultCode,data);
|
||||
break;
|
||||
case 27:
|
||||
issueWebFragment.onActivityResult(requestCode,resultCode,data);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -9,6 +9,9 @@ import com.navinfo.outdoor.util.NoSlideViewPager;
|
||||
|
||||
import androidx.fragment.app.Fragment;
|
||||
import androidx.fragment.app.FragmentPagerAdapter;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.SharedPreferences;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
import android.widget.ImageView;
|
||||
|
@ -62,4 +62,7 @@ public class LoginActivity extends BaseActivity implements View.OnClickListener
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
272
app/src/main/java/com/navinfo/outdoor/activity/UserActivity.java
Normal file
272
app/src/main/java/com/navinfo/outdoor/activity/UserActivity.java
Normal file
@ -0,0 +1,272 @@
|
||||
package com.navinfo.outdoor.activity;
|
||||
|
||||
import android.content.Intent;
|
||||
import android.graphics.Color;
|
||||
import android.text.TextUtils;
|
||||
import android.view.View;
|
||||
import android.widget.Button;
|
||||
import android.widget.EditText;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.LinearLayout;
|
||||
import android.widget.TextView;
|
||||
import android.widget.Toast;
|
||||
|
||||
import com.bigkoo.pickerview.builder.OptionsPickerBuilder;
|
||||
import com.bigkoo.pickerview.listener.OnOptionsSelectListener;
|
||||
import com.bigkoo.pickerview.view.OptionsPickerView;
|
||||
import com.google.gson.Gson;
|
||||
import com.navinfo.outdoor.R;
|
||||
import com.navinfo.outdoor.base.BaseActivity;
|
||||
import com.navinfo.outdoor.bean.CityBean;
|
||||
import com.navinfo.outdoor.bean.JsonBean;
|
||||
import com.navinfo.outdoor.util.GetJsonDataUtil;
|
||||
import com.navinfo.outdoor.util.RegexUtil;
|
||||
import org.json.JSONArray;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
/**
|
||||
* 用户资料
|
||||
*/
|
||||
public class UserActivity extends BaseActivity implements View.OnClickListener {
|
||||
private List<JsonBean> options1Items = new ArrayList<>();
|
||||
private ArrayList<ArrayList<String>> options2Items = new ArrayList<>();
|
||||
private ArrayList<ArrayList<ArrayList<String>>> options3Items = new ArrayList<>();
|
||||
private ArrayList<ArrayList<ArrayList<CityBean>>> cityItems = new ArrayList<>();
|
||||
private Button btnGathering, btnAttestation;
|
||||
private ImageView ivUser;
|
||||
private TextView region;
|
||||
private EditText etPhone, etQq, etMailbox;
|
||||
public static Pattern compile = Pattern.compile("/^[_a-z0-9-]+(\\.[_a-z0-9-]+)*@[a-z0-9-]+(\\.[a-z0-9-]+)*(\\.[a-z]{2,})$/");
|
||||
private Button userSave;
|
||||
private LinearLayout llRegion;
|
||||
|
||||
@Override
|
||||
protected int getLayout() {
|
||||
return R.layout.activity_user;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void initData() {
|
||||
super.initData();
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void initView() {
|
||||
super.initView();
|
||||
initJsonData();
|
||||
ivUser = findViewById(R.id.iv_user);
|
||||
ivUser.setOnClickListener(this::onClick);
|
||||
btnAttestation = findViewById(R.id.btn_attestation);
|
||||
btnAttestation.setOnClickListener(this::onClick);
|
||||
btnGathering = findViewById(R.id.btn_gathering);
|
||||
btnGathering.setOnClickListener(this::onClick);
|
||||
region = findViewById(R.id.region);
|
||||
region.setOnClickListener(this::onClick);
|
||||
llRegion = findViewById(R.id.ll_region);
|
||||
llRegion.setOnClickListener(this::onClick);
|
||||
etPhone = findViewById(R.id.et_phone);
|
||||
etPhone.setOnClickListener(this::onClick);
|
||||
etQq = findViewById(R.id.edit_qq);
|
||||
etQq.setOnClickListener(this::onClick);
|
||||
etMailbox = findViewById(R.id.edit_mailbox);
|
||||
etMailbox.setOnClickListener(this::onClick);
|
||||
userSave = findViewById(R.id.btn_save);
|
||||
userSave.setOnClickListener(this::onClick);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
switch (v.getId()) {
|
||||
case R.id.iv_user:
|
||||
finish();
|
||||
break;
|
||||
case R.id.btn_gathering:
|
||||
Intent gatheringIntent = new Intent(this, FragmentManagement.class);
|
||||
gatheringIntent.putExtra("tag", 24);
|
||||
startActivity(gatheringIntent);
|
||||
break;
|
||||
case R.id.btn_attestation:
|
||||
Intent attestationIntent = new Intent(this, FragmentManagement.class);
|
||||
attestationIntent.putExtra("tag", 25);
|
||||
startActivity(attestationIntent);
|
||||
break;
|
||||
case R.id.ll_region:
|
||||
showPickerView();
|
||||
break;
|
||||
case R.id.et_phone:
|
||||
String phoneEt = etPhone.getText().toString().trim();
|
||||
if (TextUtils.isEmpty(phoneEt)) {
|
||||
Toast.makeText(this, "请输入手机号", Toast.LENGTH_SHORT).show();
|
||||
return;
|
||||
}
|
||||
if (!RegexUtil.isPhone(phoneEt)) {
|
||||
Toast.makeText(this, "手机格式有误", Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
break;
|
||||
case R.id.edit_qq:
|
||||
qq();
|
||||
break;
|
||||
case R.id.edit_mailbox:
|
||||
if (isEmail(etMailbox.getText().toString().trim()) && etMailbox.getText().toString().trim().length() <= 31) {
|
||||
Toast.makeText(this, "邮箱验证成功", Toast.LENGTH_SHORT).show();
|
||||
} else {
|
||||
Toast.makeText(this, "邮箱格式错误", Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
break;
|
||||
case R.id.btn_save:
|
||||
final String userphone = etPhone.getText().toString().trim();
|
||||
final String userqq = etQq.getText().toString().trim();
|
||||
final String usermailbox = etMailbox.getText().toString().trim();
|
||||
if (!RegexUtil.isPhone(userphone)) {
|
||||
Toast.makeText(this, "手机号输入错误", Toast.LENGTH_SHORT).show();
|
||||
return;
|
||||
}
|
||||
if (userqq.length() > 11) {
|
||||
Toast.makeText(this, "QQ号输入错误", Toast.LENGTH_SHORT).show();
|
||||
return;
|
||||
}
|
||||
if (usermailbox.length() > 31) {
|
||||
Toast.makeText(this, "邮箱输入错误", Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
private static String qq() {
|
||||
String qq = "23412312";
|
||||
String regex = "[1-9][0-9]{4,11}";
|
||||
boolean flag = qq.matches(regex);
|
||||
if (flag) {
|
||||
System.out.println("输入正确!!");
|
||||
} else {
|
||||
System.out.println("输入正确!!");
|
||||
}
|
||||
return qq();
|
||||
|
||||
}
|
||||
|
||||
public static boolean isEmail(String email) {
|
||||
if (null == email || "".equals(email)) return false;
|
||||
Matcher m = compile.matcher(email);
|
||||
return m.matches();
|
||||
}
|
||||
|
||||
private void showPickerView() {// 弹出选择器(省市区三级联动)
|
||||
OptionsPickerView pvOptions = new OptionsPickerBuilder(UserActivity.this, new OnOptionsSelectListener() {
|
||||
@Override
|
||||
public void onOptionsSelect(int options1, int options2, int options3, View v) {
|
||||
//返回的分别是三个级别的选中位置
|
||||
//返回的分别是三个级别的选中位置
|
||||
String opt1tx = options1Items.size() > 0 ?
|
||||
options1Items.get(options1).getPickerViewText() : "";
|
||||
|
||||
String opt2tx = options2Items.size() > 0
|
||||
&& options2Items.get(options1).size() > 0 ?
|
||||
options2Items.get(options1).get(options2) : "";
|
||||
|
||||
String opt3tx = options2Items.size() > 0
|
||||
&& options3Items.get(options1).size() > 0
|
||||
&& options3Items.get(options1).get(options2).size() > 0 ?
|
||||
options3Items.get(options1).get(options2).get(options3) : "";
|
||||
String region_id = cityItems.get(options1).get(options2).get(options3).getRegion_id();
|
||||
Toast.makeText(UserActivity.this, region_id, Toast.LENGTH_SHORT).show();
|
||||
String tx = opt1tx + " " + opt2tx + " " + opt3tx;
|
||||
region.setText(tx);
|
||||
}
|
||||
}).setSubmitText("确定")//确定按钮文字
|
||||
.setCancelText("取消")//取消按钮文字
|
||||
.setTitleText("城市选择")//标题
|
||||
.setSubCalSize(18)//确定和取消文字大小
|
||||
.setTitleSize(20)//标题文字大小
|
||||
.setTitleColor(Color.BLACK)//标题文字颜色
|
||||
.setSubmitColor(Color.parseColor("#2196F3"))//确定按钮文字颜色
|
||||
.setCancelColor(Color.parseColor("#2196F3"))//取消按钮文字颜色
|
||||
.setContentTextSize(18)//滚轮文字大小
|
||||
.setLabels("", "", "")//设置选择的三级单位
|
||||
.setCyclic(false, false, false)//循环与否
|
||||
.setSelectOptions(0, 0, 0) //设置默认选中项
|
||||
.setOutSideCancelable(false)//点击外部dismiss default true
|
||||
.build();
|
||||
/*pvOptions.setPicker(options1Items);//一级选择器
|
||||
pvOptions.setPicker(options1Items, options2Items);//二级选择器*/
|
||||
pvOptions.setPicker(options1Items, options2Items, options3Items);//三级选择器
|
||||
pvOptions.show();
|
||||
}
|
||||
|
||||
|
||||
private void initJsonData() {//解析数据 (省市区三级联动)
|
||||
/**
|
||||
* 注意:assets 目录下的Json文件仅供参考,实际使用可自行替换文件
|
||||
* 关键逻辑在于循环体
|
||||
*
|
||||
* */
|
||||
String JsonData = new GetJsonDataUtil().getJson(UserActivity.this, "prov_city_county.json");//获取assets目录下的json文件数据
|
||||
|
||||
ArrayList<JsonBean> jsonBean = parseData(JsonData);//用Gson 转成实体
|
||||
|
||||
/**
|
||||
* 添加省份数据
|
||||
*
|
||||
* 注意:如果是添加的JavaBean实体,则实体类需要实现 IPickerViewData 接口,
|
||||
* PickerView会通过getPickerViewText方法获取字符串显示出来。
|
||||
*/
|
||||
options1Items = jsonBean;
|
||||
|
||||
for (int i = 0; i < jsonBean.size(); i++) {//遍历省份
|
||||
ArrayList<String> CityList = new ArrayList<>();//该省的城市列表(第二级)
|
||||
ArrayList<ArrayList<CityBean>> city_AreaList = new ArrayList<>();//该省的所有地区列表(第三级)
|
||||
ArrayList<ArrayList<String>> Province_AreaList = new ArrayList<>();//该省的所有地区列表(第三级)
|
||||
|
||||
for (int c = 0; c < jsonBean.get(i).getCitys().size(); c++) {//遍历该省份的所有城市
|
||||
String CityName = jsonBean.get(i).getCitys().get(c).getCity();
|
||||
CityList.add(CityName);//添加城市
|
||||
ArrayList<CityBean> AreaList = new ArrayList<>();//该城市的所有地区列表
|
||||
ArrayList<String> City_AreaList = new ArrayList<>();//该城市的所有地区列表
|
||||
|
||||
//如果无地区数据,建议添加空字符串,防止数据为null 导致三个选项长度不匹配造成崩溃
|
||||
if (jsonBean.get(i).getCitys().get(c).getCounties() == null
|
||||
|| jsonBean.get(i).getCitys().get(c).getCounties().size() == 0) {
|
||||
AreaList.add(new CityBean("", ""));
|
||||
City_AreaList.add("");
|
||||
} else {
|
||||
for (int j = 0; j < jsonBean.get(i).getCitys().get(c).getCounties().size(); j++) {
|
||||
AreaList.add(new CityBean(jsonBean.get(i).getCitys().get(c).getCounties().get(j).getName(), jsonBean.get(i).getCitys().get(c).getCounties().get(j).getRegion_id()));
|
||||
City_AreaList.add(jsonBean.get(i).getCitys().get(c).getCounties().get(j).getName());
|
||||
}
|
||||
|
||||
}
|
||||
Province_AreaList.add(City_AreaList);//添加该省所有地区数据
|
||||
city_AreaList.add(AreaList);//添加该省所有地区数据的bean
|
||||
}
|
||||
/**
|
||||
* 添加城市数据
|
||||
*/
|
||||
options2Items.add(CityList);
|
||||
/**
|
||||
* 添加地区数据
|
||||
*/
|
||||
options3Items.add(Province_AreaList);
|
||||
cityItems.add(city_AreaList);
|
||||
}
|
||||
}
|
||||
|
||||
public ArrayList<JsonBean> parseData(String result) {//Gson 解析
|
||||
ArrayList<JsonBean> detail = new ArrayList<>();
|
||||
try {
|
||||
JSONArray data = new JSONArray(result);
|
||||
Gson gson = new Gson();
|
||||
for (int i = 0; i < data.length(); i++) {
|
||||
JsonBean entity = gson.fromJson(data.optJSONObject(i).toString(), JsonBean.class);
|
||||
detail.add(entity);
|
||||
}
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
return detail;
|
||||
}
|
||||
|
||||
}
|
68
app/src/main/java/com/navinfo/outdoor/bean/ArrayBean.java
Normal file
68
app/src/main/java/com/navinfo/outdoor/bean/ArrayBean.java
Normal file
@ -0,0 +1,68 @@
|
||||
package com.navinfo.outdoor.bean;
|
||||
|
||||
import com.contrarywind.interfaces.IPickerViewData;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public class ArrayBean implements IPickerViewData {
|
||||
|
||||
|
||||
/**
|
||||
* name : 省份
|
||||
* city : [{"name":"北京市","area":["东城区","西城区","崇文区","宣武区","朝阳区"]}]
|
||||
*/
|
||||
|
||||
private String name;
|
||||
private List<CityBean> city;
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
|
||||
public void setName(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public List<CityBean> getCityList() {
|
||||
return city;
|
||||
}
|
||||
|
||||
public void setCityList(List<CityBean> city) {
|
||||
this.city = city;
|
||||
}
|
||||
|
||||
// 实现 IPickerViewData 接口,
|
||||
// 这个用来显示在PickerView上面的字符串,
|
||||
// PickerView会通过IPickerViewData获取getPickerViewText方法显示出来。
|
||||
@Override
|
||||
public String getPickerViewText() {
|
||||
return this.name;
|
||||
}
|
||||
|
||||
|
||||
public static class CityBean {
|
||||
/**
|
||||
* name : 城市
|
||||
* area : ["东城区","西城区","崇文区","昌平区"]
|
||||
*/
|
||||
|
||||
private String name;
|
||||
private List<String> area;
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
|
||||
public void setName(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public List<String> getArea() {
|
||||
return area;
|
||||
}
|
||||
|
||||
public void setArea(List<String> area) {
|
||||
this.area = area;
|
||||
}
|
||||
}
|
||||
}
|
32
app/src/main/java/com/navinfo/outdoor/bean/CityBean.java
Normal file
32
app/src/main/java/com/navinfo/outdoor/bean/CityBean.java
Normal file
@ -0,0 +1,32 @@
|
||||
package com.navinfo.outdoor.bean;
|
||||
|
||||
public class CityBean {
|
||||
/**
|
||||
* name : 临翔区
|
||||
* region_id : 530902
|
||||
*/
|
||||
|
||||
private String name;
|
||||
private String region_id;
|
||||
|
||||
public CityBean(String name, String region_id) {
|
||||
this.name = name;
|
||||
this.region_id = region_id;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
|
||||
public void setName(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getRegion_id() {
|
||||
return region_id;
|
||||
}
|
||||
|
||||
public void setRegion_id(String region_id) {
|
||||
this.region_id = region_id;
|
||||
}
|
||||
}
|
88
app/src/main/java/com/navinfo/outdoor/bean/JsonBean.java
Normal file
88
app/src/main/java/com/navinfo/outdoor/bean/JsonBean.java
Normal file
File diff suppressed because one or more lines are too long
@ -14,13 +14,8 @@ import com.navinfo.outdoor.base.BaseFragment;
|
||||
*/
|
||||
public class ForgetPawFragment extends BaseFragment implements View.OnClickListener{
|
||||
private ImageView ivFinish;
|
||||
private TextView title;
|
||||
private EditText etForgetPawPhone;
|
||||
private EditText etForgetPawNote;
|
||||
private EditText etForgetPawPaw;
|
||||
private EditText etForgetPawConfirmPaw;
|
||||
private TextView tvForgetPaw;
|
||||
private TextView forgetPawGetNote;
|
||||
private TextView title,tvForgetPaw, forgetPawGetNote;
|
||||
private EditText etForgetPawPhone, etForgetPawNote, etForgetPawPaw, etForgetPawConfirmPaw;
|
||||
|
||||
@Override
|
||||
protected int getLayout() {
|
||||
@ -37,11 +32,8 @@ public class ForgetPawFragment extends BaseFragment implements View.OnClickListe
|
||||
etForgetPawConfirmPaw = findViewById(R.id.et_forgetPaw_confirm_paw);
|
||||
forgetPawGetNote = findViewById(R.id.forgetPaw_get_note);
|
||||
tvForgetPaw = findViewById(R.id.tv_forgetPaw);
|
||||
|
||||
ivFinish.setOnClickListener(this::onClick);
|
||||
forgetPawGetNote.setOnClickListener(this::onClick);
|
||||
|
||||
|
||||
ivFinish.setOnClickListener(this);
|
||||
forgetPawGetNote.setOnClickListener(this);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -13,8 +13,7 @@ import com.navinfo.outdoor.base.BaseFragment;
|
||||
*/
|
||||
public class GatheringFragment extends BaseFragment implements View.OnClickListener {
|
||||
|
||||
private ImageView ivGathering;
|
||||
private ImageView imageBank;
|
||||
private ImageView ivGathering, imageBank;
|
||||
private Button btnBank;
|
||||
private TextView tvBank;
|
||||
|
||||
@ -45,7 +44,6 @@ public class GatheringFragment extends BaseFragment implements View.OnClickListe
|
||||
getActivity().finish();
|
||||
break;
|
||||
case R.id.iv_bank:
|
||||
break;
|
||||
case R.id.btn_bank:
|
||||
break;
|
||||
}
|
||||
|
@ -62,7 +62,6 @@ public class IssueFragment extends BaseFragment implements View.OnClickListener
|
||||
issueProblemAdapter.setExplainList(taskExplainInfo.getBody().getData());
|
||||
Log.d("TAG", "onSuccess: " + taskExplainInfo.getMsg() + "");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onError(Throwable e, int id) {
|
||||
dismissLoadingDialog();
|
||||
@ -91,19 +90,19 @@ public class IssueFragment extends BaseFragment implements View.OnClickListener
|
||||
mainIssueRecycler.setLoadingListener(new XRecyclerView.LoadingListener() {
|
||||
@Override
|
||||
public void onRefresh() {}
|
||||
|
||||
@Override
|
||||
public void onLoadMore() {}
|
||||
});
|
||||
|
||||
issueProblemAdapter.setOnIssueClick(new IssueProblemAdapter.OnIssueClick() {
|
||||
@Override
|
||||
public void onClick(int pos) {
|
||||
Intent iissueWeb = new Intent(getActivity(), FragmentManagement.class);
|
||||
iissueWeb.putExtra("tag",27);
|
||||
startActivity(iissueWeb);
|
||||
Intent issueWeb = new Intent(getActivity(), FragmentManagement.class);
|
||||
issueWeb.putExtra("tag",16);
|
||||
startActivity(issueWeb);
|
||||
}
|
||||
});
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -41,7 +41,7 @@ public class IssueWebFragment extends BaseFragment implements View.OnClickListen
|
||||
@Override
|
||||
protected void initView() {
|
||||
super.initView();
|
||||
ivIssueWebFinish = (ImageView) findViewById(R.id.iv_issueWeb_finish);
|
||||
ivIssueWebFinish = findViewById(R.id.iv_issueWeb_finish);
|
||||
issueWebView = (WebView) findViewById(R.id.issue_webView);
|
||||
ivIssueWebFinish.setOnClickListener(this::onClick);
|
||||
issueWebView.getSettings().setBlockNetworkImage(false);
|
||||
|
@ -13,6 +13,7 @@ import com.bumptech.glide.load.resource.bitmap.CircleCrop;
|
||||
import com.bumptech.glide.request.RequestOptions;
|
||||
import com.navinfo.outdoor.R;
|
||||
import com.navinfo.outdoor.activity.FragmentManagement;
|
||||
import com.navinfo.outdoor.activity.UserActivity;
|
||||
import com.navinfo.outdoor.base.BaseFragment;
|
||||
|
||||
/**
|
||||
@ -67,7 +68,6 @@ public class MineFragment extends BaseFragment implements View.OnClickListener{
|
||||
@Override
|
||||
protected void initData() {
|
||||
super.initData();
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -75,7 +75,7 @@ public class MineFragment extends BaseFragment implements View.OnClickListener{
|
||||
switch (v.getId()){
|
||||
case R.id.image_heard:
|
||||
case R.id.tv_name://跳转到个人信息
|
||||
Intent intentUser = new Intent(getActivity(), FragmentManagement.class);
|
||||
Intent intentUser = new Intent(getActivity(), UserActivity.class);
|
||||
intentUser.putExtra("tag",16);
|
||||
startActivity(intentUser);
|
||||
break;
|
||||
@ -86,6 +86,7 @@ public class MineFragment extends BaseFragment implements View.OnClickListener{
|
||||
Toast.makeText(getActivity(), "签到", Toast.LENGTH_SHORT).show();
|
||||
break;
|
||||
case R.id.btn_withdraw://提现页面
|
||||
|
||||
Intent intentWithdraw = new Intent(getActivity(), FragmentManagement.class);
|
||||
intentWithdraw.putExtra("tag",15);
|
||||
startActivity(intentWithdraw);
|
||||
|
@ -16,16 +16,9 @@ import com.navinfo.outdoor.base.BaseFragment;
|
||||
public class RegisterFragment extends BaseFragment implements View.OnClickListener{
|
||||
|
||||
|
||||
private EditText etRegisterPhone;
|
||||
private EditText etRegisterNote;
|
||||
private TextView registerGetNote;
|
||||
private EditText etRegisterReferrer;
|
||||
private EditText etRegisterPaw;
|
||||
private EditText etRegisterConfirmPaw;
|
||||
private ImageView ivRegisterCheck;
|
||||
private TextView haveGoLogin;
|
||||
private TextView tvRegister;
|
||||
private ImageView ivFinish;
|
||||
private EditText etRegisterPhone, etRegisterNote, etRegisterReferrer, etRegisterPaw, etRegisterConfirmPaw;
|
||||
private ImageView ivRegisterCheck,ivFinish;
|
||||
private TextView haveGoLogin, tvRegister,registerGetNote;
|
||||
|
||||
|
||||
@Override
|
||||
@ -48,7 +41,6 @@ public class RegisterFragment extends BaseFragment implements View.OnClickListen
|
||||
tvRegister =findViewById(R.id.tv_register);
|
||||
ivFinish.setOnClickListener(this::onClick);
|
||||
haveGoLogin.setOnClickListener(this::onClick);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
@ -1,7 +1,14 @@
|
||||
package com.navinfo.outdoor.fragment;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.SharedPreferences;
|
||||
import android.view.View;
|
||||
import android.widget.CompoundButton;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.Switch;
|
||||
import android.widget.Toast;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
|
||||
import com.navinfo.outdoor.R;
|
||||
import com.navinfo.outdoor.base.BaseFragment;
|
||||
@ -9,9 +16,21 @@ import com.navinfo.outdoor.base.BaseFragment;
|
||||
/**
|
||||
* 设置页面的fragment
|
||||
*/
|
||||
public class SetFragment extends BaseFragment implements View.OnClickListener{
|
||||
public class SetFragment extends BaseFragment implements View.OnClickListener {
|
||||
|
||||
private ImageView ivSet;
|
||||
private Switch switchTrafficRemind;
|
||||
private Switch switchInform;
|
||||
private Switch switchAutoSave;
|
||||
private Switch switchRealUpload;
|
||||
private SharedPreferences.Editor navInfoEditor;
|
||||
private SharedPreferences navInfo;
|
||||
|
||||
@Override
|
||||
public void onAttach(@NonNull Context context) {
|
||||
super.onAttach(context);
|
||||
navInfoEditor = context.getSharedPreferences("navInfo", Context.MODE_PRIVATE).edit();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected int getLayout() {
|
||||
@ -21,18 +40,60 @@ public class SetFragment extends BaseFragment implements View.OnClickListener{
|
||||
@Override
|
||||
protected void initData() {
|
||||
super.initData();
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void initView() {
|
||||
super.initView();
|
||||
navInfo = getActivity().getSharedPreferences("navInfo", Context.MODE_PRIVATE);
|
||||
ivSet = findViewById(R.id.iv_set);
|
||||
ivSet.setOnClickListener(this);
|
||||
switchRealUpload = findViewById(R.id.switch_real_upload);
|
||||
switchRealUpload.setChecked(navInfo.getBoolean("switchRealUpload", false));
|
||||
switchRealUpload.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
|
||||
@Override
|
||||
public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
|
||||
//控制开关字体颜色
|
||||
navInfoEditor.putBoolean("switchRealUpload", b);
|
||||
navInfoEditor.commit();
|
||||
}
|
||||
});
|
||||
switchAutoSave = findViewById(R.id.switch_autosave);
|
||||
switchAutoSave.setChecked(navInfo.getBoolean("switchAutoSave", false));
|
||||
switchAutoSave.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
|
||||
@Override
|
||||
public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
|
||||
//控制开关字体颜色
|
||||
navInfoEditor.putBoolean("switchAutoSave", b);
|
||||
navInfoEditor.commit();
|
||||
}
|
||||
});
|
||||
switchInform = findViewById(R.id.switch_inform);
|
||||
switchInform.setChecked(navInfo.getBoolean("switchInform", false));
|
||||
switchInform.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
|
||||
@Override
|
||||
public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
|
||||
//控制开关字体颜色
|
||||
navInfoEditor.putBoolean("switchInform", b);
|
||||
navInfoEditor.commit();
|
||||
}
|
||||
});
|
||||
switchTrafficRemind = findViewById(R.id.switch_traffic_remind);
|
||||
switchTrafficRemind.setChecked(navInfo.getBoolean("switchTrafficRemind", false));
|
||||
switchTrafficRemind.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
|
||||
@Override
|
||||
public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
|
||||
//控制开关字体颜色
|
||||
navInfoEditor.putBoolean("switchTrafficRemind", b);
|
||||
navInfoEditor.commit();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
switch (v.getId()){
|
||||
switch (v.getId()) {
|
||||
case R.id.iv_set:
|
||||
getActivity().finish();
|
||||
break;
|
||||
|
@ -1,190 +0,0 @@
|
||||
package com.navinfo.outdoor.fragment;
|
||||
|
||||
import android.content.Intent;
|
||||
import android.text.TextUtils;
|
||||
import android.util.Log;
|
||||
import android.view.View;
|
||||
import android.widget.Button;
|
||||
import android.widget.EditText;
|
||||
import android.widget.ImageView;
|
||||
import android.widget.RelativeLayout;
|
||||
import android.widget.TextView;
|
||||
import android.widget.Toast;
|
||||
|
||||
import com.airsaid.pickerviewlibrary.CityPickerView;
|
||||
import com.airsaid.pickerviewlibrary.listener.OnSimpleCitySelectListener;
|
||||
import com.navinfo.outdoor.R;
|
||||
import com.navinfo.outdoor.activity.FragmentManagement;
|
||||
import com.navinfo.outdoor.base.BaseFragment;
|
||||
import com.navinfo.outdoor.util.RegexUtil;
|
||||
|
||||
import java.util.Scanner;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
/**
|
||||
* 用户资料的fragment
|
||||
*/
|
||||
public class UserDataFragment extends BaseFragment implements View.OnClickListener {
|
||||
|
||||
private Button btnGathering;
|
||||
private Button btnAttestation;
|
||||
private ImageView ivUser;
|
||||
private TextView region;
|
||||
private EditText etPhone;
|
||||
private EditText etQq;
|
||||
private EditText etMailbox;
|
||||
public static Pattern compile = Pattern.compile("/^[_a-z0-9-]+(\\.[_a-z0-9-]+)*@[a-z0-9-]+(\\.[a-z0-9-]+)*(\\.[a-z]{2,})$/");
|
||||
private Button userSave;
|
||||
private RelativeLayout rlRegion;
|
||||
|
||||
@Override
|
||||
protected int getLayout() {
|
||||
return R.layout.user_data_fragment;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void initData() {
|
||||
super.initData();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void initView() {
|
||||
super.initView();
|
||||
ivUser = findViewById(R.id.iv_user);
|
||||
ivUser.setOnClickListener(this::onClick);
|
||||
btnAttestation = findViewById(R.id.btn_attestation);
|
||||
btnAttestation.setOnClickListener(this::onClick);
|
||||
btnGathering = findViewById(R.id.btn_gathering);
|
||||
btnGathering.setOnClickListener(this::onClick);
|
||||
region = findViewById(R.id.region);
|
||||
rlRegion = findViewById(R.id.rl_region);
|
||||
rlRegion.setOnClickListener(this::onClick);
|
||||
etPhone = (EditText) findViewById(R.id.et_phone);
|
||||
etPhone.setOnClickListener(this::onClick);
|
||||
etQq = (EditText) findViewById(R.id.edit_qq);
|
||||
etQq.setOnClickListener(this::onClick);
|
||||
etMailbox = (EditText) findViewById(R.id.edit_mailbox);
|
||||
etMailbox.setOnClickListener(this::onClick);
|
||||
userSave = (Button) findViewById(R.id.btn_save);
|
||||
userSave.setOnClickListener(this::onClick);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void onClick(View v) {
|
||||
switch (v.getId()) {
|
||||
case R.id.iv_user:
|
||||
getActivity().finish();
|
||||
break;
|
||||
case R.id.btn_gathering:
|
||||
Intent gatheringIntent = new Intent(getActivity(), FragmentManagement.class);
|
||||
gatheringIntent.putExtra("tag", 24);
|
||||
startActivity(gatheringIntent);
|
||||
break;
|
||||
case R.id.btn_attestation:
|
||||
Intent attestationIntent = new Intent(getActivity(), FragmentManagement.class);
|
||||
attestationIntent.putExtra("tag", 25);
|
||||
startActivity(attestationIntent);
|
||||
break;
|
||||
case R.id.rl_region:
|
||||
initRegion();
|
||||
break;
|
||||
case R.id.et_phone:
|
||||
String phoneEt = etPhone.getText().toString().trim();
|
||||
if (TextUtils.isEmpty(phoneEt)) {
|
||||
Toast.makeText(getActivity(), "请输入手机号", Toast.LENGTH_SHORT).show();
|
||||
return;
|
||||
}
|
||||
if (!RegexUtil.isPhone(phoneEt)) {
|
||||
Toast.makeText(getActivity(), "手机格式有误", Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
break;
|
||||
case R.id.edit_qq:
|
||||
qq();
|
||||
break;
|
||||
case R.id.edit_mailbox:
|
||||
if (isEmail(etMailbox.getText().toString().trim()) && etMailbox.getText().toString().trim().length() <= 31) {
|
||||
Toast.makeText(getActivity(), "邮箱验证成功", Toast.LENGTH_SHORT).show();
|
||||
} else {
|
||||
Toast.makeText(getActivity(), "邮箱格式错误", Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
break;
|
||||
case R.id.btn_save:
|
||||
final String userphone = etPhone.getText().toString().trim();
|
||||
final String userqq = etQq.getText().toString().trim();
|
||||
final String usermailbox = etMailbox.getText().toString().trim();
|
||||
if (!RegexUtil.isPhone(userphone)) {
|
||||
Toast.makeText(getActivity(), "手机号输入错误", Toast.LENGTH_SHORT).show();
|
||||
return;
|
||||
}
|
||||
if (userqq.length() > 11) {
|
||||
Toast.makeText(getActivity(), "QQ号输入错误", Toast.LENGTH_SHORT).show();
|
||||
return;
|
||||
}
|
||||
if (usermailbox.length() > 31) {
|
||||
Toast.makeText(getActivity(), "邮箱输入错误", Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
private static String qq() {
|
||||
|
||||
String qq = "23412312";
|
||||
String regex = "[1-9][0-9]{4,11}";
|
||||
boolean flag = qq.matches(regex);
|
||||
if (flag) {
|
||||
System.out.println("输入正确!!");
|
||||
} else {
|
||||
System.out.println("输入正确!!");
|
||||
}
|
||||
return qq();
|
||||
|
||||
}
|
||||
|
||||
public static boolean isEmail(String email) {
|
||||
if (null == email || "".equals(email)) return false;
|
||||
Matcher m = compile.matcher(email);
|
||||
return m.matches();
|
||||
}
|
||||
|
||||
private void initRegion() {
|
||||
CityPickerView mCityPickerView = new CityPickerView(getContext());
|
||||
// 设置点击外部是否消失
|
||||
mCityPickerView.setCancelable(true);
|
||||
// 设置滚轮字体大小
|
||||
// mCityPickerView.setTextSize(18f);
|
||||
// 设置标题
|
||||
//mCityPickerView.setTitle("");
|
||||
// 设置取消文字
|
||||
// mCityPickerView.setCancelText("取消");
|
||||
// 设置取消文字颜色
|
||||
// mCityPickerView.setCancelTextColor(Color.WHITE);
|
||||
// 设置取消文字大小
|
||||
//mCityPickerView.setCancelTextSize(14f);
|
||||
// 设置确定文字
|
||||
//mCityPickerView.setSubmitText("确定");
|
||||
// 设置确定文字颜色
|
||||
//mCityPickerView.setSubmitTextColor(Color.WHITE);
|
||||
// 设置确定文字大小
|
||||
// mCityPickerView.setSubmitTextSize(14f);
|
||||
// 设置头部背景
|
||||
// mCityPickerView.setHeadBackgroundColor(Color.BLUE);
|
||||
mCityPickerView.setOnCitySelectListener(new OnSimpleCitySelectListener(){
|
||||
@Override
|
||||
public void onCitySelect(String prov, String city, String area) {
|
||||
// 省、市、区 分开获取
|
||||
Log.d("TAG", "省: " + prov + " 市: " + city + " 区: " + area);
|
||||
region.setText(prov+"-"+city+"-"+area+"");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCitySelect(String str) {
|
||||
// 一起获取
|
||||
//Toast.makeText(getContext(), "选择了:" + str, Toast.LENGTH_SHORT).show();
|
||||
}
|
||||
});
|
||||
mCityPickerView.show();
|
||||
}
|
||||
}
|
@ -7,7 +7,7 @@ public class HttpInterface {
|
||||
//发现:测试接口
|
||||
public static final String listTask = IP1 + "task/list";//任务专区
|
||||
public static final String listEvent = IP1 + "task/list";//活动专区
|
||||
public static final String listTaskExplain = IP1 + "task/info";//任务说明
|
||||
public static final String listTaskExplain = IP1 + "task/info";//任务说明
|
||||
public static final String MSG_LISt = IPm4 + "msg_list";//发现查询接口
|
||||
public static final String MSG_CONTENT = IPm4 + "msg_content";//发现 -富文本详情页请求
|
||||
public static final String EXAM_CONTENT = IPm4 + "exam_content";//发现 -能力测评获取试题接口
|
||||
|
@ -0,0 +1,38 @@
|
||||
package com.navinfo.outdoor.util;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.res.AssetManager;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStreamReader;
|
||||
|
||||
/**
|
||||
* <读取Json文件的工具类>
|
||||
*
|
||||
* @author: 小嵩
|
||||
* @date: 2017/3/16 16:22
|
||||
|
||||
*/
|
||||
|
||||
public class GetJsonDataUtil {
|
||||
|
||||
|
||||
public String getJson(Context context, String fileName) {
|
||||
|
||||
StringBuilder stringBuilder = new StringBuilder();
|
||||
try {
|
||||
AssetManager assetManager = context.getAssets();
|
||||
BufferedReader bf = new BufferedReader(new InputStreamReader(
|
||||
assetManager.open(fileName)));
|
||||
String line;
|
||||
while ((line = bf.readLine()) != null) {
|
||||
stringBuilder.append(line);
|
||||
}
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
return stringBuilder.toString();
|
||||
}
|
||||
}
|
||||
|
@ -46,6 +46,8 @@
|
||||
android:layout_height="wrap_content"
|
||||
android:background="@color/white"
|
||||
android:orientation="vertical"
|
||||
app:layout_constraintEnd_toEndOf="parent"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintTop_toBottomOf="@+id/view1">
|
||||
|
||||
<ImageView
|
||||
@ -88,6 +90,8 @@
|
||||
android:background="@color/white"
|
||||
android:orientation="vertical"
|
||||
app:layout_constraintBottom_toBottomOf="parent"
|
||||
app:layout_constraintEnd_toEndOf="parent"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintTop_toBottomOf="@+id/view2">
|
||||
|
||||
<RelativeLayout
|
||||
|
284
app/src/main/res/layout/activity_user.xml
Normal file
284
app/src/main/res/layout/activity_user.xml
Normal file
@ -0,0 +1,284 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<androidx.constraintlayout.widget.ConstraintLayout
|
||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent">
|
||||
<LinearLayout
|
||||
android:id="@+id/rl_user"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:background="#1BA5F1"
|
||||
android:paddingTop="@dimen/top_pind_sp"
|
||||
android:orientation="horizontal"
|
||||
app:layout_constraintEnd_toEndOf="parent"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintTop_toTopOf="parent">
|
||||
|
||||
<ImageView
|
||||
android:id="@+id/iv_user"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="45dp"
|
||||
android:layout_alignParentLeft="true"
|
||||
android:layout_marginLeft="15dp"
|
||||
android:src="@drawable/icon_arrow"
|
||||
/>
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tv_user"
|
||||
android:layout_width="wrap_content"
|
||||
style="@style/text_style_toolbar_title"
|
||||
android:layout_toRightOf="@id/iv_find_task"
|
||||
android:text="用户资料" />
|
||||
</LinearLayout>
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tv_title"
|
||||
style="@style/text_style"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="账号信息"
|
||||
android:layout_margin="20dp"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintBottom_toTopOf="@id/linearLayout"
|
||||
app:layout_constraintTop_toBottomOf="@+id/rl_user" />
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/linearLayout"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="480dp"
|
||||
android:layout_marginLeft="20dp"
|
||||
android:layout_marginTop="20dp"
|
||||
android:layout_marginRight="20dp"
|
||||
android:background="#fff"
|
||||
android:orientation="vertical"
|
||||
app:layout_constraintEnd_toEndOf="parent"
|
||||
app:layout_constraintStart_toStartOf="parent"
|
||||
app:layout_constraintTop_toBottomOf="@id/tv_title">
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0dp"
|
||||
android:layout_weight="1"
|
||||
android:gravity="center_vertical">
|
||||
|
||||
<TextView
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="实名认证"
|
||||
android:layout_marginLeft="20dp"
|
||||
android:layout_centerVertical="true"
|
||||
style="@style/user_text_style" />
|
||||
<Button
|
||||
android:id="@+id/btn_attestation"
|
||||
style="@style/user_style"
|
||||
android:layout_width="70dp"
|
||||
android:layout_height="30dp"
|
||||
android:layout_alignParentRight="true"
|
||||
android:layout_marginRight="10dp"
|
||||
android:text="去认证"
|
||||
android:textColor="#fff" />
|
||||
|
||||
</RelativeLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="#F1F0F0" />
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0dp"
|
||||
android:layout_weight="1"
|
||||
android:gravity="center_vertical">
|
||||
|
||||
<TextView
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="收款信息"
|
||||
android:layout_marginLeft="20dp"
|
||||
android:layout_centerVertical="true"
|
||||
style="@style/user_text_style"
|
||||
/>
|
||||
<Button
|
||||
android:id="@+id/btn_gathering"
|
||||
android:layout_width="70dp"
|
||||
android:layout_height="30dp"
|
||||
android:layout_alignParentRight="true"
|
||||
android:layout_marginRight="10dp"
|
||||
android:text="去绑定"
|
||||
android:textColor="#fff"
|
||||
style="@style/user_style"
|
||||
android:layout_centerVertical="true"
|
||||
/>
|
||||
</RelativeLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="#F1F0F0" />
|
||||
|
||||
<LinearLayout
|
||||
android:id="@+id/ll_region"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0dp"
|
||||
android:layout_weight="1"
|
||||
android:gravity="center_vertical">
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tv_region"
|
||||
android:layout_width="80dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="所在地区*"
|
||||
android:layout_centerVertical="true"
|
||||
android:layout_marginLeft="20dp"
|
||||
style="@style/user_text_style"
|
||||
/>
|
||||
<TextView
|
||||
android:id="@+id/region"
|
||||
android:layout_toRightOf="@id/tv_region"
|
||||
android:layout_width="wrap_content"
|
||||
style="@style/user_hint_style"
|
||||
android:layout_centerVertical="true"
|
||||
android:hint="请选择所在区域"
|
||||
android:layout_height="wrap_content"
|
||||
/>
|
||||
</LinearLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="#F1F0F0" />
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0dp"
|
||||
android:layout_weight="1"
|
||||
android:gravity="center_vertical">
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tv_number"
|
||||
android:layout_width="80dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="手机号码*"
|
||||
android:layout_centerVertical="true"
|
||||
android:layout_marginLeft="20dp"
|
||||
style="@style/user_text_style"
|
||||
/>
|
||||
<EditText
|
||||
android:id="@+id/et_phone"
|
||||
android:layout_toRightOf="@id/tv_number"
|
||||
android:layout_width="wrap_content"
|
||||
style="@style/user_hint_style"
|
||||
android:layout_centerVertical="true"
|
||||
android:hint="请输入手机号码"
|
||||
android:layout_height="wrap_content"
|
||||
/>
|
||||
</RelativeLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="#F1F0F0" />
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0dp"
|
||||
android:layout_weight="1"
|
||||
android:gravity="center_vertical">
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tv_qq"
|
||||
android:layout_width="80dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="QQ号码*"
|
||||
android:layout_centerVertical="true"
|
||||
android:layout_marginLeft="20dp"
|
||||
style="@style/user_text_style"
|
||||
/>
|
||||
<EditText
|
||||
android:id="@+id/edit_qq"
|
||||
android:layout_toRightOf="@id/tv_qq"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_centerVertical="true"
|
||||
android:hint="请输入QQ号码 "
|
||||
style="@style/user_hint_style"
|
||||
android:layout_height="wrap_content"
|
||||
/>
|
||||
</RelativeLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="#F1F0F0" />
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0dp"
|
||||
android:layout_weight="1"
|
||||
android:gravity="center_vertical">
|
||||
|
||||
<TextView
|
||||
android:id="@+id/tv_mailbox"
|
||||
android:layout_width="80dp"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="电子邮箱*"
|
||||
android:layout_centerVertical="true"
|
||||
android:layout_marginLeft="20dp"
|
||||
style="@style/user_text_style"
|
||||
/>
|
||||
<EditText
|
||||
android:id="@+id/edit_mailbox"
|
||||
android:layout_toRightOf="@id/tv_mailbox"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_centerVertical="true"
|
||||
android:hint="请输入邮箱地址"
|
||||
style="@style/user_hint_style"
|
||||
android:layout_height="wrap_content"
|
||||
/>
|
||||
</RelativeLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="#F1F0F0" />
|
||||
|
||||
<RelativeLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0dp"
|
||||
android:layout_weight="1">
|
||||
|
||||
<TextView
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="微信"
|
||||
android:layout_marginLeft="20dp"
|
||||
android:layout_centerVertical="true"
|
||||
style="@style/user_text_style"
|
||||
/>
|
||||
<Button
|
||||
android:layout_width="70dp"
|
||||
android:layout_height="30dp"
|
||||
android:layout_alignParentRight="true"
|
||||
android:layout_marginRight="10dp"
|
||||
android:text="去绑定"
|
||||
android:textColor="#fff"
|
||||
style="@style/user_style"
|
||||
android:layout_centerVertical="true"
|
||||
/>
|
||||
</RelativeLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="1dp"
|
||||
android:background="#F1F0F0" />
|
||||
<Button
|
||||
android:id="@+id/btn_save"
|
||||
android:layout_marginTop="50dp"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="保存"
|
||||
style="@style/main_style"
|
||||
/>
|
||||
</LinearLayout>
|
||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
@ -127,7 +127,7 @@
|
||||
android:background="@null"
|
||||
android:textSize="16sp"
|
||||
android:layout_height="match_parent"
|
||||
android:hint="持卡人姓名" />
|
||||
android:hint="银行卡号 " />
|
||||
</LinearLayout>
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
|
@ -70,6 +70,7 @@
|
||||
android:textColor="#333"
|
||||
android:textSize="15sp" />
|
||||
<Switch
|
||||
android:id="@+id/switch_real_upload"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignParentRight="true"
|
||||
@ -99,6 +100,7 @@
|
||||
android:textColor="#333"
|
||||
android:textSize="15sp"/>
|
||||
<Switch
|
||||
android:id="@+id/switch_autosave"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignParentRight="true"
|
||||
@ -137,6 +139,7 @@
|
||||
android:textColor="#333"
|
||||
android:textSize="15sp" />
|
||||
<Switch
|
||||
android:id="@+id/switch_inform"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignParentRight="true"
|
||||
@ -166,6 +169,7 @@
|
||||
android:textColor="#333"
|
||||
android:textSize="15sp"/>
|
||||
<Switch
|
||||
android:id="@+id/switch_traffic_remind"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_alignParentRight="true"
|
||||
|
@ -118,11 +118,12 @@
|
||||
android:layout_height="1dp"
|
||||
android:background="#F1F0F0" />
|
||||
|
||||
<RelativeLayout
|
||||
android:id="@+id/rl_region"
|
||||
<LinearLayout
|
||||
android:id="@+id/ll_region"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="0dp"
|
||||
android:layout_weight="1"
|
||||
android:background="@drawable/underline"
|
||||
android:gravity="center_vertical">
|
||||
|
||||
<TextView
|
||||
@ -143,7 +144,7 @@
|
||||
android:hint="请选择所在区域"
|
||||
android:layout_height="wrap_content"
|
||||
/>
|
||||
</RelativeLayout>
|
||||
</LinearLayout>
|
||||
|
||||
<View
|
||||
android:layout_width="match_parent"
|
||||
|
BIN
navinfo.jks
Normal file
BIN
navinfo.jks
Normal file
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user