ज़ामरीन - मल्टीस्क्रीन ऐप
इस अध्याय में, हम एक लॉगिन सिस्टम बनाने जा रहे हैं जो एक उपयोगकर्ता को पंजीकृत करने में सक्षम बनाता है। फिर, हम सफल लॉगिन पर पंजीकृत उपयोगकर्ता को अपने ऐप की होम स्क्रीन पर ले जाएंगे।
सबसे पहले, एक नया प्रोजेक्ट बनाएं और इसे कॉल करें Login System। अपने नए प्रोजेक्ट पर, पर जाएंmain.axml और नीचे दिखाए गए अनुसार दो बटन और एक प्रगति पट्टी जोड़ें।
<?xml version = "1.0" encoding = "utf-8"?>
<LinearLayout xmlns:android = "http://schemas.android.com/apk/res/android"
android:orientation = "vertical"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent"
android:background = "@android:color/background_light"
android:weightSum = "100"
android:minWidth = "25px"
android:minHeight = "25px">
<TextView
android:text = "Login App"
android:textAppearance = "?android:attr/textAppearanceMedium"
android:layout_width = "match_parent"
android:layout_weight = "20"
android:layout_height = "0dp"
android:textColor = "#368DEB"
android:id = "@+id/txtCreatAccount"
android:gravity = "center"
android:textStyle = "bold"
android:textSize = "25sp" />
<Button
android:text = "Sign In"
android:layout_width = "match_parent"
android:layout_weight = "15"
android:layout_height = "0dp"
android:background = "@drawable/btnSignInStyle"
android:id = "@+id/btnSignIn"
android:layout_marginLeft = "20dp"
android:layout_marginRight = "20dp"
android:textSize = "15sp" />
<Button
android:text = "Sign Up"
android:layout_width = "match_parent"
android:layout_weight = "15"
android:layout_height = "0dp"
android:background = "@drawable/btnSignUpStyle"
android:id = "@+id/btnSignUp"
android:layout_marginLeft = "20dp"
android:layout_marginRight = "20dp"
android:textSize = "15sp" />
<RelativeLayout
android:layout_width = "match_parent"
android:layout_height = "0dp"
android:layout_weight = "50"
android:minWidth = "25px"
android:minHeight = "25px">
<ProgressBar
android:layout_width = "wrap_content"
android:layout_height = "wrap_content"
android:id = "@+id/progressBar1"
android:background = "@drawable/progressBarStyle"
android:layout_centerInParent="true"
android:indeterminate = "true"
xmlns:tools = "
http://schemas.android.com/tools"
tools:visibility = "invisible" />
</RelativeLayout>
</LinearLayout>
उपयोगकर्ता इंटरफ़ेस बनाने के बाद, बटन को स्टाइल करने के लिए उन्हें और अधिक आकर्षक बनाने के लिए महत्वपूर्ण है। ऐसा करने के लिए, एक नई XML फ़ाइल बनाएँdrawable folder और फ़ाइल का नाम btnSignInStyle.xml।
XML फ़ाइल में, कोड की निम्नलिखित पंक्तियाँ जोड़ें -
<selector xmlns:android = "http://schemas.android.com/apk/res/android">
<item android:state_pressed = "false">
<layer-list>
<item android:right = "5dp" android:top = "5dp">
<shape>
<corners android:radius = "2dp"/>
<solid android:color = "#D6D6D6"/>
</shape>
</item>
<item android:left = "2dp" android:bottom = "2dp">
<shape>
<corners android:radius = "4dp"/>
<gradient android:angle = "270"
android:endColor = "#486EA9" android:startColor = "#486EA9"/>
<stroke android:width = "1dp" android:color = "#BABABA"/>
<padding android:bottom = "10dp"
android:right = "10dp" android:left = "10dp" android:top = "10dp"/>
</shape>
</item>
</layer-list>
</item>
<item android:state_pressed = "true">
<layer-list>
<item android:right = "5dp" android:top = "5dp">
<shape>
<corners android:radius = "2dp"/>
<solid android:color = "#D6D6D6"/>
</shape>
</item>
<item android:left = "2dp" android:bottom = "2dp">
<shape>
<corners android:radius = "4dp"/>
<gradient android:angle = "270"
android:endColor = "#79C791" android:startColor = "#486EA9"/>
<stroke android:radius = "4dp" android:color = "#BABABA"/>
<padding android:bottom = "10dp"
android:right = "10dp" android:left = "10dp" android:top = "10dp"/>
</shape>
</item>
</layer-list>
</item>
</selector>
उपरोक्त कोड लोड और क्लिक पर बटन के रंगों को सेट करता है, यह बटन की सीमा त्रिज्या भी निर्धारित करता है।
अगला, हम ऊपर के लिए एक समान स्टाइल XML बनाते हैं signupबटन। ऐसा करने के लिए, नीचे एक और XML बनाएँdrawable फ़ोल्डर और इसे कॉल करें btnSignUpStyle.xml। इससे सब कुछ विरासत में मिलेगाbtnSignInStyle.xml। एकमात्र अंतर बटन के ग्रेडिएंट स्टार्ट और एंड कलर होगा।
बदलाव startColor तथा endColor में btnSignUpStyle.xml सेवा
<gradient android:angle="270"
android:endColor="#008000" android:startColor="#008000"/>
के लिए जाओ layout folderऔर एक नई AXML फ़ाइल बनाएँ और इसे registerDailog.axml कहें। इस फ़ाइल में हमारे ऐप में नए उपयोगकर्ताओं के लिए पंजीकरण विवरण होगा। पेज में तीन होंगेEditTextsऔर डेटा सबमिट करने के लिए एक बटन। अपने रैखिक लेआउट कोड के अंदर निम्नलिखित कोड जोड़ें।
<EditText
android:layout_width = "match_parent"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:layout_height = "35dp"
android:paddingLeft = "10dp"
android:id = "@+id/txtUsername"
android:hint = "Username"
android:textColor = "#000" />
<EditText
android:layout_width = "match_parent"
android:layout_height = "35dp"
android:id = "@+id/txtEmail"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:paddingLeft = "10dp"
android:textColor = "#000"
android:hint = "Email" />
<EditText
android:layout_width = "match_parent"
android:layout_height = "35dp"
android:layout_marginBottom = "10dp"
android:layout_marginTop = "25dp"
android:layout_marginRight = "25dp"
android:layout_marginLeft = "25dp"
android:paddingLeft = "10dp"
android:textColor = "#000"
android:id = "@+id/txtPassword"
android:hint = "Password" />
<Button
android:text = "Sign Up"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/btnSave"
android:textSize = "20dp"
android:textColor = "#fff"
android:textStyle = "bold"
android:height = "70dp"
android:background = "@drawable/btnSignUpStyle"
android:paddingLeft = "5dp"
android:paddingRight = "5dp"
android:paddingTop = "5dp"
android:paddingBottom = "5dp"
android:layout_marginLeft = "25dp"
android:layout_marginRight = "25dp"
android:layout_centerHorizontal = "true" />
इसके बाद, एक नया वर्ग जोड़ें signUpDialog.cs। इस वर्ग में एक संवाद बॉक्स बनाने के लिए आवश्यक कोड होगा। निम्न उदाहरण कोड दिखाता है।
public class OnSignUpEvent:EventArgs {
private string myUserName;
private string myEmail;
private string myPassword;
public string UserName {
get {
return myUserName;
}
set{
myUserName = value;
}
}
public string Email {
get {
return myEmail;
}
set {
myEmail = value;
}
}
public string Password {
get {
return myPassword;
}
set {
myPassword = value;
}
}
public OnSignUpEvent(string username, string
email, string password):base() {
UserName = username;
Email = email;
Password = password;
}
class SignUpDialog:DialogFragment {
private EditText txtUsername;
private EditText txtEmail;
private EditText txtPassword;
private Button btnSaveSignUp;
public event EventHandler<OnSignUpEvent> onSignUpComplete;
public override View OnCreateView(LayoutInflater inflater,
ViewGroup container, Bundle savedInstanceState) {
base.OnCreateView(inflater, container, savedInstanceState);
var view = inflater.Inflate(Resource.Layout.registerDialog, container, false);
txtUsername = view.FindViewById<EditText>(Resource.Id.txtUsername);
txtEmail = view.FindViewById<EditText>(Resource.Id.txtEmail);
txtPassword = view.FindViewById<EditText>(Resource.Id.txtPassword);
btnSaveSignUp = view.FindViewById<Button>(Resource.Id.btnSave);
btnSaveSignUp.Click += btnSaveSignUp_Click;
return view;
}
void btnSaveSignUp_Click(object sender, EventArgs e) {
onSignUpComplete.Invoke(this, new OnSignUpEvent(txtUsername.Text,
txtEmail.Text, txtPassword.Text));
this.Dismiss();
}
}
}
उपरोक्त कोड में, हमने उपयोग किया है get तथा setगुण। get विधि एक चर देता है, जबकि setविधि लौटे चर का मान प्रदान करती है। यहाँ एक उदाहरण है -
public string Color {
get {
return color;
}
set {
color = value;
}
}
हमारे पिछले उदाहरण में, हमने एक तरीका बनाया जो एक दृश्य को ओवरराइड करता है। विधि के अंदर, हमने एक बनायाvar बुलाया view जिसे संदर्भित किया गया registerDialog.axml लेआउट फ़ोल्डर में निहित।
अगला, करने के लिए जाओ mainActivity.cs संवाद टुकड़ा बनाने के लिए।
private Button signUp;
private Button submitNewUser;
private EditText txtUsername;
private EditText txtEmail;
private EditText txtPassword;
protected override void OnCreate(Bundle bundle) {
base.OnCreate(bundle);
SetContentView(Resource.Layout.Main);
signUp = FindViewById<Button>(Resource.Id.btnSignUp);
submitNewUser = FindViewById<Button>(Resource.Id.btnSave);
txtUsername = FindViewById<EditText>(Resource.Id.txtUsername);
txtEmail = FindViewById<EditText>(Resource.Id.txtEmail);
txtPassword = FindViewById<EditText>(Resource.Id.txtPassword);
signUp.Click += (object sender, EventArgs args) => {
FragmentTransaction transFrag = FragmentManager.BeginTransaction();
SignUpDialog diagSignUp = new SignUpDialog();
diagSignUp.Show(transFrag, "Fragment Dialog");
diagSignUp.onSignUpComplete += diagSignUp_onSignUpComplete;
};
}
void diagSignUp_onSignUpComplete(object sender, OnSignUpEvent e) {
StartActivity(typeof(Activity2));
}
उपरोक्त कोड में एक बटन क्लिक करने की घटना है जो क्लिक किए जाने पर साइनअप संवाद को लोड करता है। बटन क्लिक के अंदर, हमने एक बनायाSignUpDialog वर्ग जो लोड करता है registerDialog.axml फ़ाइल।
हमने तब उपयोग किया FragmentTransaction transFrag = FragmentManager.BeginTransaction(); हमारे दिखाने के लिए registerDialog पेज एक एंड्रॉइड डायलॉग फ्रैगमेंट के रूप में।
हम एक और जोड़ने जा रहे हैं .axml फ़ाइल कहा जाता है home.axml। उपयोगकर्ता द्वारा सिस्टम में सफलतापूर्वक लॉग इन करने पर यह लेआउट लैंडिंग स्क्रीन होगा। इस लेआउट के अंदर, हम एक टेक्स्टव्यू जोड़ने जा रहे हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।
<TextView
android:text = "You have been succesfully registered. Welcome!"
android:textAppearance = "?android:attr/textAppearanceLarge"
android:layout_width = "match_parent"
android:layout_height = "wrap_content"
android:id = "@+id/textView1" />
अगला, हम एक अंतिम गतिविधि बनाते हैं जिसे कहा जाता है Activity2.cs। इस गतिविधि में, हम खोजने जा रहे हैंhome.axml का उपयोग करते हुए findViewById।
अंत में, अपना ऐप बनाएं और चलाएं। यह आउटपुट के रूप में निम्न स्क्रीन प्रदर्शित करेगा।