iOS---transform类的使用,平移,缩放,旋转效果的实现

尚宏硕
2023-12-01

UIButton  *btn = (UIButton *)sender;
    
   //----------平移------------

    // CGAffineTransformMakeTranslation(0, -100) 是相对于原来的view的初始位置的移动(ty:-100----向上移动100,这个只会有一次向上移动的效果
//    btn.transform = CGAffineTransformMakeTranslation(0, -100);
    
    
    //是在当前的transform的基础上,每次向上移动100,每次点击都会出现效果。默认情况下transform的值都是:0;
   btn.transform = CGAffineTransformTranslate(btn.transform, 0, -100);
    
    
    
   // ----------旋转---------
    
    //使用弧度值的,正数顺时针转,负数逆时针转,相对原来的初始位置作用一次,所以就只会出现一次旋转效果
//    btn.transform = CGAffineTransformMakeRotation(M_PI_4);
    
    //每次在当前的transform上,改变m_pi_4,每次点击都会出现旋转的效果
    btn.transform = CGAffineTransformRotate(btn.transform, M_PI_4);



// ----------旋转---------
    
    //使用弧度值的,正数顺时针转,负数逆时针转,相对原来的初始位置作用一次,所以就只会出现一次旋转效果
//    btn.transform = CGAffineTransformMakeRotation(M_PI_4);
    
    //每次在当前的transform上,改变m_pi_4,每次点击都会出现旋转的效果
//    btn.transform = CGAffineTransformRotate(btn.transform, M_PI_4);
    
    
     // ----------缩放---------
    //放大,缩小的比例,比如放大使用设置比1大,缩小设置成1小
//    btn.transform = CGAffineTransformMakeScale(1.5, 1.5);
    btn.transform = CGAffineTransformScale(btn.transform, 1.5, 1.5);


 类似资料: