技术杂谈(1)

Linux相关

1 Linux下进程在后台运行的方式:nohup <程序名> &

2 Linux下执行定时任务:crontab -l (显示)  crontab -e (编辑)

   30 21 * * * /usr/local/etc/rc.d/lighttpd restart 

   表示每晚的21:30重启apache

3 Linux下多线程下载工具:Axel

4 Linux下的查找命令使用:find -name '*.php' -exec grep -H '{$content}' {} \;

5 Linux下使用tar命令:

   tar -zxvf /tmp/etc.tar.gz

6 Linux下下载文件一般使用wget

调试相关

ndk-stack:platform-tools/adb logcat | xxx/ndk-stack -sym projectxxx/proj.android/obj/local/armeabi

在cocos2d-x开发时,Android很有可能会出现Native相关的错误,可以通过上述的方法查看错误堆栈。

Lua中调试:

pcall

blob.png

 

 

 

 

 

 

 

 

 

 

 

 

xpcall

blob.png

debug相当于Lua中的断点功能,大家有兴趣的可以试试。

批处理创建文件夹的文件列表:dir /b/a-d-s-h-r/on *.* > list.txt

Cocos2d-x开发

cocos2d-x中的plist图片进行拆分:

PlistToPngFormat_cocos.py

#!python
import os,sys
from xml.etree import ElementTree
from PIL import Image
 
def tree_to_dict(tree):
    d = {}
    for index, item in enumerate(tree):
        if item.tag == 'key':
            if tree[index+1].tag == 'string':
                d[item.text] = tree[index + 1].text
            elif tree[index + 1].tag == 'true':
                d[item.text] = True
            elif tree[index + 1].tag == 'false':
                d[item.text] = False
            elif tree[index+1].tag == 'dict':
                d[item.text] = tree_to_dict(tree[index+1])
    return d
 
def gen_png_from_plist(plist_filename, png_filename):
    file_path = plist_filename.replace('.plist', '')
    big_image = Image.open(png_filename)
    root = ElementTree.fromstring(open(plist_filename, 'r').read())
    plist_dict = tree_to_dict(root[0])
    to_list = lambda x: x.replace('{','').replace('}','').split(',')
    for k,v in plist_dict['frames'].items():
        rectlist = to_list(v['frame'])
        width = int( rectlist[3] if v['rotated'] else rectlist[2] )
        height = int( rectlist[2] if v['rotated'] else rectlist[3] )
        box=( 
            int(rectlist[0]),
            int(rectlist[1]),
            int(rectlist[0]) + width,
            int(rectlist[1]) + height,
            )
        sizelist = [ int(x) for x in to_list(v['sourceSize'])]
        rect_on_big = big_image.crop(box)
 
        if v['rotated']:
            rect_on_big = rect_on_big.rotate(90)
 
        result_image = Image.new('RGBA', sizelist, (0,0,0,0))
        if v['rotated']:
            result_box=(
                ( sizelist[0] - height )/2,
                ( sizelist[1] - width )/2,
                ( sizelist[0] + height )/2,
                ( sizelist[1] + width )/2
                )
        else:
            result_box=(
                ( sizelist[0] - width )/2,
                ( sizelist[1] - height )/2,
                ( sizelist[0] + width )/2,
                ( sizelist[1] + height )/2
                )
        result_image.paste(rect_on_big, result_box, mask=0)
 
        if not os.path.isdir(file_path):
            os.mkdir(file_path)
        outfile = (file_path+'/' + k).replace('gift_', '')
        print outfile, "generated"
        result_image.save(outfile)
 
if __name__ == '__main__':
    filename = sys.argv[1]
    plist_filename = filename + '.plist'
    png_filename = filename + '.png'
    if (os.path.exists(plist_filename) and os.path.exists(png_filename)):
        gen_png_from_plist( plist_filename, png_filename )
    else:
        print "make sure you have boith plist and png files in the same directory"

PlistToPngFormat_common.py

#!python
import os,sys
from xml.etree import ElementTree
from PIL import Image
 
def tree_to_dict(tree):
    d = {}
    for index, item in enumerate(tree):
        if item.tag == 'key':
            if tree[index+1].tag == 'string':
                d[item.text] = tree[index + 1].text
            elif tree[index + 1].tag == 'true':
                d[item.text] = True
            elif tree[index + 1].tag == 'false':
                d[item.text] = False
            elif tree[index+1].tag == 'dict':
                d[item.text] = tree_to_dict(tree[index+1])
            elif tree[index+1].tag == 'integer':
                d[item.text] = tree[index + 1].text
    return d
 
def gen_png_from_plist(plist_filename, png_filename):
    file_path = plist_filename.replace('.plist', '')
    big_image = Image.open(png_filename)
    root = ElementTree.fromstring(open(plist_filename, 'r').read())
    plist_dict = tree_to_dict(root[0])
    for k,v in plist_dict['frames'].items():
        width = int(v['width'])
        height = int(v['height'])
        curr_x = int(v['x'])
        curr_y = int(v['y'])
        box=( 
            curr_x,
            curr_y,
            curr_x + width,
            curr_y + height,
            )
        sizelist = [int(v['originalWidth']), int(v['originalHeight'])]
        rect_on_big = big_image.crop(box)
 
        result_image = Image.new('RGBA', sizelist, (0,0,0,0))
        result_box=(
            ( sizelist[0] - width )/2,
            ( sizelist[1] - height )/2,
            ( sizelist[0] + width )/2,
            ( sizelist[1] + height )/2
            )
        result_image.paste(rect_on_big, result_box, mask=0)
        print file_path
        if not os.path.isdir(file_path):
            os.mkdir(file_path)
        outfile = (file_path+'/' + k).replace('gift_', '')
        print outfile, "generated"
        result_image.save(outfile)
 
if __name__ == '__main__':
    filename = sys.argv[1]
    plist_filename = filename + '.plist'
    png_filename = filename + '.png'
    if (os.path.exists(plist_filename) and os.path.exists(png_filename)):
        gen_png_from_plist( plist_filename, png_filename )
    else:
        print "make sure you have boith plist and png files in the same directory"

TexturePacker 命令行 打图

TexturePacker --size-constraints AnySize --pack-mode Best --opt RGBA4444 --dither-fs-alpha --reduce-border-artifacts --data C:/test/tools/PlistToPng/AllNums.plist --format cocos2d --sheet C:/test/tools/PlistToPng/AllNums.png C:/test/tools/PlistToPng/AllNums

转载于:https://www.cnblogs.com/TomYuan/p/5130798.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值