首页 > 其他分享 >代码动态添加组件类型、大小 、方位 (addView)

代码动态添加组件类型、大小 、方位 (addView)

时间:2023-11-24 11:02:59浏览次数:42  
标签:LayoutParams addText 添加 params addView 组件 import android id



文章目录

  • 1、功能介绍
  • 2、代码结构
  • 3、activity_main.xml 文件
  • 4、功能代码


1、功能介绍

在代码里动态添加我们需要的组件 ,并确定位置 大小等格式

代码动态添加组件类型、大小 、方位 (addView)_xml

2、代码结构

代码动态添加组件类型、大小 、方位 (addView)_android_02

3、activity_main.xml 文件

定义两个按钮 点击 添加 不同的组件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/relay_id"
    tools:context=".MainActivity">

    <Button
        android:id="@+id/add_text_id"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="add text"
        android:layout_marginLeft="100px"
        android:layout_marginTop="1000px"
 />


    <Button
        android:id="@+id/add_img_id"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="add img"
        android:layout_marginLeft="600px"
        android:layout_marginTop="1000px"
        />
</RelativeLayout>
4、功能代码
package com.example.ubuntu.mystyle;

import android.graphics.drawable.Drawable;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.RelativeLayout;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity implements View.OnClickListener {


    private String TAG = "MainActivity: ";
    private RelativeLayout relativeLayout;
    private Button buttonText,buttonImg;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        relativeLayout = (RelativeLayout) findViewById(R.id.relay_id);
        buttonText = (Button) findViewById(R.id.add_text_id);
        buttonImg = (Button) findViewById(R.id.add_img_id);
        buttonText.setOnClickListener(this);
        buttonImg.setOnClickListener(this);
    }


    @Override
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.add_text_id:
                addTextView();
                break;
            case R.id.add_img_id:
                addImageView();
                break;
                default:
                    break;
        }

    }

    private void addImageView() {

        ImageView addImg  = new ImageView(MainActivity.this);
        addImg.setBackgroundColor(getResources().getColor(R.color.colorPrimary));

        // 定义LayoutParam
        //两个400分别为添加图片的大小
        LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(50, 50);


        params.topMargin = 10;   //距离顶部高度
        params.leftMargin = 50; //距离左边高度

        relativeLayout.addView(addImg, params); //添加的组件位置
    }


    private void addTextView() {
        TextView addText = new TextView(this);
        addText.setTextSize(12); //设置字体大小
        addText.setTextColor(getResources().getColor(R.color.colorAccent));  //设置字体颜色
        addText.setText("add Text"); //设置内容
        addText.setWidth(300);  //设置宽度
        addText.setHeight(40); //设置高度


        // 定义LayoutParam
        RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(
                ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);

        params.topMargin = 200;   //距离顶部高度
        params.leftMargin = 100; //距离左边高度


        relativeLayout.addView(addText, params); //添加的组件位置

    }
}

文献参考:
Android动态添加View之addView的用法
https://www.jianshu.com/p/760573e1964f

Android 在程序中动态添加 View 布局或控件


标签:LayoutParams,addText,添加,params,addView,组件,import,android,id
From: https://blog.51cto.com/u_15866638/8546138

相关文章

  • UEC++头文件添加与函数查找方法
    1.官方函数查找与应用技巧在蓝图中插入函数(中文也可以),右键能看到库名;官网也能查找函数名和使用方法;C++中使用可以将蓝图转化2.UEC++头文件添加VS编译时缺失头文件会报错,ctrl单击调用的函数,进入.h文件中查看的地址,将地址classes后面的目录用#clucde放入如下图如果报错......
  • 公众号添加附件
    在内容爆炸的今天,公众号运营者常常需要在文章中附加额外的文件以提供更多信息。如何便捷地在公众号文章中添加附件?这里,我们推荐一种简单易行的方法——使用微附件小程序。微附件小程序,添加附件的新方式微附件小程序是一款专为微信公众号定制的附件添加工具,它允许用户在公众号文章中......
  • React 组件之样式
    无论你的梦想有多么高远,记住,一切皆有可能。我们从前面的学习知道一个React组件不仅仅只包含DOM结构的,还应该样式和Javascript逻辑的。这里我们学习下如何构建CSS样式。1.逻辑表示JSX中使用大括号语法来包裹JS表达式(简单逻辑代码)。例如:{1+1}{表达式/对象/......
  • pyinstaller添加数据文件
    添加数据文件您可以使用命令选项将数据文件添加到捆绑包中,或者通过将它们作为列表添加到规范文件中。使用规范文件时,请提供以下列表:将文件描述为的参数值。数据文件列表是元组列表。每个元组有两个值,这两个值都必须是字符串:datas=Analysis第一个字符串指定一个或多个......
  • Vue + Element UI 实现复制当前行数据功能(复制到新增页面组件值不能更新等问题解决)
    1、需求使用Vue+ElementUI实现在列表的操作栏新增一个复制按钮,复制当前行的数据可以打开新增弹窗后亦可以跳转到新增页面,本文实现为跳转到新增页面。2、实现1)列表页index.vue<el-table><!--其他列--><el-table-columnlabel="操作"width="150"><templateslot-s......
  • 18、Scaffold 布局组件
    Scaffold 是一个非常重要的布局组件,它提供了一个常见的应用程序结构布局,包含了许多基础的UI元素和交互方式。Scaffold 组件主要由以下几个部分组成:AppBar:用于显示在页面顶部的应用栏,通常包含标题、导航按钮、操作按钮等。body:包含了页面主要内容的部分,可以是任意的Widge......
  • Vue + Element UI 实现复制当前行数据功能(复制到新增页面组件值不能更新等问题解决)
    1、需求使用Vue+ElementUI实现在列表的操作栏新增一个复制按钮,复制当前行的数据可以打开新增弹窗后亦可以跳转到新增页面,本文实现为跳转到新增页面。2、实现1)列表页index.vue<el-table><!--其他列--><el-table-columnlabel="操作"width="150"><templateslot-scope=......
  • 您可以尝试添加 --skip-broken 选项来解决该问题 ** 发现 2 个已存在的 RPM 数据库问
    ##提示如下**Found2pre-existingrpmdbproblem(s),‘yumcheck’outputfollows:2:postfix-2.10.1-7.el7.x86_64hasmissingrequiresoflibmysqlclient.so.18()(64bit)2:postfix-2.10.1-7.el7.x86_64hasmissingrequiresoflibmysqlclient.so.18(libmysqlclient_18)......
  • 界面组件Telerik UI for WinForms中文教程 - 创建明暗模式的桌面应用
    黑暗模式现在在很多应用程序中都挺常见的,但如何在桌面应用程序中实现它呢?这很简单,本文将为大家介绍如何使用一个类和命令行调用来实现!TelerikUIforWinForms拥有适用WindowsForms的110多个令人惊叹的UI控件。所有的UIforWinForms控件都具有完整的主题支持,可以轻松地帮助开发......
  • 无涯教程-Tk - 基本组件
    基本窗口小部件是几乎所有Tk应用程序中可用的常见窗口小部件。可用的基本小部件列表如下:Sr.No.Widgets&Remark1Label用于显示单行文本的小部件。2Button可单击并触发动作的小部件。3Entry小部件过去接受单行文本作为输入。4Message用于显示多行文本的小部件......