裁切区域

新建工程testClip

添加类ClipLayer

ClipLayer.h

//

//  ClipLayer.h

//  testClip

//

//  Created by cloud on 13-4-11.

//

//


#ifndef __testClip__ClipLayer__

#define __testClip__ClipLayer__


#include "cocos2d.h"

using namespace cocos2d;

class ClipLayer:public CCLayer

{

public:

    static ClipLayer *create(CCSize size);

    void clipLayerInit(CCSize size);

    void visit();

    CCSize mSize;

};


#endif /* defined(__testClip__ClipLayer__) */


ClipLayer.cpp

//

//  ClipLayer.cpp

//  testClip

//

//  Created by cloud on 13-4-11.

//

//


#include "ClipLayer.h"

ClipLayer *ClipLayer::create(CCSize size)

{

    ClipLayer *nCLayer=new ClipLayer();

    if (nCLayer&&nCLayer->init()) {

        nCLayer->autorelease();

        nCLayer->clipLayerInit(size);

        return nCLayer;

    }

    CC_SAFE_DELETE(nCLayer);

    return NULL;

}

void ClipLayer::clipLayerInit(CCSize size)

{

    mSize=size;   

    

}

void ClipLayer::visit()

{

    kmGLPushMatrix();

    

    if (m_pGrid&&m_pGrid->isActive()) {

        m_pGrid->beforeDraw();

        this->transformAncestors();

    }

    this->transform();

    

    //默认情况,剪裁是禁用的

    glEnable(GL_SCISSOR_TEST);//启用剪裁测试

    

    float s= this->getScale();//当前layer缩放的倍数

    //获取缩放倍率

    s *=CCDirector::sharedDirector()->getContentScaleFactor();

    CCPoint screenPos=this->convertToWorldSpace(this->getParent()->getPosition());

    //默认不设置Scissor的大小是整个视图的大小

    glScissor((GLint)screenPos.x, (GLint)screenPos.y, (GLsizei)(mSize.width*s), (GLsizei)(mSize.height*s));

    

    if (m_pChildren) {

        ccArray *arrayData=m_pChildren->data;

        unsigned int i=0;

        for (; i<arrayData->num; i++)

        {

            CCNode *child=(CCNode *)arrayData->arr[i];

            if(child->getZOrder()<0)

            {                

                child->visit();                

            }

            else

            {

                break;

            }


        }

        this->draw();

        for (;i<arrayData->num; i++) {

            CCNode *child=(CCNode*)arrayData->arr[i];

            child->visit();

        }

    }

    else

    {

        this->draw();

    }

    glDisable(GL_SCISSOR_TEST);//禁用剪裁

    if (m_pGrid&&m_pGrid->isActive()) {

        m_pGrid->afterDraw(this);

    }

    kmGLPopMatrix();

    

}

修改HelloWorldScene.cpp

#include "HelloWorldScene.h"

#include "SimpleAudioEngine.h"

#include "ClipLayer.h"


using namespace cocos2d;

using namespace CocosDenshion;


CCScene* HelloWorld::scene()

{

    // 'scene' is an autorelease object

    CCScene *scene = CCScene::create();

    

    // 'layer' is an autorelease object

    HelloWorld *layer = HelloWorld::create();


    // add layer as a child to scene

    scene->addChild(layer);


    // return the scene

    return scene;

}


// on "init" you need to initialize your instance

bool HelloWorld::init()

{

    //////////////////////////////

    // 1. super init first

    if ( !CCLayer::init() )

    {

        return false;

    }


#define clipMacro 3

    switch (clipMacro) {

        case 1:

        {

            CCLabelTTF *label=CCLabelTTF::create("正常精灵", "Helvetica", 24);

            label->setPosition(ccp(100,260));

            addChild(label);

            CCLabelTTF *clipLabel=CCLabelTTF::create("剪裁后的精灵", "Helvetica",24);

            clipLabel->setPosition(ccp(300,260));

            addChild(clipLabel);

            

            CCSprite *sprite=CCSprite::create("Icon.png");

            sprite->setPosition(ccpAdd(label->getPosition(), ccp(0,-100)));

            addChild(sprite);

            

            CCSprite *clipSprite=CCSprite::create("Icon.png");

            clipSprite->setPosition(ccpAdd(clipLabel->getPosition(), ccp(0,-100)));

            clipSprite->setTextureRect(CCRectMake(0, 0, 30, 30));

            addChild(clipSprite);


        }

            break;

        case 2:

        {

            CCLayer *layer=CCLayer::create();

            layer->setPosition(ccp(190,110));//Icon不应该显示全,但它显示全了,说明没剪裁

            layer->addChild(CCSprite::create("Icon.png"));

            addChild(layer);

        }

            break;

        case 3:

        {

            CCSize size = CCDirector::sharedDirector()->getWinSize();

            CCLayerColor* colorBg = CCLayerColor::create(ccc4(255, 127, 0, 255), size.width,size.height);

            addChild(colorBg);


            

            ClipLayer *clipLayer=ClipLayer::create(CCSizeMake(100, 100));

            clipLayer->setPosition(ccp(190,110));

            clipLayer->addChild(CCSprite::create("Icon.png"));

            addChild(clipLayer);

        }

            break;

        default:

            break;

    }

    

    

    return true;

}



### 使用Python根据指定区域裁剪TIF图像 对于基于特定地理坐标(即经纬度)来裁剪TIFF影像的需求,可以利用`rasterio`库读取带有地理信息的栅格数据,并通过定义感兴趣区(AOI)的空间范围完成裁剪工作[^1]。下面是一个简单的例子展示如何实现这一功能: #### 安装必要的包 首先确保安装了所需的软件包: ```bash pip install rasterio shapely fiona geopandas ``` #### 裁剪代码示例 接下来提供一段用于按照给定边界框(最小经度, 最小纬度, 最大经度, 最大纬度)裁剪输入GeoTIFF文件并保存结果到新位置的Python脚本。 ```python import os import rasterio from rasterio.mask import mask from shapely.geometry import box import geopandas as gpd from fiona.crs import from_epsg def tif_clip_by_bbox(input_raster, output_raster, bbox): """ 根据bbox参数中的空间范围对input_raster进行裁剪, 并将裁剪后的结果存储至output_raster路径下。 参数: input_raster (str): 输入.tif 文件路径. output_raster (str): 输出.tif 文件路径. bbox (tuple): 边界框元组形式(minX,minY,maxX,maxY). 返回值: None """ # 创建几何对象表示要裁剪的矩形区域 geom = box(*bbox) # 将其转换成 GeoDataFrame 类型以便后续处理 geo = gpd.GeoDataFrame({'geometry': [geom]}, crs=from_epsg(4326)) with rasterio.open(input_raster) as src: out_image, out_transform = mask(src, geo['geometry'], crop=True) out_meta = src.meta.copy() # 更新元数据以反映新的尺寸和变换矩阵 out_meta.update({"driver": "GTiff", "height": out_image.shape[1], "width": out_image.shape[2], "transform": out_transform}) # 写入裁剪后的 TIFF 文件 with rasterio.open(output_raster, "w", **out_meta) as dest: dest.write(out_image) # 测试函数调用 tif_clip_by_bbox('path_to_input_file.tif', 'path_to_output_file_clipped.tif', (-78.925, 35.875, -78.875, 35.925)) # 这里填写实际使用的经纬度范围 ``` 此段程序会打开原始`.tif`文件,应用由`bbox`变量所描述的窗口来进行裁剪操作,最后把得到的新图片存放到指定的位置上。注意这里的EPSG码设置为4326意味着使用WGS84作为投影参考系;如果源文件采用了同的CRS,则可能需要调整这部分配置以匹配实际情况。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值