完成所在地区的弹窗

This commit is contained in:
wds 2021-06-03 18:15:05 +08:00
parent 3242c4861d
commit a2304731c3
34 changed files with 19748 additions and 457 deletions

1
.gitignore vendored
View File

@ -13,3 +13,4 @@
/captures
.externalNativeBuild
.cxx
app/release/

View File

@ -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
View File

@ -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>

View File

@ -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
View File

@ -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>

View File

@ -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
View File

@ -1,6 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="" vcs="Git" />
</component>
</project>

View File

@ -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')
}

View File

@ -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>

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -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;
}
}

View File

@ -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;

View File

@ -62,4 +62,7 @@ public class LoginActivity extends BaseActivity implements View.OnClickListener
break;
}
}
}

View 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;
}
}

View 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;
}
}
}

View 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;
}
}

File diff suppressed because one or more lines are too long

View File

@ -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

View File

@ -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;
}

View File

@ -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

View File

@ -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);

View File

@ -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);

View File

@ -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);
}

View File

@ -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;

View File

@ -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();
}
}

View File

@ -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";//发现 -能力测评获取试题接口

View File

@ -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();
}
}

View File

@ -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

View 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>

View File

@ -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"

View File

@ -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"

View File

@ -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

Binary file not shown.