在数据库中创建了名为adopter和donor的两个表。当'作为捐赠者'单击单选按钮,注册表的值应存储在正确工作的捐赠者表中。问题在于“作为采用者”的时间。单击单选按钮,值将存储在捐赠者表中,并且在采用者表中单独输入id(主键)。在这里'是'单选按钮是作为捐赠者'并且没有'单选按钮是'作为采用者'我需要你的帮助。
findViewById(R.id.button2).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
final String email = mail.getText().toString();
final String name1 = name.getText().toString();
final String pass = password.getText().toString();
final String pass1 = password1.getText().toString();
int id;
id = student.getCheckedRadioButtonId();
boolean check;
check = stud.isChecked();
if (!isValidName(name1)) {
name.setError("Invalid name");
}
if (isValidName(name1) && !isValidEmail(email)) {
mail.setError("Invalid Email");
}
if (isValidName(name1) && isValidEmail(email) && !isValidPassword(pass)) {
password.setError("Invalid password");
}
if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass)) {
if (!isValidPassword(pass1)) {
password1.setError("Invalid password");
}
}
if (isValidPassword(pass) != isValidPassword(pass1)) {
password1.setError("The given passwords does not match ");
}
if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && isValidPassword(pass) == isValidPassword(pass1) && (id == -1)) {
Toast toast;
toast = makeText(Register.this, "Click any one of the option", Toast.LENGTH_SHORT);
toast.show();
}
if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && (id != -1) && isValidPassword(pass) == isValidPassword(pass1) && (check == false)) {
Toast msg1;
msg1 = makeText(Register.this, "You can not register without clicking this checkbox", Toast.LENGTH_SHORT);
msg1.show();
}
if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && isValidPassword(pass) == isValidPassword(pass1) && (check == true) && (yes.isEnabled()==true)) {
Toast msg2;
msg2 = makeText(Register.this, "Step 1 of registration is completed", Toast.LENGTH_SHORT);
msg2.show();
Intent launch;
launch = new Intent(Register.this, donor.class);
startActivity(launch);
donor_insert(view);
if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && isValidPassword(pass) == isValidPassword(pass1) && (check == true) && (no.isEnabled()==true)){
Toast msg3;
msg3 = makeText(Register.this, "Step 1 of registration is completed", Toast.LENGTH_SHORT);
msg3.show();
Intent adopter;
adopter = new Intent(Register.this, adopter.class);
startActivity(adopter);
adopter_insert(view);
}
}
}
});
}
private boolean isValidEmail(String email) {
String EMAIL_PATTERN = "^(?=.*[a-z]).(?=\\S+$).{4,}$";
Pattern pattern = Pattern.compile(EMAIL_PATTERN);
Matcher matcher = pattern.matcher(email);
return matcher.matches();
}
private boolean isValidName(String name) {
String name1 = "^(?=.*[a-z]).{1,}$";
Pattern pattern1 = Pattern.compile(name1);
Matcher matcher1 = pattern1.matcher(name);
return matcher1.matches();
}
// validating password with retype password
private boolean isValidPassword(String pass) {
if (pass != null && pass.length() > 6) {
return true;
}
return false;
}
public void adopter_insert(View view) {
UserInputs adopt = new UserInputs(name.getText().toString(), mail.getText().toString(), password.getText().toString());
dbHandler.adopter_insert(adopt);
name.setText("");
mail.setText("");
password.setText("");
}
public void donor_insert(View view) {
UserInputs donate = new UserInputs(name.getText().toString(), mail.getText().toString(), password.getText().toString());
dbHandler.donor_insert(donate);
name.setText("");
mail.setText("");
password.setText("");
}
}
{ //Dbhandler.java
public DBhandler(Context context, String name,
SQLiteDatabase.CursorFactory factory, int version) {
super(context, DBNAME, null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
String create_table = ("CREATE TABLE " + TABLE + "("
+ COLUMN_ID1 + " INTEGER PRIMARY KEY," + COLUMN_NAME
+ " TEXT," + COLUMN_MAIL + " TEXT, " + COLUMN_PASSWORD + " BLOB " + ")");
db.execSQL(create_table);
String create_table1 = ("CREATE TABLE " + TABLE1 + "("
+ COLUMN_ID + " INTEGER PRIMARY KEY," + COLUMN_NAME
+ " TEXT," + COLUMN_MAIL + " TEXT, " + COLUMN_PASSWORD + " BLOB " + ")");
db.execSQL(create_table1);
}
@Override
public void onUpgrade(SQLiteDatabase db, int i, int i1) {
db.execSQL("DROP TABLE IF EXISTS " + TABLE);
onCreate(db);
db.execSQL("DROP TABLE IF EXISTS " + TABLE1);
onCreate(db);
}
public void adopter_insert(UserInputs inputs) {
ContentValues values = new ContentValues();
values.put(COLUMN_NAME, inputs.getName());
values.put(COLUMN_MAIL, inputs.getMail());
values.put(COLUMN_PASSWORD, inputs.getPass());
SQLiteDatabase db = this.getWritableDatabase();
db.insert(TABLE, null, values);
db.close();
}
public void donor_insert(UserInputs inputs) {
ContentValues values1 = new ContentValues();
values1.put(COLUMN_NAME, inputs.getName());
values1.put(COLUMN_MAIL, inputs.getMail());
values1.put(COLUMN_PASSWORD, inputs.getPass());
SQLiteDatabase db = this.getWritableDatabase();
db.insert(TABLE1, null, values1);
db.close();
}
}
}
答案 0 :(得分:0)
如果你需要设置这样的条件,你会在最后看到你,因为当你的捐赠者被检查时,你的第一个将被执行,如果你的采用者被检查,那么你的第二个将被执行。我希望这对你有所帮助。
if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && isValidPassword(pass) == isValidPassword(pass1) && (check == true) && (yes.isEnabled()==true))
{
Toast msg2;
msg2 = makeText(Register.this, "Step 1 of registration is completed", Toast.LENGTH_SHORT);
msg2.show();
Intent launch;
launch = new Intent(Register.this, donor.class);
startActivity(launch);
donor_insert(view);
}
if (isValidName(name1) && isValidEmail(email) && isValidPassword(pass) && isValidPassword(pass) == isValidPassword(pass1) && (check == true) && (no.isEnabled()==true))
{
Toast msg3;
msg3 = makeText(Register.this, "Step 1 of registration is completed", Toast.LENGTH_SHORT);
msg3.show();
Intent adopter;
adopter = new Intent(Register.this, adopter.class);
startActivity(adopter);
adopter_insert(view);
}