首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用搅拌器创建平铺地图

使用搅拌器创建平铺地图
EN

Stack Overflow用户
提问于 2010-06-02 20:38:35
回答 1查看 1.7K关注 0票数 2

我正在考虑创建基于搅拌器制作的3D模型的地图瓦片,

该贴图在搅拌器中为16 x 16。

我有4个不同的缩放级别,每个瓦片都是100 x 100像素。最大缩小级别的整个地图是4 x 4平铺,构成了一个400 x 400的图像。

最大的放大级别是256x256,显然是构建了一个25600 x 25600的图像

我需要的是一个搅拌器的脚本,可以从模型创建瓷砖。

我以前从来没有用python写过,所以我一直在试着改编一些已经存在的脚本。

到目前为止,我已经想出了一个脚本,但它并不能很好地工作。我真的很难让瓷砖无缝地排成一排。我不太关心改变相机的高度,因为我总是可以在6400 x 6400图像上创建相同的缩小平铺,并将生成的图像分割成正确的平铺。

这是我到目前为止得到的..。

代码语言:javascript
复制
#!BPY

"""
Name: 'Export Map Tiles'
Blender: '242'
Group: 'Export'
Tip: 'Export to Map'
"""

import Blender
from Blender import Scene,sys
from Blender.Scene import Render

def init():
        thumbsize = 200
        CameraHeight = 4.4
        YStart = -8
        YMove = 4
        XStart = -8
        XMove = 4
        ZoomLevel = 1
        Path = "/Images/Map/"
        Blender.drawmap = [thumbsize,CameraHeight,YStart,YMove,XStart,XMove,ZoomLevel,Path]


def show_prefs():
        buttonthumbsize = Blender.Draw.Create(Blender.drawmap[0]);
        buttonCameraHeight = Blender.Draw.Create(Blender.drawmap[1])
        buttonYStart = Blender.Draw.Create(Blender.drawmap[2])
        buttonYMove = Blender.Draw.Create(Blender.drawmap[3])
        buttonXStart = Blender.Draw.Create(Blender.drawmap[4])
        buttonXMove = Blender.Draw.Create(Blender.drawmap[5])
        buttonZoomLevel = Blender.Draw.Create(Blender.drawmap[6])
        buttonPath = Blender.Draw.Create(Blender.drawmap[7])

    block = []
    block.append(("Image Size", buttonthumbsize, 0, 500))
    block.append(("Camera Height", buttonCameraHeight, -0, 10))
    block.append(("Y Start", buttonYStart, -10, 10))
    block.append(("Y Move", buttonYMove, 0, 5))
    block.append(("X Start", buttonXStart,-10, 10))
    block.append(("X Move", buttonXMove, 0, 5))
    block.append(("Zoom Level", buttonZoomLevel, 1, 10))
    block.append(("Export Path", buttonPath,0,200,"The Path to save the tiles"))

    retval = Blender.Draw.PupBlock("Draw Map: Preferences" , block)

    if retval:
        Blender.drawmap[0] = buttonthumbsize.val
        Blender.drawmap[1] = buttonCameraHeight.val
        Blender.drawmap[2] = buttonYStart.val
        Blender.drawmap[3] = buttonYMove.val
        Blender.drawmap[4] = buttonXStart.val
        Blender.drawmap[5] = buttonXMove.val
        Blender.drawmap[6] = buttonZoomLevel.val
        Blender.drawmap[7] = buttonPath.val
        Export()

def Export():
    scn = Scene.GetCurrent()
    context = scn.getRenderingContext()

    def cutStr(str): #cut off path leaving name
        c = str.find("\\")
        while c != -1:
            c = c + 1
            str = str[c:]
            c = str.find("\\")

        str = str[:-6]
        return str

    #variables from gui:
    thumbsize,CameraHeight,YStart,YMove,XStart,XMove,ZoomLevel,Path = Blender.drawmap


    XMove = XMove / ZoomLevel
    YMove = YMove / ZoomLevel
    Camera = Scene.GetCurrent().getCurrentCamera()
    Camera.LocZ = CameraHeight / ZoomLevel
    YStart = YStart + (YMove / 2)
    XStart = XStart + (XMove / 2)

    #Point it straight down
    Camera.RotX = 0
    Camera.RotY = 0
    Camera.RotZ = 0
    TileCount = 4**ZoomLevel
    #Because the first thing we do is move the camera, start it off the map
    Camera.LocY = YStart - YMove
    for i in range(0,TileCount):
        Camera.LocY = Camera.LocY + YMove
        Camera.LocX = XStart - XMove
        for j in range(0,TileCount):
            Camera.LocX = Camera.LocX + XMove
            Render.EnableDispWin()
            context.extensions = True
            context.renderPath = Path

            #setting thumbsize
            context.imageSizeX(thumbsize)
            context.imageSizeY(thumbsize)

            #could be put into a gui.
            context.imageType = Render.PNG
            context.enableOversampling(0)

            #render
            context.render()

            #save image
            ZasString = '%s' %(int(ZoomLevel))
            XasString = '%s' %(int(j+1))
            YasString = '%s' %(int((3-i)+1))
            context.saveRenderedImage("Z" + ZasString + "X" + XasString + "Y" + YasString)

            #close the windows

            Render.CloseRenderWindow()

try:
        type(Blender.drawmap)
except:
        #print 'initialize extern variables'
        init()
show_prefs()    
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2010-06-18 19:19:02

最终,这是相对简单的。

我放大了模型,使地图上的1个瓦片是搅拌器中的1个网格。

将相机设置为正交。

将相机上的比例设置为1表示最高缩放,4表示下一个缩放,16表示下一个缩放,依此类推。

相应地更新了起始坐标和移动值。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2957702

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档