如何在android中移动验证消息或密码切换
如果您查看图片,您可以看到验证图标干扰了passwordToggle图标。是否有方法移动验证图标或密码切换图标 注册活动如何在android中移动验证消息或密码切换,android,validation,passwords,toggle,Android,Validation,Passwords,Toggle,如果您查看图片,您可以看到验证图标干扰了passwordToggle图标。是否有方法移动验证图标或密码切换图标 注册活动 public class RegisterActivity extends AppCompatActivity { private static final String TAG = "RegisterActivity"; @InjectView(R.id.input_name) EditText _nameText; @InjectView(R.
public class RegisterActivity extends AppCompatActivity {
private static final String TAG = "RegisterActivity";
@InjectView(R.id.input_name) EditText _nameText;
@InjectView(R.id.input_email) EditText _emailText;
@InjectView(R.id.input_password) EditText _passwordText;
@InjectView(R.id.input_confirmPassword) EditText _confirmPasswordText;
@InjectView(R.id.btn_signup) Button _signupButton;
@InjectView(R.id.link_login) TextView _loginLink;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_register);
ButterKnife.inject(this);
_signupButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
signup();
}
});
_loginLink.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// Finish the registration screen and return to the Login activity
finish();
}
});
}
public void signup() {
Log.d(TAG, "Begin Signup process...");
if (!validate()) {
onSignupFailed();
return;
}
_signupButton.setEnabled(false);
final ProgressDialog signupProgressDialog = new ProgressDialog(RegisterActivity.this,
R.style.Theme_IAPTheme);
signupProgressDialog.setIndeterminate(true);
signupProgressDialog.setMessage("Creating Account...");
signupProgressDialog.show();
String name = _nameText.getText().toString();
String email = _emailText.getText().toString();
String password = _passwordText.getText().toString();
String confirmPassword = _confirmPasswordText.getText().toString();
// TODO: Implement your own signup logic here.
Response.Listener<String> responseListener = new Response.Listener<String>() {
@Override
public void onResponse(String response) {
try {
Log.i("tagconvertstr", "["+response+"]");
JSONObject jsonResponse = new JSONObject(response);
boolean success = jsonResponse.getBoolean("success");
if (success) {
onSignupSuccess();
} else {
onSignupFailed();
}
} catch (JSONException e) {
e.printStackTrace();
}
}
};
RegisterRequest registerRequest = new RegisterRequest(name, email, password, responseListener);
RequestQueue queue = Volley.newRequestQueue(RegisterActivity.this);
queue.add(registerRequest);
/*new android.os.Handler().postDelayed(
new Runnable() {
public void run() {
// On complete call either onSignupSuccess or onSignupFailed
// depending on success
onSignupSuccess();
// onSignupFailed();
progressDialog.dismiss();
}
}, 3000);*/
}
public void onSignupSuccess() {
Toast.makeText(getBaseContext(), "Signup Successful", Toast.LENGTH_LONG).show();
_signupButton.setEnabled(true);
setResult(RESULT_OK, null);
finish();
}
public void onSignupFailed() {
Toast.makeText(getBaseContext(), "Signup Failed", Toast.LENGTH_LONG).show();
_signupButton.setEnabled(true);
}
public boolean validate() {
boolean valid = true;
boolean psisequal;
String name = _nameText.getText().toString();
String email = _emailText.getText().toString();
String password = _passwordText.getText().toString();
String confirmPassword = _confirmPasswordText.getText().toString();
if (name.isEmpty() || name.length() < 3) {
_nameText.setError("at least 3 characters");
valid = false;
} else {
_nameText.setError(null);
}
if (email.isEmpty() || !android.util.Patterns.EMAIL_ADDRESS.matcher(email).matches()) {
_emailText.setError("enter a valid email address");
valid = false;
} else {
_emailText.setError(null);
}
if (password.isEmpty() || password.length() < 4 || password.length() > 10) {
_passwordText.setError("between 4 and 10 alphanumeric characters");
valid = false;
}else {
_passwordText.setError(null);
}
if (password.equals(confirmPassword)){
_confirmPasswordText.setError(null);
psisequal = true;
}else {
_confirmPasswordText.setError("passwords do not match");
valid = false;
psisequal = false;
}
return valid;
}
}
public class RegisterActivity extends AppCompatActivity {
private static final String TAG = "RegisterActivity";
@InjectView(R.id.input_name) EditText _nameText;
@InjectView(R.id.input_email) EditText _emailText;
@InjectView(R.id.input_password) EditText _passwordText;
@InjectView(R.id.fragment_login_password_visibility) ImageView _passwordToggle;
@InjectView(R.id.fragment_login_confirm_password_visibility) ImageView _confirmPasswordToggle;
@InjectView(R.id.input_confirmPassword) EditText _confirmPasswordText;
@InjectView(R.id.btn_signup) Button _signupButton;
@InjectView(R.id.link_login) TextView _loginLink;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_register);
ButterKnife.inject(this);
//_passwordToggle.setVisibility(View.GONE);
//_confirmPasswordToggle.setVisibility(View.GONE);
_signupButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
signup();
}
});
_loginLink.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// Finish the registration screen and return to the Login activity
finish();
}
});
//Code added HERE for handling the text change for the password icon, I decided not to make the icon disappear if there is no text in the input field but if you choose to do so then uncomment the functional code below.
_passwordText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
//_passwordToggle.setVisibility(s.length() > 0 ? View.VISIBLE : View.GONE);
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
//_passwordToggle.setVisibility(s.length() > 0 ? View.VISIBLE : View.GONE);
}
});
_passwordToggle.setOnTouchListener(mPasswordVisibleTouchListener);
_confirmPasswordText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
//_passwordToggle.setVisibility(s.length() > 0 ? View.VISIBLE : View.GONE);
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
//_confirmPasswordToggle.setVisibility(s.length() > 0 ? View.VISIBLE : View.GONE);
}
});
_confirmPasswordToggle.setOnTouchListener(mConfirmPasswordVisibleTouchListener);
}
private View.OnTouchListener mPasswordVisibleTouchListener = new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
final boolean isOutsideView = event.getX() < 0 ||
event.getX() > v.getWidth() ||
event.getY() < 0 ||
event.getY() > v.getHeight();
// change input type will reset cursor position, so we want to save it
final int cursor = _passwordText.getSelectionStart();
if (isOutsideView || MotionEvent.ACTION_UP == event.getAction())
_passwordText.setInputType( InputType.TYPE_CLASS_TEXT |
InputType.TYPE_TEXT_VARIATION_PASSWORD);
else
_passwordText.setInputType( InputType.TYPE_CLASS_TEXT |
InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);
_passwordText.setSelection(cursor);
return true;
}
};
private View.OnTouchListener mConfirmPasswordVisibleTouchListener = new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
final boolean isOutsideView = event.getX() < 0 ||
event.getX() > v.getWidth() ||
event.getY() < 0 ||
event.getY() > v.getHeight();
// change input type will reset cursor position, so we want to save it
final int cursor = _confirmPasswordText.getSelectionStart();
if (isOutsideView || MotionEvent.ACTION_UP == event.getAction())
_confirmPasswordText.setInputType( InputType.TYPE_CLASS_TEXT |
InputType.TYPE_TEXT_VARIATION_PASSWORD);
else
_confirmPasswordText.setInputType( InputType.TYPE_CLASS_TEXT |
InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);
_confirmPasswordText.setSelection(cursor);
return true;
}
};
//End of NEW code changes
public void signup() {
Log.d(TAG, "Begin Signup process...");
if (!validate()) {
onSignupFailed();
return;
}
_signupButton.setEnabled(false);
final ProgressDialog signupProgressDialog = new ProgressDialog(RegisterActivity.this,
R.style.Theme_IAPTheme);
signupProgressDialog.setIndeterminate(true);
signupProgressDialog.setMessage("Creating Account...");
signupProgressDialog.show();
String name = _nameText.getText().toString();
String email = _emailText.getText().toString();
String password = _passwordText.getText().toString();
String confirmPassword = _confirmPasswordText.getText().toString();
// TODO: Implement your own signup logic here.
Response.Listener<String> responseListener = new Response.Listener<String>() {
@Override
public void onResponse(String response) {
try {
Log.i("tagconvertstr", "["+response+"]");
JSONObject jsonResponse = new JSONObject(response);
boolean success = jsonResponse.getBoolean("success");
if (success) {
onSignupSuccess();
} else {
onSignupFailed();
}
} catch (JSONException e) {
e.printStackTrace();
}
}
};
RegisterRequest registerRequest = new RegisterRequest(name, email, password, responseListener);
RequestQueue queue = Volley.newRequestQueue(RegisterActivity.this);
queue.add(registerRequest);
/*new android.os.Handler().postDelayed(
new Runnable() {
public void run() {
// On complete call either onSignupSuccess or onSignupFailed
// depending on success
onSignupSuccess();
// onSignupFailed();
progressDialog.dismiss();
}
}, 3000);*/
}
public void onSignupSuccess() {
Toast.makeText(getBaseContext(), "Signup Successful", Toast.LENGTH_LONG).show();
_signupButton.setEnabled(true);
setResult(RESULT_OK, null);
finish();
}
public void onSignupFailed() {
Toast.makeText(getBaseContext(), "Signup Failed", Toast.LENGTH_LONG).show();
_signupButton.setEnabled(true);
}
public boolean validate() {
boolean valid = true;
Drawable errorIcon = getResources().getDrawable(R.drawable.eye);
errorIcon.setBounds(new Rect(0, 0, 100, 100));
String name = _nameText.getText().toString();
String email = _emailText.getText().toString();
String password = _passwordText.getText().toString();
String confirmPassword = _confirmPasswordText.getText().toString();
//Trainer Name validation
if (name.isEmpty() || name.length() < 3) {
_nameText.setError("enter at least 3 characters", errorIcon);
valid = false;
} else {
_nameText.setError(null);
}
//E-Mail validation
if (email.isEmpty() || !android.util.Patterns.EMAIL_ADDRESS.matcher(email).matches()) {
_emailText.setError("enter a valid email address");
valid = false;
} else {
_emailText.setError(null);
}
//Password validation
if (password.isEmpty() || password.length() < 4 || password.length() > 10) {
_passwordText.setError("between 4 and 20 alphanumeric characters");
valid = false;
}else {
_passwordText.setError(null);
}
//Confirm Password validation
if (password.equals(confirmPassword)){
_confirmPasswordText.setError(null);
}else {
_confirmPasswordText.setError("passwords do not match");
valid = false;
}
return valid;
}
}
公共类注册表活动扩展了AppCompatActivity{
私有静态最终字符串标记=“RegisterActivity”;
@InjectView(R.id.input_name)EditText_nameText;
@InjectView(R.id.input\u email)EditText\u emailText;
@InjectView(R.id.input_password)EditText_passwordText;
@InjectView(R.id.input_confirmPassword)EditText_confirmPasswordText;
@InjectView(R.id.btn_注册)按钮_注册按钮;
@InjectView(R.id.link\u login)TextView\u loginLink;
@凌驾
创建时的公共void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity\u寄存器);
注射(这个);
_signupButton.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
注册();
}
});
_loginLink.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
//完成注册屏幕并返回登录活动
完成();
}
});
}
公开无效注册(){
Log.d(标签“开始注册过程…”);
如果(!validate()){
onSignupFailed();
返回;
}
_signupButton.setEnabled(false);
final ProgressDialog SignUppressDialog=新建ProgressDialog(RegisterActivity.this,
R.风格、主题;
signupProgressDialog.setUndeterminate(true);
设置消息(“创建帐户…”);
signupProgressDialog.show();
字符串名称=_nameText.getText().toString();
字符串email=_emailText.getText().toString();
字符串密码=_passwordText.getText().toString();
字符串confirmPassword=\u confirmPasswordText.getText().toString();
//TODO:在这里实现您自己的注册逻辑。
Response.Listener responseListener=新的Response.Listener(){
@凌驾
公共void onResponse(字符串响应){
试一试{
Log.i(“tagconvertstr”,“[”+响应+“]”);
JSONObject jsonResponse=新的JSONObject(响应);
boolean success=jsonResponse.getBoolean(“success”);
如果(成功){
onSignupSuccess();
}否则{
onSignupFailed();
}
}捕获(JSONException e){
e、 printStackTrace();
}
}
};
RegisterRequest RegisterRequest=新的RegisterRequest(名称、电子邮件、密码、响应侦听器);
RequestQueue=Volley.newRequestQueue(RegisterActivity.this);
添加(registerRequest);
/*新的android.os.Handler().postDelayed(
新的Runnable(){
公开募捐{
//在完成调用时,onSignupSuccess或onSignupFailed
//取决于成功
onSignupSuccess();
//onSignupFailed();
progressDialog.disclose();
}
}, 3000);*/
}
public void onSignupSuccess(){
Toast.makeText(getBaseContext(),“注册成功”,Toast.LENGTH_LONG.show();
_signupButton.setEnabled(true);
setResult(RESULT_OK,null);
完成();
}
public void onSignupFailed(){
Toast.makeText(getBaseContext(),“注册失败”,Toast.LENGTH_LONG.show();
_signupButton.setEnabled(true);
}
公共布尔验证(){
布尔有效=真;
布尔幻觉;
字符串名称=_nameText.getText().toString();
字符串email=_emailText.getText().toString();
字符串密码=_passwordText.getText().toString();
字符串confirmPassword=\u confirmPasswordText.getText().toString();
if(name.isEmpty()| | name.length()<3){
_nameText.setError(“至少3个字符”);
有效=错误;
}否则{
_nameText.setError(null);
}
if(email.isEmpty()| | |!android.util.Patterns.email_ADDRESS.matcher(email.matches()){
_emailText.setError(“输入有效的电子邮件地址”);
有效=错误;
}否则{
_emailText.setError(空);
}
if(password.isEmpty()| | password.length()<4 | | password.length()>10){
_passwordText.setError(“4到10个字母数字字符之间”);
有效=错误;
}否则{
_passwordText.setError(null);
}
if(password.equals(confirmPassword)){
_confirmPasswordText.setError(null);
psisequal=真;
}否则{
_confirmPasswordText.setError(“密码不匹配”);
有效=错误;
psisequal=假;
}
返回有效;
}
}
活动登记簿
<?xml version="1.0" encoding="utf-8"?>
<ScrollView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:fitsSystemWindows="true"
android:background="@color/black">
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="56dp"
android:paddingLeft="24dp"
android:paddingRight="24dp">
<ImageView android:src="@drawable/logo"
android:layout_width="wrap_content"
android:layout_height="72dp"
android:layout_marginBottom="24dp"
android:layout_gravity="center_horizontal" />
<!-- Name Label -->
<android.support.design.widget.TextInputLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:layout_marginBottom="8dp"
android:textColor="#ffffff"
android:textColorHint="#ffffff">
<EditText android:id="@+id/input_name"
android:theme="@style/MyEditTextTheme"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:inputType="textCapWords"
android:hint="Trainer Name (Gamer Tag)" />
</android.support.design.widget.TextInputLayout>
<!-- Email Label -->
<android.support.design.widget.TextInputLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:layout_marginBottom="8dp"
android:textColor="#ffffff"
android:textColorHint="#ffffff">
<EditText android:id="@+id/input_email"
android:theme="@style/MyEditTextTheme"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:inputType="textEmailAddress"
android:hint="E-Mail Address" />
</android.support.design.widget.TextInputLayout>
<!-- Password Label -->
<android.support.design.widget.TextInputLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:layout_marginBottom="8dp"
android:textColor="#ffffff"
android:textColorHint="#ffffff">
<EditText android:id="@+id/input_password"
android:theme="@style/MyEditTextTheme"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:inputType="textPassword"
android:hint="Password"/>
</android.support.design.widget.TextInputLayout>
<!-- Confirm Password Label -->
<android.support.design.widget.TextInputLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:layout_marginBottom="8dp"
android:textColor="#ffffff"
android:textColorHint="#ffffff">
<EditText android:id="@+id/input_confirmPassword"
android:theme="@style/MyEditTextTheme"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:inputType="textPassword"
android:hint="Confirm Password"/>
</android.support.design.widget.TextInputLayout>
<!-- Signup Button -->
<android.support.v7.widget.AppCompatButton
android:id="@+id/btn_signup"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginTop="24dp"
android:layout_marginBottom="24dp"
android:padding="12dp"
android:text="Create Account"/>
<TextView android:id="@+id/link_login"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="24dp"
android:text="Already a member? Login"
android:textColor="#ffffff"
android:gravity="center"
android:textSize="16dip"/>
</LinearLayout>
</ScrollView>
弦
<resources xmlns:android="http://schemas.android.com/tools">
<string name="app_name">The World of Go</string>
<string name="title_activity_maps">Map</string>
<!--CODE FOR BUTTON OVERLAY-->
<string name="Popular"></string>
<string name="AZ"></string>
<string name="Category"></string>
<string name="NearBy"></string>
<color name="bg_color">#ffffff</color>
<color name="black">#222222</color>
<color name="white">#ffffff</color>
<style name="MyEditTextTheme">
<item name="colorControlNormal">#ffffff</item>
<item name="colorControlActivated">#ffffff</item>
<item name="colorControlHighlight">#ffffff</item>
<item name="colorAccent">@android:color/white</item>
<item name="android:textColor">#ffffff</item>
<item name="android:textColorHint">#ffffff</item> />
</style>
<string name="type_prompt">Choose a Type</string>
<string-array name="type_arrays">
<item>Pokestop</item>
<item>Gym</item>
</string-array>
</resources>
围棋世界
地图
#ffffff
#222222
#ffffff
#ffffff
#ffffff
#ffffff
@android:彩色/白色
#ffffff
#ffffff/>
选择一种类型
口袋
健身房
我不知道这是否是处理这个问题的唯一方法,但为了解决这个问题,我将布局从线性布局切换到网格布局,并添加了
public class RegisterActivity extends AppCompatActivity {
private static final String TAG = "RegisterActivity";
@InjectView(R.id.input_name) EditText _nameText;
@InjectView(R.id.input_email) EditText _emailText;
@InjectView(R.id.input_password) EditText _passwordText;
@InjectView(R.id.fragment_login_password_visibility) ImageView _passwordToggle;
@InjectView(R.id.fragment_login_confirm_password_visibility) ImageView _confirmPasswordToggle;
@InjectView(R.id.input_confirmPassword) EditText _confirmPasswordText;
@InjectView(R.id.btn_signup) Button _signupButton;
@InjectView(R.id.link_login) TextView _loginLink;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_register);
ButterKnife.inject(this);
//_passwordToggle.setVisibility(View.GONE);
//_confirmPasswordToggle.setVisibility(View.GONE);
_signupButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
signup();
}
});
_loginLink.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// Finish the registration screen and return to the Login activity
finish();
}
});
//Code added HERE for handling the text change for the password icon, I decided not to make the icon disappear if there is no text in the input field but if you choose to do so then uncomment the functional code below.
_passwordText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
//_passwordToggle.setVisibility(s.length() > 0 ? View.VISIBLE : View.GONE);
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
//_passwordToggle.setVisibility(s.length() > 0 ? View.VISIBLE : View.GONE);
}
});
_passwordToggle.setOnTouchListener(mPasswordVisibleTouchListener);
_confirmPasswordText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
//_passwordToggle.setVisibility(s.length() > 0 ? View.VISIBLE : View.GONE);
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
//_confirmPasswordToggle.setVisibility(s.length() > 0 ? View.VISIBLE : View.GONE);
}
});
_confirmPasswordToggle.setOnTouchListener(mConfirmPasswordVisibleTouchListener);
}
private View.OnTouchListener mPasswordVisibleTouchListener = new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
final boolean isOutsideView = event.getX() < 0 ||
event.getX() > v.getWidth() ||
event.getY() < 0 ||
event.getY() > v.getHeight();
// change input type will reset cursor position, so we want to save it
final int cursor = _passwordText.getSelectionStart();
if (isOutsideView || MotionEvent.ACTION_UP == event.getAction())
_passwordText.setInputType( InputType.TYPE_CLASS_TEXT |
InputType.TYPE_TEXT_VARIATION_PASSWORD);
else
_passwordText.setInputType( InputType.TYPE_CLASS_TEXT |
InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);
_passwordText.setSelection(cursor);
return true;
}
};
private View.OnTouchListener mConfirmPasswordVisibleTouchListener = new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
final boolean isOutsideView = event.getX() < 0 ||
event.getX() > v.getWidth() ||
event.getY() < 0 ||
event.getY() > v.getHeight();
// change input type will reset cursor position, so we want to save it
final int cursor = _confirmPasswordText.getSelectionStart();
if (isOutsideView || MotionEvent.ACTION_UP == event.getAction())
_confirmPasswordText.setInputType( InputType.TYPE_CLASS_TEXT |
InputType.TYPE_TEXT_VARIATION_PASSWORD);
else
_confirmPasswordText.setInputType( InputType.TYPE_CLASS_TEXT |
InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);
_confirmPasswordText.setSelection(cursor);
return true;
}
};
//End of NEW code changes
public void signup() {
Log.d(TAG, "Begin Signup process...");
if (!validate()) {
onSignupFailed();
return;
}
_signupButton.setEnabled(false);
final ProgressDialog signupProgressDialog = new ProgressDialog(RegisterActivity.this,
R.style.Theme_IAPTheme);
signupProgressDialog.setIndeterminate(true);
signupProgressDialog.setMessage("Creating Account...");
signupProgressDialog.show();
String name = _nameText.getText().toString();
String email = _emailText.getText().toString();
String password = _passwordText.getText().toString();
String confirmPassword = _confirmPasswordText.getText().toString();
// TODO: Implement your own signup logic here.
Response.Listener<String> responseListener = new Response.Listener<String>() {
@Override
public void onResponse(String response) {
try {
Log.i("tagconvertstr", "["+response+"]");
JSONObject jsonResponse = new JSONObject(response);
boolean success = jsonResponse.getBoolean("success");
if (success) {
onSignupSuccess();
} else {
onSignupFailed();
}
} catch (JSONException e) {
e.printStackTrace();
}
}
};
RegisterRequest registerRequest = new RegisterRequest(name, email, password, responseListener);
RequestQueue queue = Volley.newRequestQueue(RegisterActivity.this);
queue.add(registerRequest);
/*new android.os.Handler().postDelayed(
new Runnable() {
public void run() {
// On complete call either onSignupSuccess or onSignupFailed
// depending on success
onSignupSuccess();
// onSignupFailed();
progressDialog.dismiss();
}
}, 3000);*/
}
public void onSignupSuccess() {
Toast.makeText(getBaseContext(), "Signup Successful", Toast.LENGTH_LONG).show();
_signupButton.setEnabled(true);
setResult(RESULT_OK, null);
finish();
}
public void onSignupFailed() {
Toast.makeText(getBaseContext(), "Signup Failed", Toast.LENGTH_LONG).show();
_signupButton.setEnabled(true);
}
public boolean validate() {
boolean valid = true;
Drawable errorIcon = getResources().getDrawable(R.drawable.eye);
errorIcon.setBounds(new Rect(0, 0, 100, 100));
String name = _nameText.getText().toString();
String email = _emailText.getText().toString();
String password = _passwordText.getText().toString();
String confirmPassword = _confirmPasswordText.getText().toString();
//Trainer Name validation
if (name.isEmpty() || name.length() < 3) {
_nameText.setError("enter at least 3 characters", errorIcon);
valid = false;
} else {
_nameText.setError(null);
}
//E-Mail validation
if (email.isEmpty() || !android.util.Patterns.EMAIL_ADDRESS.matcher(email).matches()) {
_emailText.setError("enter a valid email address");
valid = false;
} else {
_emailText.setError(null);
}
//Password validation
if (password.isEmpty() || password.length() < 4 || password.length() > 10) {
_passwordText.setError("between 4 and 20 alphanumeric characters");
valid = false;
}else {
_passwordText.setError(null);
}
//Confirm Password validation
if (password.equals(confirmPassword)){
_confirmPasswordText.setError(null);
}else {
_confirmPasswordText.setError("passwords do not match");
valid = false;
}
return valid;
}
}