全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android实现多个连续带数字圆圈效果

有项目需求需要绘制多个圆圈,并且使用连续的数字对其排列起来,也就是好多排的圆圈。

首先看一下效果图:

一排设置为8个,一共有53个的:

一排设值为5个的,一共有153个:

可以根据总的个数和每排个数自动调节圆圈的大小,并且根据传入的监听事件作出不同的点击效果。

思路很简单,首先需要画一个圆出来:

<?xml version="1.0" encoding="UTF-8"?>
<shape
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="oval"
 android:useLevel="false" >
 <padding
  android:left="1dp"
  android:top="1dp"
  android:right="1dp"
  android:bottom="1dp" />

 <stroke
  android:width="1dp"
  android:color="@android:color/black" />
 <size android:width="10dp"
   android:height="10dp" />
</shape>

然后创建TextView,设置TextView的背景为这个drawable即可。

可以根据屏幕的总宽度和每排需要放置的圆个数,计算出每一个圆的合适大小,然后设置每个圆之间的margin为这个圆的十分之一,所以这个圆的最后大小应该为平均值的十分之八。

然后使用LinearLayout布局,动态加载多个TextView,每个TextView设置好对应的属性即可。

由于可能圆的个数过多,所以需要ScrollView来进行嵌套,从而支持滑动事件,需要注意的就是ScrollView下面只能有一个子节点。

完整代码:

import android.content.Context;
import android.os.Build;
import android.support.annotation.RequiresApi;
import android.util.Log;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.view.WindowManager;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.TextView;

/**
 * Created by leafage on 2017/7/21.
 */

public class CircleView {

 private LinearLayout mMainLinearLayout;
 private ScrollView mScrollView;
 private LinearLayout mLinearLayout;
 private WindowManager mWindowManager;
 private Context mContext;

 //全屏参数
 LinearLayout.LayoutParams MatchParams = new LinearLayout.LayoutParams(
   ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);

 //用来设置内部LinearLayout的参数,宽度适应父布局,高度自动
 LinearLayout.LayoutParams LinearLayoutParams = new LinearLayout.LayoutParams(
   ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);

 //设置TextView的参数
 LinearLayout.LayoutParams TextViewParams = new LinearLayout.LayoutParams(
   LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);


 public CircleView(Context context) {
  mContext = context;
  mMainLinearLayout = new LinearLayout(context);
  mLinearLayout = new LinearLayout(context);
  mScrollView = new ScrollView(context);

  //用来得到总屏幕的宽度
  mWindowManager = (WindowManager) context.getSystemService(Context.WINDOW_SERVICE);
  init();
 }

 private void init() {
  mLinearLayout.setOrientation(LinearLayout.VERTICAL);

  mMainLinearLayout.setLayoutParams(MatchParams);//最外面的全屏
  mScrollView.setLayoutParams(MatchParams);//滚动的全屏
  mLinearLayout.setLayoutParams(MatchParams);//内容的全屏
  mLinearLayout.setOrientation(LinearLayout.VERTICAL);//垂直放置

 }

 @RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
 public LinearLayout getLinearLayout(int column, int count, View.OnClickListener onClickListener) {

  int row = count / column;//计算出多少排

  int duoyu = count - row * column;//计算出多余的个数

  int totalWidth = mWindowManager.getDefaultDisplay().getWidth();//得到总的宽度

  int width = totalWidth / column;//计算出每排的每个圆圈的平均宽度

  int margin = (int) (width*0.1);//设置边距为0.1

  width = (int) (width * 0.8);//去掉左右边距剩下的宽度

  int num = 1;//从1开始计数


  TextViewParams.setMargins(margin, margin, margin, margin);

  for (int i = 0 ; i < row; i++) {//一共绘制多少排
   LinearLayout linearLayout = new LinearLayout(mContext);
   linearLayout.setLayoutParams(LinearLayoutParams);
   linearLayout.setOrientation(LinearLayout.HORIZONTAL);
   for (int j = 0; j < column; j++) {//一排绘制多少个
    final TextView textView = new TextView(mContext);
    textView.setBackground(mContext.getResources().getDrawable(R.drawable.cricle));
    textView.setHeight(width);
    textView.setWidth(width);
    textView.setGravity(Gravity.CENTER);
    textView.setText(String.valueOf(num));
    textView.setLayoutParams(TextViewParams);
    textView.setOnClickListener(onClickListener);//设置监听事件
    linearLayout.addView(textView);
    num++;
   }
   mLinearLayout.addView(linearLayout);
  }

  //绘制剩下多余的一排
  LinearLayout linearLayout = new LinearLayout(mContext);
  linearLayout.setLayoutParams(LinearLayoutParams);
  linearLayout.setOrientation(LinearLayout.HORIZONTAL);

  for (int i = 0 ; i< duoyu;i++) {
   TextView textView = new TextView(mContext);
   textView.setBackground(mContext.getResources().getDrawable(R.drawable.cricle));
   textView.setHeight(width);
   textView.setWidth(width);
   textView.setGravity(Gravity.CENTER);
   textView.setText(String.valueOf(num));
   textView.setLayoutParams(TextViewParams);
   textView.setOnClickListener(onClickListener);
   linearLayout.addView(textView);
   num++;
  }

  mLinearLayout.addView(linearLayout);

  mScrollView.addView(mLinearLayout);

  mMainLinearLayout.addView(mScrollView);

  return mMainLinearLayout;
 }

}


可以直接在Activity里面使用:

import android.os.Build;
import android.os.Bundle;
import android.support.annotation.RequiresApi;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity{

 private LinearLayout mMainLayout;

 @RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);

  CircleView circle = new CircleView(this);

  mMainLayout = circle.getLinearLayout(8, 53, new View.OnClickListener() {
   @Override
   public void onClick(View view) {
    Toast.makeText(MainActivity.this, "ID:" + ((TextView)view).getText(), Toast.LENGTH_SHORT).show();
   }
  });
  setContentView(mMainLayout);
 }

}

代码结构:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Android多个连续带数字圆圈  # Android连续带数字圆圈  # Android带数字圆圈  # Android中TextView显示圆圈背景或设置圆角的方法  # 全屏  # 计算出  # 多个  # 可以根据  # 有一  # 对其  # 很简单  # 可以直接  # 看一下  # 设置为  # 需要注意  # 值为  # 大家多多  # 多少个  # 画一  # 自动调节  # 加载  # drawable  # TextView  # LinearLayout 


相关文章: 如何使用Golang安装API文档生成工具_快速生成接口文档  如何在阿里云购买域名并搭建网站?  微信小程序 五星评分(包括半颗星评分)实例代码  建站之星免费模板:自助建站系统与智能响应式一键生成  如何解决ASP生成WAP建站中文乱码问题?  表情包在线制作网站免费,表情包怎么弄?  宝塔建站无法访问?如何排查配置与端口问题?  如何在腾讯云服务器快速搭建个人网站?  实例解析angularjs的filter过滤器  网站制作软件有哪些,制图软件有哪些?  如何配置FTP站点权限与安全设置?  建站之星安装后界面空白如何解决?  宝华建站服务条款解析:五站合一功能与SEO优化设置指南  建站之星后台管理系统如何操作?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  网站好制作吗知乎,网站开发好学吗?有什么技巧?  宝塔新建站点报错如何解决?  网站微信制作软件,如何制作微信链接?  建站之星代理如何获取技术支持?  建站之星后台密码遗忘如何找回?  定制建站策划方案_专业建站与网站建设方案一站式指南  潮流网站制作头像软件下载,适合母子的网名有哪些?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  如何在阿里云高效完成企业建站全流程?  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  完全自定义免费建站平台:主题模板在线生成一站式服务  如何快速搭建响应式可视化网站?  简单实现Android文件上传  如何零成本快速生成个人自助网站?  建站主机是否属于云主机类型?  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  h5网站制作工具有哪些,h5页面制作工具有哪些?  如何配置WinSCP新建站点的密钥验证步骤?  网站制作知乎推荐,想做自己的网站用什么工具比较好?  如何高效配置IIS服务器搭建网站?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  详解jQuery停止动画——stop()方法的使用  定制建站流程解析:需求评估与SEO优化功能开发指南  高性价比服务器租赁——企业级配置与24小时运维服务  如何正确选择百度移动适配建站域名?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。