如图所示:

C#代码:

 using System.Collections;
using System.Collections.Generic;
using UnityEngine; public class SpriteRendererTest : MonoBehaviour {
List<Transform> list = new List<Transform>(); // 存储父物体的子对象
List<float> rendererWidthList = new List<float>(); // 存储子对象的宽度
private Vector3 centerPos = Vector3.zero; // 中心位置
private float offSet = 0.2f; //偏移量
private float length = 0.0f; // 初始化长度 void Start () {
// 遍历所有子对象
for (int i = ; i < gameObject.transform.childCount; i++) {
var child = gameObject.transform.GetChild(i);
var width = child.GetComponent<SpriteRenderer>().sprite.bounds.size.x;
if (i < gameObject.transform.childCount - )
{
length += width + offSet;
}
else {
length += width;
}
list.Add(child);
rendererWidthList.Add(width);
}
var startX = centerPos.x - length / 2.0f; //第一个子对象的左边界
foreach (var child in list)
{
int index = ;
child.transform.position = new Vector3(startX + rendererWidthList[index] / 2.0f, , );
startX = startX + offSet + rendererWidthList[index];
index += ;
}
}
}

lua代码:

 -- 创建数组
local parent = UGameObject.Find("Parent")
local objectList = {}
local rendererWidthList = {}
for i = , parent.transform.childCount do
local child = parent.transform:GetChild(i - )
local renderer = child:GetComponent(typeof(USpriteRenderer))
local width = renderer.sprite.bounds.size.x
table.insert(objectList, child)
table.insert(rendererWidthList, width)
end local length = -- 初始化长度
local offSet = 0.2 -- 间隔
for i = , #objectList do
local obj = objectList[i]
local width = rendererWidthList[i]
if i == #objectList then
length = length + width
break
end
length = length + width + offSet
end local centerPos = Vector3.zero -- 中心位置
local startX = centerPos.x - length / -- 初始位置 for i = , #objectList do
local obj = objectList[i]
local width = rendererWidthList[i]
obj.transform.position = Vector3(startX + width / , , )
startX = startX + width + offSet
end

2d图片依次排列在屏幕中间(SpriteRenderer)的更多相关文章

  1. WPF编程,通过DoubleAnimation控制图片的透明度,将重叠的图片依次显示。

    原文:WPF编程,通过DoubleAnimation控制图片的透明度,将重叠的图片依次显示. 版权声明:我不生产代码,我只是代码的搬运工. https://blog.csdn.net/qq_43307 ...

  2. 基于jQuery图片自适应排列显示代码

    基于jQuery图片自适应排列显示代码.这是一款基于jquery.flex-images插件实现的类似谷歌图片流效果.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div ...

  3. NGUI如何使2D图片按像素1:1显示在屏幕上

    NGUI版本为3.5.1. 将camera 设置为正交模式,size值设为1. UIRoot(2D)有3种缩放样式: 1.PixelPerfect.UI严格按照指定的像素大小显示,不会随着屏幕的分辨率 ...

  4. 横向图片墙排列算法及demo

    演示地址: http://codeman35.itongyin.com:19005/v1/9gg_v2.html 功能: 按照不同的图片比例,进行横向9宫格排列,原则是尽量排列的整齐,不要多余出来格子 ...

  5. Android 图片文件操作、屏幕相关、.9图片的理解

     一:Android图片操作 1.存储bitmap到本地文件系统 public static void bitmapToFile(Bitmap bitmap, String uri) { if(!ex ...

  6. 从2D图片生成3D模型(3D-GAN)

    https://blog.csdn.net/u014365862/article/details/54783209 3D-GAN是使用生成对抗网络学习2D图像到3D模型的映射,生成网络负责生成3D模型 ...

  7. ajax读取图片后排列问题(先加载完图片再排列)

    网上找了个瀑布流的图片排列插件.从数据库读取图片路径后显示时出现了位置重叠问题. $.ajax({ type: "POST", url: "index.aspx" ...

  8. html中图片自适应浏览器和屏幕,宽度高度自适应

    1.(宽度自适应):在网页代码的头部,加入一行viewport元标签. <meta name="viewport" content="width=device-wi ...

  9. HMS Core AR Engine 2D图片/3D物体跟踪技术 助力打造更智能AR交互体验

    AR技术已经被广泛应用于营销.教育.游戏.展览等场景.通过2D图像跟踪技术和3D物体跟踪技术,用户只需使用一台手机进行拍摄,即可实现海报.卡牌等平面物体以及文物.手办等立体物体的AR效果.尽管近年来2 ...

随机推荐

  1. Go Programming Language 2

    [Go Programming Language 2] 1.In Go, the sign of the remainder is always the same as the sign of the ...

  2. node_promise

    学习链接 http://liubin.org/promises-book/#__5

  3. SDOI2010选做

    Round1 D1T1外星千足虫 \(BSOJ2793\)--高斯消元解异或方程组 简述 有\(n\)个数\(\{a_i\}\) 给出\(m\)个信息,每个信息给出\(\displaystyle{(\ ...

  4. python发邮件报错SMTP AUTH extension not supported by server."

    在login(username,password)之前添加 smtp.ehlo() smtp.starttls() d ={'smtp_server': '','smtp_email': '','sm ...

  5. Chrome DevTools的使用

    一.Chrome DevTools 简介 Chrome 开发者工具是一套内置于Google Chrome中的Web开发和调试工具,可用来对网站进行迭代.调试和分析 手册:Chrome 开发者工具中文手 ...

  6. ABP 网站发布

    报错1:HTTP Error 503. The service is unavailable. 解决:IIS->应用程序池->高级设置->进程模型->标识.将内置账户更改为Ne ...

  7. vue CSS使用/deep/

    比如你使用了别人的组件或者自己开发一个组件,有时候你修改一处就可能影响到别的地方,这个时候要么你不用别人的组件,自己重新封装一个,但很多时候是不太现实的,所以就需要有一个方法或者方式,既不影响到别的地 ...

  8. JAVA程序执行顺序(静态代码块》非静态代码块》静态方法》构造函数)

    总结:静态代码块总是最先执行. 非静态代码块跟非静态方法一样,跟对象有关.只不过非静态代码块在构造函数之前执行. 父类非静态代码块.构造函数执行完毕后(相当于父类对象初始化完成), 才开始执行子类的非 ...

  9. nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件

    前言一.nginx简介1. 什么是 nginx 和可以做什么事情Nginx 是高性能的 HTTP 和反向代理的web服务器,处理高并发能力是十分强大的,能经受高负 载的考验,有报告表明能支持高达 50 ...

  10. Failed to contact the endpoint at http://controller:35357/ for discovery. Fallback to using that endpoint as the base url.

    问题描述 openstack安装过程中,执行 openstack domain create --description "Domain" example 报错如下: Failed ...