第5章(2) 按钮和文本框

分类:C#、Android、VS2015;

创建日期:2016-02-07

一、简介

1、Button

常规按钮。

2、TextView

文本视图,其功能和WPF的TextBlock控件类似,【工具箱】中提供的3个组件实际上是同一个TextView控件用不同的属性来区分的,这3个不同的属性在【工具箱】中对应的名称如下:

  • Text(Large):大字体的TextView
  • Text(Medium):中等字体的TextView
  • Text(small):小字体的TextView

3、EditText

文本框,其功能和WinForm的TextBox类似,区别仅是WinForm的TextBox在【工具箱】中只有一个,然后通过属性设置是普通文本还是密码输入;而Android的EditText实际上也是通过属性来区分是普通文本还是密码输入,但在工具箱中分别以组件的形式提供了,这2个不同的属性在【工具箱】中对应的名称如下:

  • PlainText:常规的EditText
  • Password:密码输入的EditText

二、示例1—Demo1EditText

本示例演示如何功能:

  • 在文本框中输入信息时立即在另一个文本框中显示所键入的字符。
  • Toast基本用法。
  • 常规文本框和密码输入文本框的基本用法。

1、运行截图

2、主要设计步骤

(1)添加demo01_EditTextaxml文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
  <TextView
      android:text="文本框基本用法"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/textView1" />
  <EditText
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/editText1" />
  <EditText
      android:inputType="textPassword"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/editText2" />
  <TextView
      android:text=""
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/txtResult"
      android:gravity="center_horizontal"
      android:layout_marginTop="20dp" />
</LinearLayout>
(2)添加Demo01EditText.cs文件

先在项目根目录下添加一个SrcActivity文件夹,然后在该文件夹下添加.cs文件,这些文件选择的模板都是【Activity】。

using Android.App;
using Android.OS;
using Android.Widget;
using Android.Graphics;
namespace ch05demos.SrcActivity
{
    [Activity(Label = "TextBoxDemo")]
    public class Demo01EditText : Activity
    {
        protected override void OnCreate(Bundle savedInstanceState)
        {
            base.OnCreate(savedInstanceState);
            SetContentView(Resource.Layout.demo01_EditText);

            var txtResult = FindViewById<TextView>(Resource.Id.txtResult);
            txtResult.SetTextColor(Color.Red);
            txtResult.Enabled = false;

            var txt1 = FindViewById<EditText>(Resource.Id.editText1);
            txt1.TextChanged += (s, e) =>
            {
                txtResult.Text = "输入的内容为:" + txt1.Text;
            };

            var txt2 = FindViewById<EditText>(Resource.Id.editText2);
            txt2.TextChanged += (s, e) =>
            {
                txtResult.Text = "输入的内容为:" + txt2.Text;
            };
        }
    }
}

运行即得到截图所示的结果。

如果希望在文本输入过程中立即判断键入的是哪个字符,可利用下面的事件来实现(用模拟器测试时,仅在硬件键盘开启时才有效):

EditText edittext = FindViewById<EditText>(Resource.Id.edittext);
edittext.KeyPress += (s, e) =>
{
    e.Handled = false;
    if (e.Event.Action == KeyEventActions.Down && e.KeyCode == Keycode.Enter) {
        Toast.MakeText (this, edittext.Text, ToastLength.Short).Show ();
        e.Handled = true;
    }
};

三、示例2--Demo02Login

在一个应用中,登录是最最基本的界面,该例子演示如何利用Button、TextView、EditText基本控件开发一个简单的登录窗口。

运行截图:

主要设计步骤:

(1)在layout文件夹下添加demo02_Login.axml文件。在该文件的【设计】视图中,从【工具箱】中拖放以下控件:

Text(Medium):生成中等的TextView

PlainText:生成明文输入的EditText

Password:生成密码输入的EditText

Button:生成Button

(2)在【属性】窗口中设置各控件对应的属性。最后生成的代码如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
  <TextView
      android:text="用户名"
      android:textAppearance="?android:attr/textAppearanceMedium"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/textView1" />
  <EditText
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/editTextUserName" />
  <TextView
      android:text="密码"
      android:textAppearance="?android:attr/textAppearanceMedium"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/textView2" />
  <EditText
      android:inputType="textPassword"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/editTextPwd" />
  <Button
      android:text="登录"
      android:layout_width="100dp"
      android:layout_height="wrap_content"
      android:id="@+id/buttonLogin"
      android:layout_gravity="center_horizontal" />
</LinearLayout>

(3)保存所有打开的文件,以便能在.cs中键入代码时能看到智能提示。说明:如果在.cs文件中仍然看不到ID的智能提示,单击【解决方案资源管理器】上方的【刷新】按钮即可。

(4)在SrcActivity文件夹下添加Demo02Login.cs文件,将代码改为下面的内容:

using System;
using Android.App;
using Android.OS;
using Android.Widget;
namespace ch05demos.SrcActivity
{
    [Activity(Label = "LoginDemo")]
    public class Demo02Login : Activity
    {
        protected override void OnCreate(Bundle savedInstanceState)
        {
            base.OnCreate(savedInstanceState);
            SetContentView(Resource.Layout.demo02_Login);
            Button btn = FindViewById<Button>(Resource.Id.buttonLogin);
            btn.Click += Btn_Click;  //技巧:按+=后,连续按两次<Tab>键
        }

        private void Btn_Click(object sender, EventArgs e)
        {
            var userName = FindViewById<EditText>(Resource.Id.editTextUserName);
            var pwd = FindViewById<EditText>(Resource.Id.editTextPwd);
            Toast.MakeText(this,
                string.Format("用户名:{0}, 密码:{1}", userName.Text, pwd.Text),
                //技巧:按空格
                ToastLength.Long).Show();
        }
    }
}

运行,即得到截图所示的效果。

时间: 2024-10-19 10:33:58

第5章(2) 按钮和文本框的相关文章

Qt基础(一)----按钮,文本框,窗口,布局,选项框等等

对于每条语句的解释都放在了函数注释中! 一 Qt程序初探,窗口和按钮的创建及关联 //应用程序抽象类 #include<QApplication> //窗口类 #include<QWidget> //按钮类 #include<QPushButton> int main(int argc, char *argv[]) { //初始化应用程序 QApplication app(argc, argv); //构造一个窗口w QWidget w; //设置窗口名称 w.setW

iOS_book 02 - 基本交互(约束、视图控制器、基本控件:按钮、文本框、分段控件、开关、标签、图像控件)

实现基本交互 MVC模式 Cocoa Touch 设计者们采用MVC(Model-View-Controller, 模型 - 视图 - 控制器)模式作为指导原则. MVC 模式把代码功能划分为3个不同的类别. 模型: 保存应用程序数据的类. 视图:包括窗口.控件以及其他一些用户可以看到并能与之交互的元素. 控制器:把模型和视图绑定在一起的代码,包括处理用户输入的应用程序逻辑. MVC的目标最大限度地分离这三类代码.MVC可以帮助确保代码的最大可重用性. 控制器组件通常有应用程序的具体类组成.控制

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

一.使用qt designer拖拽界面. 使用qtdesigner拖拽界面: 如图左侧导航栏,1:Sources,2:Forms,3:Resouces 1:代码,2:Qt Designer的拖拽界面的代码,xml形式的 3:暂未使用,猜测用来放置一些图片.音频.视频之类的. 在2:Forms中右键点击,然后选择new form,选择 类型:Dialog然后会启动Qt Designer,拖拽出如图的界面. 二.在qt designer中  自定义信号/槽 在Qt Designer的界面中 1:编辑

ColorStateList改变按钮、文本框文字变色

在平时项目中经常要做的就是改变按钮的背景颜色.文字验证,文本框也是如此. 我们知道用xml来实现选中效果是非常容易的,而且也简单.xml代码如下:这样的可以直接写在res/color/button_text.xml中 <?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android"

开发进阶05_代码创建按钮和文本框

在控制器的view加载完毕的时候会调用一次viewDidLoad方法 #pragma mark 控制器的view加载完毕的时候会调用一次 - (void)viewDidLoad { [super viewDidLoad]; //1.创建按钮 //1.1.创建  UIButton *btn = [[UIButton alloc] init]; //1.2.设置按钮的尺寸和位置 btn.frame = CGRectMake(0, 20, 100, 100); //1.3.设置按钮普通状态下的属性 /

第22章:自动完成文本框AutoCompleteTextView的用法

AutoCompleteText有以下基本属性: android:completionHint-->设置下拉菜单中的提示标题-->对应方法:setCompletionHint(CharSequence) android:completionHintView-->设置下拉菜单中提示标题的视图 android:completionThreshold-->设置用户至少输入几个字符才会有提示-->对应方法:setThreshold(int) android:dropDownAncho

vue项目中做点击按钮复制文本框内容

zeroclipboard是走的flash插件,手机浏览器是不支持的,所以不得不舍弃之,用clipboard,clipboard不需要flash就可以完成复制剪切等功能,而且可以兼容pc,移动端 首先要安装:cnpm install clipboard --save 然后引入包 引入:import Clipboard from 'clipboard'; 这个人地方坑会报各种依赖丢失的错,没关系,用下面的方法可以拯救 项目: . 代码: <span class="NetbarNumber&q

点击按钮获得文本框里面的值

<script type="text/javascript"> window.onload = function(){ var obtn=document.getElementById("Button2"); obtn.onclick = function(){ alert(document.getElementsById("Text2").value); }; } </script> <p>用户名:<i

vue点击按钮复制文本框内容

1.npm进行安装 npm install clipboard --save 2.在需要使用的组件中import 引用方法:import Clipboard from 'clipboard'; 3.添加需要复制的内容 <button class="tag-read" data-clipboard-text="我是可以复制的内容,请点击复制" @click="copy">立即阅读</button> 解析: data-clip