远程推送 Demo

#import <UIKit/UIKit.h>

//专门写常量值的

// 以下的格式, 只是对常量的声明
//extern: 代表其他类可以引用
extern NSString *const LEESkinToolLabelTextDayColor;
extern NSString *const LEESkinToolLabelBackgroundDayColor;

@interface LEESkinTools : NSObject


/** 返回对应的皮肤的图像*/
+ (UIImage *)imageWithImageName:(NSString *)imageName;

/** 保存皮肤信息*/
+ (void)saveSkinName:(NSString *)skinName;

/** 返回制定标识符所对应的颜色*/
+ (UIColor *)colorWithName:(NSString *)name;

@end
#import "LEESkinTools.h"

//专门写常量值的

// 以下的格式, 只是对常量的声明
NSString *const LEESkinToolLabelTextDayColor = @"labelTextDayColor";
NSString *const LEESkinToolLabelBackgroundDayColor = @"labelBackgroundDayColor";

static NSString *_skinName;

//#1. 创建一个static的可变字典
static NSMutableDictionary *_colorDict;

@implementation LEESkinTools

/**
 保证代码只加载一次:
 1. 多线程 --> dispatchOnce
 2. 只调用一次的方法
 */

/** load方法, 只要头文件参与了编译就会调用此方法 */
+ (void)load
{
    NSLog(@"%s",__func__);
}

/** 类的实例创建时, 才会调用此方法*/
+ (void)initialize
{
    //1. 读取偏好设置信息 --> 访问磁盘是耗性能的, 所以只需要加载一次即可
//    _skinName = [[NSUserDefaults standardUserDefaults] objectForKey:@"skinName"];

    if (_skinName == nil) {
        _skinName = @"green";
    }

    //#2. 可变字典做初始化
    _colorDict = [NSMutableDictionary dictionary];

    //#3. 加载颜色plist
    [self loadColorDict];
}


/** 返回对应的皮肤的图像*/
+ (UIImage *)imageWithImageName:(NSString *)imageName
{
    //1. 拼接文件路径
    NSString *imageStr = [NSString stringWithFormat:@"skin/%@/%@",_skinName,imageName];

    //2. 返回一个指定的图像
    return [UIImage imageNamed:imageStr];
}

/** 保存皮肤信息*/
+ (void)saveSkinName:(NSString *)skinName
{

    //当皮肤读取改变成一次之后, 那么我们做皮肤切换保存操作, 原来的_skinName

    //更改皮肤
    _skinName = skinName;

    // 当设置了不同皮肤时, 我们还需要将皮肤plist颜色信息进行重新加载
    [self loadColorDict];

    //保存皮肤
    [[NSUserDefaults standardUserDefaults] setObject:skinName forKey:@"skinName"];
    [[NSUserDefaults standardUserDefaults] synchronize];
}


/** 返回制定标识符所对应的颜色*/
+ (UIColor *)colorWithName:(NSString *)name
{
    NSLog(@"%@",name);
    return _colorDict[name];
}

/** 初始化时需要调用一次, 来加载字典及转换颜色*/
+ (void)loadColorDict
{
    //1. 获取plist列表
    //2. 颜色转换(255,0,0,1 --> UIColor对象)

    //1. plist只需要加载一次
    //2. 将转换后的UIColor做保存

    //1. 获取plist路径
    NSString *pathStr = [NSString stringWithFormat:@"skin/%@/SkinColors.plist",_skinName];

    NSString *path = [[NSBundle mainBundle] pathForResource:pathStr ofType:nil];

    //2. 获取字典
    NSDictionary *colorDict = [NSDictionary dictionaryWithContentsOfFile:path];

    //3. 直接获取所有颜色值将其转换成UIColor对象
    [colorDict enumerateKeysAndObjectsUsingBlock:^(id  _Nonnull key, id  _Nonnull colorStr, BOOL * _Nonnull stop) {

        //4. 截取字符串
        NSArray *colorArr = [colorStr componentsSeparatedByString:@","];

        //5. 创建颜色赋值给缓存字典
        CGFloat r = [colorArr[0] doubleValue];
        CGFloat g = [colorArr[1] doubleValue];
        CGFloat b = [colorArr[2] doubleValue];
        CGFloat a = [colorArr[3] doubleValue];

        //字典的里面存的是转换好的UIColor对象, 当设置切换皮肤后, 需要重新调用此方法, 进行_colorDict的更新
        _colorDict[key] = [UIColor colorWithRed:r / 255.0 green:g / 255.0 blue:b / 255.0 alpha:a];
    }];
}

@end

storyboard 中的空间拖线在这里就省略了,直接调用工具类实现

#import "ViewController.h"
#import "LEESkinTools.h"

@interface ViewController ()

@property (weak, nonatomic) IBOutlet UIImageView *faceView;
@property (weak, nonatomic) IBOutlet UIImageView *heartView;
@property (weak, nonatomic) IBOutlet UIImageView *rectView;

@property (weak, nonatomic) IBOutlet UILabel *label;

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];

    // 启动时加载皮肤
    [self changeSkinWithSkinName:nil];
}

- (IBAction)redClick:(id)sender {

    // 切换皮肤
    [self changeSkinWithSkinName:@"red"];
}

- (IBAction)greenClick:(id)sender {
    // 切换皮肤
    [self changeSkinWithSkinName:@"green"];
}

- (IBAction)blueClick:(id)sender {
    // 切换皮肤
    [self changeSkinWithSkinName:@"blue"];
}

- (IBAction)orangeClick:(id)sender {
    // 切换皮肤
    [self changeSkinWithSkinName:@"orange"];
}

//抽取公用方法
- (void)changeSkinWithSkinName:(NSString *)skinName
{
    // 判断如果皮肤名称传了空, 那么不用管保存
    if (skinName != nil) {
        [LEESkinTools saveSkinName:skinName];
    }

    // 切换图像
    self.faceView.image = [LEESkinTools imageWithImageName:@"face"];
    self.heartView.image = [LEESkinTools imageWithImageName:@"heart"];
    self.rectView.image = [LEESkinTools imageWithImageName:@"rect"];

    // 切换文字颜色
    self.label.textColor = [LEESkinTools colorWithName:LEESkinToolLabelTextDayColor];

    // 切换背景颜色
    self.label.backgroundColor = [LEESkinTools colorWithName:LEESkinToolLabelBackgroundDayColor];
}

@end
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全评估测试题大模型安全评估测试题关键词库生成内容测试题库应拒答测试题库非拒答测试题大模型安全
### 回答1: 1400协议 demo 是一种用于推送图片的协议,以下是一种可能的300字中文回答。 1400协议 demo 是一种用于推送图片的协议,其主要作用是通过网络将图像数据从服务器传输到设备。这种协议通常被应用于远程监控、图像传感器等领域。 使用1400协议 demo 推送图片的过程大致如下:首先,设备需要与服务器建立连接,建立后设备可以向服务器发送请求。请求中通常包含设备的身份标识和请求的数据类型,这里是图片。服务器接收到请求后,会根据设备标识和数据类型准备相应的图像数据。 在数据准备完毕后,服务器会使用1400协议 demo 将图像数据进行打包和编码,并将其发送给设备。设备在接收到数据后,会解码并将图像显示在屏幕上。同时,设备还可能会执行一些额外的处理,比如图像保存、图像分析等。 在这个过程中,协议的设计和实现非常重要。1400协议 demo 采用了特定的数据格式和通信规则,以确保数据的准确传输和设备的正确解析。同时,协议还可能包含错误处理和安全机制,以应对网络不稳定和数据篡改等问题。 总的来说,1400协议 demo 是一种用于推送图片的专用协议,通过该协议,服务器可以将图像数据及时地传输给设备,实现远程监控、图像传感器等功能。协议的设计和实现对保证数据传输的可靠性和设备的稳定运行非常重要。 ### 回答2: 1400协议是一种用于网络通信的协议,用于在应用程序之间进行数据传输。而demo是指演示样本。所以,将1400协议与demo结合起来,就是通过1400协议来实现推送图片的演示。 要使用1400协议推送图片,首先需要确定一方作为图片的发送者,另一方作为接收者。发送者将图片数据打包成数据包,并使用1400协议将数据包发送给接收者。接收者收到数据包后,解析数据包中的图片数据,并进行相应的处理,例如展示图片或保存图片等。 在具体实现过程中,可以使用网络套接字编程来建立发送方和接收方之间的通信。发送方将图像转换为字节流,并将字节流进行分段打包成数据包,每个数据包中包含一部分字节流。然后,发送方使用1400协议将数据包依次发送给接收方。接收方通过解析数据包,将每个数据包中的字节流合并起来,从而恢复完整的图像。最后,接收方可以对图像进行相应的处理操作。 通过这样的方式,使用1400协议进行图像推送demo可以实现。在实际应用中,可以根据需要对1400协议进行定制和优化,以满足具体的业务需求。 ### 回答3: 1400协议是一种用于服务器与客户端之间进行通信的协议。在这个协议中,demo是指示服务器向客户端展示某个功能或操作示例的请求。 如果要通过1400协议进行demo推送图片的话,可以按照以下步骤进行: 1. 服务器收到demo请求后,判断需要展示的图片是已经存在服务器上的,还是需要动态生成。 2. 如果图片已经存在服务器上,服务器将图片的路径和相关信息以消息的形式发送给客户端。 3. 客户端收到服务器发来的消息后,根据消息中的图片路径和信息,通过1400协议请求服务器获取该图片。 4. 服务器收到客户端的请求后,将图片文件以二进制的形式发送给客户端。 5. 客户端接收到服务器发送的图片后,将其展示在相应的界面上。 需要注意的是,demo推送图片的过程中,服务器和客户端需要基于1400协议进行通信,确保消息的传输是准确和可靠的。同时,服务器需要确保图片的存储路径和相关信息的准确性,以供客户端正确地获取和展示图片。 以上是关于使用1400协议进行demo推送图片的一个简要描述,具体的实现可能会根据具体的系统和需求有所不同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值