如何在Android中动态创建编辑文本

时间:2012-04-13 06:09:45

标签: android

我是Android编程新手,我有动态创建文本字段的问题;

我想创建一个视图,其中有一个名为“创建文本字段”的按钮和两个编辑文本,一个编辑文本名称为ROW,第二个编辑文本名称为COLUMN。当用户在编辑文本中输入数字时,请说ROW = 2和COLUMN = 3并按“创建文本字段”按钮,它可以在“创建文本字段”按钮下创建6个编辑文本。这些6编辑文本应该放在2行3列中,如下所示

EditText-1 EditText-2 EditText-3

EditText-1 EditText-2 EditText-3

4 个答案:

答案 0 :(得分:4)

setContentView(R.layout.main);
        LinearLayout ll = (LinearLayout)findViewById(R.id.ll);
        Display display = ((WindowManager) getApplicationContext().getSystemService(Context.WINDOW_SERVICE)).getDefaultDisplay();
        int width = display.getWidth()/3;
        for(int i=0;i<2;i++){
            LinearLayout l = new LinearLayout(this);
            l.setOrientation(LinearLayout.HORIZONTAL);
            for(int j=0;j<3;j++){
                EditText et = new EditText(this);
                LayoutParams lp = new LayoutParams(width,LayoutParams.WRAP_CONTENT);
                l.addView(et,lp);
          }
            ll.addView(l);
        }

在onCreate()中使用上面的代码,其中“main”是xml文件。你可以用edittext 1&amp;的值替换i&lt; 2和j&lt; 3 2。

我正在使用的示例main.xml位于::

之下
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/ll"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >


    <EditText
        android:id="@+id/et1"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content" >

        <requestFocus />
    </EditText>


    <EditText
        android:id="@+id/et2"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content" />


    <Button
        android:id="@+id/btn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />

</LinearLayout>

答案 1 :(得分:3)

public class DynamicEditTextActivity extends Activity {

    private EditText row, column;
    private Button submit;
    private LinearLayout main, matrix;

    @Override
    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        main = (LinearLayout) findViewById(R.id.mainlayout);
        row = (EditText) findViewById(R.id.row);
        column = (EditText) findViewById(R.id.column);      
        matrix = (LinearLayout) findViewById(R.id.matrix);
        matrix.setOrientation(LinearLayout.VERTICAL);

        submit = (Button) findViewById(R.id.submit);
        submit.setOnClickListener(generate);
    }

    OnClickListener generate = new OnClickListener() {

        public void onClick(View v) {

            matrix.removeAllViews();

            int rows = Integer.parseInt(row.getText().toString());
            int cols = Integer.parseInt(column.getText().toString());

            for (int i = 0; i < rows; i++) {

                LinearLayout layout = new LinearLayout(
                        DynamicEditTextActivity.this);
                layout.setOrientation(LinearLayout.HORIZONTAL);

                for (int j = 0; j < cols; j++) {

                    TextView text = new TextView(DynamicEditTextActivity.this);
                    text.setLayoutParams(new LayoutParams(
                            LayoutParams.WRAP_CONTENT,
                            LayoutParams.WRAP_CONTENT));
                    text.setText((j+1) + "    ");
                    text.setTextColor(Color.RED);

                    layout.addView(text);
                }

                matrix.addView(layout);
            }
        }
    };

答案 2 :(得分:1)

这是动态创建EditText框的方法......

希望这很有用......

这只是一个例子......你可以参考这个......

EditText t = new EditText(myContext);
    t.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT));
    layout.addView(t);

final LayoutParams lparams = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
final EditText edit_text = new EditText(this);
edit_text.setLayoutParams(lparams);
edit_text.setText("New text: " + text);

答案 3 :(得分:0)

尝试使用此功能

    <span 
        class="glyphicon glyphicon-copy"
        data-toggle="tooltip"
        style="cursor:pointer;font-size:20px;"
        title="myText"
    ></span>