This commit is contained in:
启星
2025-10-30 18:30:45 +08:00
parent aa356202e2
commit c92b8eb910
11 changed files with 297 additions and 87 deletions

View File

@@ -748,7 +748,7 @@
CODE_SIGN_ENTITLEMENTS = QXLive/QXLive.entitlements; CODE_SIGN_ENTITLEMENTS = QXLive/QXLive.entitlements;
CODE_SIGN_IDENTITY = "Apple Development"; CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Automatic; CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = 2; CURRENT_PROJECT_VERSION = 1;
DEVELOPMENT_TEAM = 8798G5VMH9; DEVELOPMENT_TEAM = 8798G5VMH9;
ENABLE_USER_SCRIPT_SANDBOXING = NO; ENABLE_USER_SCRIPT_SANDBOXING = NO;
FRAMEWORK_SEARCH_PATHS = ( FRAMEWORK_SEARCH_PATHS = (
@@ -787,7 +787,7 @@
"$(inherited)", "$(inherited)",
"$(SDKROOT)/usr/lib/swift", "$(SDKROOT)/usr/lib/swift",
); );
MARKETING_VERSION = 1.1.0; MARKETING_VERSION = 1.1.2;
PRODUCT_BUNDLE_IDENTIFIER = com.qxcm.qxlive; PRODUCT_BUNDLE_IDENTIFIER = com.qxcm.qxlive;
PRODUCT_NAME = "$(TARGET_NAME)"; PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE_SPECIFIER = ""; PROVISIONING_PROFILE_SPECIFIER = "";
@@ -814,7 +814,7 @@
CODE_SIGN_ENTITLEMENTS = QXLive/QXLive.entitlements; CODE_SIGN_ENTITLEMENTS = QXLive/QXLive.entitlements;
CODE_SIGN_IDENTITY = "Apple Development"; CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Automatic; CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = 2; CURRENT_PROJECT_VERSION = 1;
DEVELOPMENT_TEAM = 8798G5VMH9; DEVELOPMENT_TEAM = 8798G5VMH9;
ENABLE_USER_SCRIPT_SANDBOXING = NO; ENABLE_USER_SCRIPT_SANDBOXING = NO;
FRAMEWORK_SEARCH_PATHS = ( FRAMEWORK_SEARCH_PATHS = (
@@ -853,7 +853,7 @@
"$(inherited)", "$(inherited)",
"$(SDKROOT)/usr/lib/swift", "$(SDKROOT)/usr/lib/swift",
); );
MARKETING_VERSION = 1.1.0; MARKETING_VERSION = 1.1.2;
PRODUCT_BUNDLE_IDENTIFIER = com.qxcm.qxlive; PRODUCT_BUNDLE_IDENTIFIER = com.qxcm.qxlive;
PRODUCT_NAME = "$(TARGET_NAME)"; PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE_SPECIFIER = ""; PROVISIONING_PROFILE_SPECIFIER = "";
@@ -1207,7 +1207,7 @@
"$(inherited)", "$(inherited)",
"$(SDKROOT)/usr/lib/swift", "$(SDKROOT)/usr/lib/swift",
); );
MARKETING_VERSION = 1.1.0; MARKETING_VERSION = 1.0.0;
PRODUCT_BUNDLE_IDENTIFIER = com.qxcm.qxlive.test; PRODUCT_BUNDLE_IDENTIFIER = com.qxcm.qxlive.test;
PRODUCT_NAME = "$(TARGET_NAME)"; PRODUCT_NAME = "$(TARGET_NAME)";
SUPPORTED_PLATFORMS = "iphoneos iphonesimulator"; SUPPORTED_PLATFORMS = "iphoneos iphonesimulator";
@@ -1271,7 +1271,7 @@
"$(inherited)", "$(inherited)",
"$(SDKROOT)/usr/lib/swift", "$(SDKROOT)/usr/lib/swift",
); );
MARKETING_VERSION = 1.1.0; MARKETING_VERSION = 1.0.0;
PRODUCT_BUNDLE_IDENTIFIER = com.qxcm.qxlive.test; PRODUCT_BUNDLE_IDENTIFIER = com.qxcm.qxlive.test;
PRODUCT_NAME = "$(TARGET_NAME)"; PRODUCT_NAME = "$(TARGET_NAME)";
SUPPORTED_PLATFORMS = "iphoneos iphonesimulator"; SUPPORTED_PLATFORMS = "iphoneos iphonesimulator";

View File

@@ -80,6 +80,7 @@
[delegate changeRootViewControllerIsTabbar]; [delegate changeRootViewControllerIsTabbar];
BOOL api_version = [responseObject[@"api_version"] boolValue]; BOOL api_version = [responseObject[@"api_version"] boolValue];
TUIChatConfig.defaultConfig.isAppStore = api_version; TUIChatConfig.defaultConfig.isAppStore = api_version;
[QXGlobal shareGlobal].isAppStore = api_version;
NSLog(@"请求成功"); NSLog(@"请求成功");
} fail:^(NSError *error, NSString *msg, NSURLSessionDataTask *task) { } fail:^(NSError *error, NSString *msg, NSURLSessionDataTask *task) {
NSLog(@"请求失败"); NSLog(@"请求失败");

View File

@@ -26,6 +26,8 @@ typedef void (^showFinishBlock)(void);
@property (nonatomic,strong)NSString *roomId; @property (nonatomic,strong)NSString *roomId;
// 是否实名 // 是否实名
@property (nonatomic,assign)BOOL isRealName; @property (nonatomic,assign)BOOL isRealName;
/// 是否为appstore
@property (nonatomic,assign)BOOL isAppStore;
/// 钻石兑币比例 /// 钻石兑币比例
@property (nonatomic,strong)NSString *coin_exchange_rate; @property (nonatomic,strong)NSString *coin_exchange_rate;

View File

@@ -28,7 +28,23 @@
@property (nonatomic,strong)QXExpansionAppStoreSubView *userView6; @property (nonatomic,strong)QXExpansionAppStoreSubView *userView6;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userView7; @property (nonatomic,strong)QXExpansionAppStoreSubView *userView7;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userView8; @property (nonatomic,strong)QXExpansionAppStoreSubView *userView8;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userViewCopy1;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userViewCopy2;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userViewCopy3;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userViewCopy4;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userViewCopy5;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userViewCopy6;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userViewCopy7;
@property (nonatomic,strong)QXExpansionAppStoreSubView *userViewCopy8;
@property (nonatomic,strong)NSMutableArray *userViews; @property (nonatomic,strong)NSMutableArray *userViews;
@property (nonatomic,strong)NSMutableArray *userViewCopys;
@property (nonatomic, strong) CADisplayLink *displayLink;
@property (nonatomic, assign) CGFloat currentRotation;
@property (nonatomic, assign) CGFloat rotationSpeed;
@end @end
@implementation QXExpansionAppStoreView @implementation QXExpansionAppStoreView
@@ -117,34 +133,40 @@
// }]; // }];
self.userView1 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake((self.centerBgView.width-ScaleWidth(56))/2, 0, ScaleWidth(56), ScaleWidth(71))]; self.userView1 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake((self.centerBgView.width-ScaleWidth(56))/2, 0, ScaleWidth(56), ScaleWidth(71))];
self.userView1.hidden = YES;
[self.centerBgView addSubview:self.userView1]; [self.centerBgView addSubview:self.userView1];
self.userView2 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(self.userView1.right+ScaleWidth(54), self.userView1.top+ScaleWidth(45), ScaleWidth(56), ScaleWidth(71))]; self.userView2 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(self.userView1.right+ScaleWidth(54), self.userView1.top+ScaleWidth(45), ScaleWidth(56), ScaleWidth(71))];
self.userView2.hidden = YES;
[self.centerBgView addSubview:self.userView2]; [self.centerBgView addSubview:self.userView2];
self.userView3 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(SCREEN_WIDTH-ScaleWidth(66), (self.centerBgView.height-ScaleWidth(71))/2, ScaleWidth(56), ScaleWidth(71))]; self.userView3 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(SCREEN_WIDTH-ScaleWidth(66), (self.centerBgView.height-ScaleWidth(71))/2, ScaleWidth(56), ScaleWidth(71))];
self.userView3.hidden = YES;
[self.centerBgView addSubview:self.userView3]; [self.centerBgView addSubview:self.userView3];
self.userView4 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(self.userView2.left, self.userView3.bottom+ScaleWidth(32), ScaleWidth(56), ScaleWidth(71))]; self.userView4 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(self.userView2.left, self.userView3.bottom+ScaleWidth(32), ScaleWidth(56), ScaleWidth(71))];
self.userView4.hidden = YES;
[self.centerBgView addSubview:self.userView4]; [self.centerBgView addSubview:self.userView4];
self.userView5 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(self.userView1.left, self.centerBgView.height-ScaleWidth(71), ScaleWidth(56), ScaleWidth(71))]; self.userView5 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(self.userView1.left, self.centerBgView.height-ScaleWidth(71), ScaleWidth(56), ScaleWidth(71))];
self.userView5.hidden = YES;
[self.centerBgView addSubview:self.userView5]; [self.centerBgView addSubview:self.userView5];
self.userView7 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(ScaleWidth(10), self.userView3.top, ScaleWidth(56), ScaleWidth(71))]; self.userView7 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(ScaleWidth(10), self.userView3.top, ScaleWidth(56), ScaleWidth(71))];
self.userView7.hidden = YES;
[self.centerBgView addSubview:self.userView7]; [self.centerBgView addSubview:self.userView7];
self.userView8 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(ScaleWidth(48), self.userView2.top, ScaleWidth(56), ScaleWidth(71))]; self.userView8 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(ScaleWidth(48), self.userView2.top, ScaleWidth(56), ScaleWidth(71))];
self.userView8.hidden = YES;
[self.centerBgView addSubview:self.userView8]; [self.centerBgView addSubview:self.userView8];
self.userView6 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(self.userView8.left, self.userView4.top, ScaleWidth(56), ScaleWidth(71))]; self.userView6 = [[QXExpansionAppStoreSubView alloc] initWithFrame:CGRectMake(self.userView8.left, self.userView4.top, ScaleWidth(56), ScaleWidth(71))];
self.userView6.hidden = YES;
[self.centerBgView addSubview:self.userView6]; [self.centerBgView addSubview:self.userView6];
[self.userViews addObject:self.userView1]; [self.userViews addObject:self.userView1];
[self.userViews addObject:self.userView2]; [self.userViews addObject:self.userView2];
[self.userViews addObject:self.userView3]; [self.userViews addObject:self.userView3];
@@ -153,15 +175,63 @@
[self.userViews addObject:self.userView6]; [self.userViews addObject:self.userView6];
[self.userViews addObject:self.userView7]; [self.userViews addObject:self.userView7];
[self.userViews addObject:self.userView8]; [self.userViews addObject:self.userView8];
self.userView1.alpha = 0;
self.userView2.alpha = 0;
self.userView3.alpha = 0;
self.userView4.alpha = 0;
self.userView5.alpha = 0;
self.userView6.alpha = 0; self.userViewCopy1 = [[QXExpansionAppStoreSubView alloc] initWithFrame:self.userView1.frame];
self.userView7.alpha = 0; self.userViewCopy1.hidden = YES;
self.userView8.alpha = 0; [self.centerBgView addSubview:self.userViewCopy1];
self.userViewCopy2 = [[QXExpansionAppStoreSubView alloc] initWithFrame:self.userView2.frame];
self.userViewCopy2.hidden = YES;
[self.centerBgView addSubview:self.userViewCopy2];
self.userViewCopy3 = [[QXExpansionAppStoreSubView alloc] initWithFrame:self.userView3.frame];
self.userViewCopy3.hidden = YES;
[self.centerBgView addSubview:self.userViewCopy3];
self.userViewCopy4 = [[QXExpansionAppStoreSubView alloc] initWithFrame:self.userView4.frame];
self.userViewCopy4.hidden = YES;
[self.centerBgView addSubview:self.userViewCopy4];
self.userViewCopy5 = [[QXExpansionAppStoreSubView alloc] initWithFrame:self.userView5.frame];
self.userViewCopy5.hidden = YES;
[self.centerBgView addSubview:self.userViewCopy5];
self.userViewCopy7 = [[QXExpansionAppStoreSubView alloc] initWithFrame:self.userView7.frame];
self.userViewCopy7.hidden = YES;
[self.centerBgView addSubview:self.userViewCopy7];
self.userViewCopy8 = [[QXExpansionAppStoreSubView alloc] initWithFrame:self.userView8.frame];
self.userViewCopy8.hidden = YES;
[self.centerBgView addSubview:self.userViewCopy8];
self.userViewCopy6 = [[QXExpansionAppStoreSubView alloc] initWithFrame:self.userView6.frame];
self.userViewCopy6.hidden = YES;
[self.centerBgView addSubview:self.userViewCopy6];
[self.userViewCopys addObject:self.userViewCopy1];
[self.userViewCopys addObject:self.userViewCopy2];
[self.userViewCopys addObject:self.userViewCopy3];
[self.userViewCopys addObject:self.userViewCopy4];
[self.userViewCopys addObject:self.userViewCopy5];
[self.userViewCopys addObject:self.userViewCopy6];
[self.userViewCopys addObject:self.userViewCopy7];
[self.userViewCopys addObject:self.userViewCopy8];
self.userViewCopy1.alpha = 0;
self.userViewCopy2.alpha = 0;
self.userViewCopy3.alpha = 0;
self.userViewCopy4.alpha = 0;
self.userViewCopy5.alpha = 0;
self.userViewCopy6.alpha = 0;
self.userViewCopy7.alpha = 0;
self.userViewCopy8.alpha = 0;
MJWeakSelf MJWeakSelf
[self.userView1 addTapBlock:^(id _Nonnull obj) { [self.userView1 addTapBlock:^(id _Nonnull obj) {
if (weakSelf.userBlock) { if (weakSelf.userBlock) {
@@ -209,28 +279,75 @@
weakSelf.userBlock(weakSelf.userView8.model); weakSelf.userBlock(weakSelf.userView8.model);
} }
}]; }];
[self startAnimate]; // [self startAnimate];
[self.userView1 startSmoothFloatAnimation]; // [self.userView1 startSmoothFloatAnimation];
[self.userView2 startSmoothFloatAnimation]; // [self.userView2 startSmoothFloatAnimation];
[self.userView3 startSmoothFloatAnimation]; // [self.userView3 startSmoothFloatAnimation];
[self.userView4 startSmoothFloatAnimation]; // [self.userView4 startSmoothFloatAnimation];
[self.userView5 startSmoothFloatAnimation]; // [self.userView5 startSmoothFloatAnimation];
[self.userView6 startSmoothFloatAnimation]; // [self.userView6 startSmoothFloatAnimation];
[self.userView7 startSmoothFloatAnimation]; // [self.userView7 startSmoothFloatAnimation];
[self.userView8 startSmoothFloatAnimation]; // [self.userView8 startSmoothFloatAnimation];
self.rotationSpeed = (M_PI * 2) / (30.0 * 60.0); // 30
[self startWheelRotation];
} }
- (void)startWheelRotation {
self.currentRotation = 0;
self.displayLink = [CADisplayLink displayLinkWithTarget:self selector:@selector(updateWheelRotation)];
[self.displayLink addToRunLoop:[NSRunLoop mainRunLoop] forMode:NSRunLoopCommonModes];
}
- (void)updateWheelRotation {
//
self.currentRotation += self.rotationSpeed;
if (self.currentRotation >= M_PI * 2) {
self.currentRotation -= M_PI * 2;
}
// 1使CGAffineTransform
[self updateRotationWithCGAffineTransform];
// 2使CATransform3D
// [self updateRotationWithCATransform3D];
//
// [self updateDebugInfo];
}
// 1使CGAffineTransform
- (void)updateRotationWithCGAffineTransform {
//
self.centerBgView.transform = CGAffineTransformMakeRotation(self.currentRotation);
//
// 使identitytransform
for (QXExpansionAppStoreSubView *avatarView in self.userViews) {
// transform
avatarView.transform = CGAffineTransformIdentity;
avatarView.transform = CGAffineTransformMakeRotation(-self.currentRotation);
}
for (QXExpansionAppStoreSubView *avatarView in self.userViewCopys) {
// transform
avatarView.transform = CGAffineTransformIdentity;
avatarView.transform = CGAffineTransformMakeRotation(-self.currentRotation);
}
}
-(void)startAnimate{ -(void)startAnimate{
CABasicAnimation *rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"]; // CABasicAnimation *rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"];
// // //
rotationAnimation.toValue = [NSNumber numberWithFloat: M_PI]; // rotationAnimation.toValue = [NSNumber numberWithFloat: M_PI];
// // //
rotationAnimation.duration = 15; // rotationAnimation.duration = 15;
rotationAnimation.cumulative = YES; // rotationAnimation.cumulative = YES;
rotationAnimation.removedOnCompletion = NO; // rotationAnimation.removedOnCompletion = NO;
//MAXFLOAT // //MAXFLOAT
rotationAnimation.repeatCount = MAXFLOAT; // rotationAnimation.repeatCount = MAXFLOAT;
[self.centerBgView.layer addAnimation:rotationAnimation forKey:@"rotationAnimation"]; // [self.centerBgView.layer addAnimation:rotationAnimation forKey:@"rotationAnimation"];
} }
@@ -246,37 +363,57 @@
self.fengcheImageView.alpha = 0; self.fengcheImageView.alpha = 0;
self.fengcheImageView.hidden = NO; self.fengcheImageView.hidden = NO;
self.userViewCopy1.hidden = NO;
self.userViewCopy2.hidden = NO;
self.userViewCopy3.hidden = NO;
self.userViewCopy4.hidden = NO;
self.userViewCopy5.hidden = NO;
self.userViewCopy6.hidden = NO;
self.userViewCopy7.hidden = NO;
self.userViewCopy8.hidden = NO;
self.userView1.hidden = YES;
self.userView2.hidden = YES;
self.userView3.hidden = YES;
self.userView4.hidden = YES;
self.userView5.hidden = YES;
self.userView6.hidden = YES;
self.userView7.hidden = YES;
self.userView8.hidden = YES;
[UIView animateWithDuration:0.3 animations:^{ [UIView animateWithDuration:0.3 animations:^{
self.changeBtn.alpha = 0; self.changeBtn.alpha = 0;
self.fengcheImageView.alpha = 1; self.fengcheImageView.alpha = 1;
self.userView1.centerX = self.bgImageView.centerX; self.userViewCopy1.centerX = self.bgImageView.centerX;
self.userView1.centerY = self.bgImageView.centerY; self.userViewCopy1.centerY = self.bgImageView.centerY;
self.userView2.centerX = self.bgImageView.centerX; self.userViewCopy2.centerX = self.bgImageView.centerX;
self.userView2.centerY = self.bgImageView.centerY; self.userViewCopy2.centerY = self.bgImageView.centerY;
self.userView3.centerX = self.bgImageView.centerX; self.userViewCopy3.centerX = self.bgImageView.centerX;
self.userView3.centerY = self.bgImageView.centerY; self.userViewCopy3.centerY = self.bgImageView.centerY;
self.userView4.centerX = self.bgImageView.centerX; self.userViewCopy4.centerX = self.bgImageView.centerX;
self.userView4.centerY = self.bgImageView.centerY; self.userViewCopy4.centerY = self.bgImageView.centerY;
self.userView5.centerX = self.bgImageView.centerX; self.userViewCopy5.centerX = self.bgImageView.centerX;
self.userView5.centerY = self.bgImageView.centerY; self.userViewCopy5.centerY = self.bgImageView.centerY;
self.userView6.centerX = self.bgImageView.centerX; self.userViewCopy6.centerX = self.bgImageView.centerX;
self.userView6.centerY = self.bgImageView.centerY; self.userViewCopy6.centerY = self.bgImageView.centerY;
self.userView7.centerX = self.bgImageView.centerX; self.userViewCopy7.centerX = self.bgImageView.centerX;
self.userView7.centerY = self.bgImageView.centerY; self.userViewCopy7.centerY = self.bgImageView.centerY;
self.userView8.centerX = self.bgImageView.centerX; self.userViewCopy8.centerX = self.bgImageView.centerX;
self.userView8.centerY = self.bgImageView.centerY; self.userViewCopy8.centerY = self.bgImageView.centerY;
self.userViewCopy1.alpha = 0;
self.userViewCopy2.alpha = 0;
self.userViewCopy3.alpha = 0;
self.userViewCopy4.alpha = 0;
self.userViewCopy5.alpha = 0;
self.userViewCopy6.alpha = 0;
self.userViewCopy7.alpha = 0;
self.userViewCopy8.alpha = 0;
self.userView1.alpha = 0;
self.userView2.alpha = 0;
self.userView3.alpha = 0;
self.userView4.alpha = 0;
self.userView5.alpha = 0;
self.userView6.alpha = 0;
self.userView7.alpha = 0;
self.userView8.alpha = 0;
} completion:^(BOOL finished) { } completion:^(BOOL finished) {
self.changeBtn.hidden = YES; self.changeBtn.hidden = YES;
@@ -303,32 +440,48 @@
self.changeBtn.alpha = 0; self.changeBtn.alpha = 0;
self.changeBtn.hidden = NO; self.changeBtn.hidden = NO;
self.fengcheImageView.hidden = YES; self.fengcheImageView.hidden = YES;
dispatch_async(dispatch_get_main_queue(), ^{ [self configData];
[self configData];
});
[UIView animateWithDuration:0.3 animations:^{ [UIView animateWithDuration:0.3 animations:^{
self.changeBtn.alpha = 1; self.changeBtn.alpha = 1;
self.userViewCopy1.frame = self.userView1.frame;
self.userViewCopy2.frame = self.userView2.frame;
self.userViewCopy3.frame = self.userView3.frame;
self.userViewCopy4.frame = self.userView4.frame;
self.userViewCopy5.frame = self.userView5.frame;
self.userViewCopy6.frame = self.userView6.frame;
self.userViewCopy7.frame = self.userView7.frame;
self.userViewCopy8.frame = self.userView8.frame;
self.userViewCopy1.alpha = 1;
self.userViewCopy2.alpha = 1;
self.userViewCopy3.alpha = 1;
self.userViewCopy4.alpha = 1;
self.userViewCopy5.alpha = 1;
self.userViewCopy6.alpha = 1;
self.userViewCopy7.alpha = 1;
self.userViewCopy8.alpha = 1;
self.userView1.frame = CGRectMake((self.centerBgView.width-ScaleWidth(56))/2, 0, ScaleWidth(56), ScaleWidth(71));
self.userView2.frame = CGRectMake(self.userView1.right+ScaleWidth(54), self.userView1.top+ScaleWidth(45), ScaleWidth(56), ScaleWidth(71));
self.userView3.frame = CGRectMake(SCREEN_WIDTH-ScaleWidth(66), (self.centerBgView.height-ScaleWidth(71))/2, ScaleWidth(56), ScaleWidth(71));
self.userView4.frame = CGRectMake(self.userView2.left, self.userView3.bottom+ScaleWidth(32), ScaleWidth(56), ScaleWidth(71));
self.userView5.frame = CGRectMake(self.userView1.left, self.centerBgView.height-ScaleWidth(71), ScaleWidth(56), ScaleWidth(71));
self.userView7.frame = CGRectMake(ScaleWidth(10), self.userView3.top, ScaleWidth(56), ScaleWidth(71));
self.userView8.frame = CGRectMake(ScaleWidth(48), self.userView2.top, ScaleWidth(56), ScaleWidth(71));
self.userView6.frame = CGRectMake(self.userView8.left, self.userView4.top, ScaleWidth(56), ScaleWidth(71));
self.userView1.alpha = 1;
self.userView2.alpha = 1;
self.userView3.alpha = 1;
self.userView4.alpha = 1;
self.userView5.alpha = 1;
self.userView6.alpha = 1;
self.userView7.alpha = 1;
self.userView8.alpha = 1;
} completion:^(BOOL finished) { } completion:^(BOOL finished) {
self.userViewCopy1.hidden = YES;
self.userViewCopy2.hidden = YES;
self.userViewCopy3.hidden = YES;
self.userViewCopy4.hidden = YES;
self.userViewCopy5.hidden = YES;
self.userViewCopy6.hidden = YES;
self.userViewCopy7.hidden = YES;
self.userViewCopy8.hidden = YES;
self.userView1.hidden = NO;
self.userView2.hidden = NO;
self.userView3.hidden = NO;
self.userView4.hidden = NO;
self.userView5.hidden = NO;
self.userView6.hidden = NO;
self.userView7.hidden = NO;
self.userView8.hidden = NO;
}]; }];
} }
-(void)setUsers:(NSArray *)users{ -(void)setUsers:(NSArray *)users{
@@ -349,7 +502,9 @@
for (int i = 0 ; i < self.randomArray.count;i++) { for (int i = 0 ; i < self.randomArray.count;i++) {
QXUserHomeModel *md = self.randomArray[i]; QXUserHomeModel *md = self.randomArray[i];
QXExpansionAppStoreSubView *v = self.userViews[i]; QXExpansionAppStoreSubView *v = self.userViews[i];
QXExpansionAppStoreSubView *cv = self.userViewCopys[i];
v.model = md; v.model = md;
cv.model = [md copyModel];
} }
} }
@@ -383,6 +538,12 @@
} }
return _userViews; return _userViews;
} }
-(NSMutableArray *)userViewCopys{
if (!_userViewCopys) {
_userViewCopys = [NSMutableArray array];
}
return _userViewCopys;
}
@end @end
@@ -405,6 +566,7 @@
self.nameBgView.hidden = NO; self.nameBgView.hidden = NO;
} }
-(void)initSubviews{ -(void)initSubviews{
self.transform = CGAffineTransformRotate(self.transform, M_PI);
self.headerImageView = [[UIImageView alloc] init]; self.headerImageView = [[UIImageView alloc] init];
self.headerImageView.contentMode = UIViewContentModeScaleAspectFill; self.headerImageView.contentMode = UIViewContentModeScaleAspectFill;
[self.headerImageView addRoundedCornersWithRadius:self.width/2]; [self.headerImageView addRoundedCornersWithRadius:self.width/2];
@@ -444,7 +606,9 @@
make.height.width.mas_offset(16); make.height.width.mas_offset(16);
}]; }];
} }
- (void)startSmoothFloatAnimation { - (void)startSmoothFloatAnimation {
// [self animateFloatUp]; // [self animateFloatUp];
CABasicAnimation *rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"]; CABasicAnimation *rotationAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"];
// //
@@ -456,6 +620,18 @@
//MAXFLOAT //MAXFLOAT
rotationAnimation.repeatCount = MAXFLOAT; rotationAnimation.repeatCount = MAXFLOAT;
[self.layer addAnimation:rotationAnimation forKey:@"rotationAnimation"]; [self.layer addAnimation:rotationAnimation forKey:@"rotationAnimation"];
// [UIView animateWithDuration:15.0
// delay:0.0
// options:UIViewAnimationOptionCurveLinear|UIViewKeyframeAnimationOptionAllowUserInteraction
// animations:^{
// self.transform = CGAffineTransformRotate(self.transform, 2*M_PI);
// }
// completion:^(BOOL finished) {
// if (finished) {
// //
// [self startSmoothFloatAnimation];
// }
// }];
} }

View File

@@ -302,6 +302,9 @@
}]; }];
} }
-(void)popFirstRechargeView{ -(void)popFirstRechargeView{
if ([QXGlobal shareGlobal].isAppStore) {
return;
}
if (self.permissionModel.first_charge_permission.intValue != 1) { if (self.permissionModel.first_charge_permission.intValue != 1) {
return; return;
} }

View File

@@ -60,7 +60,7 @@ static void *WKWebBrowserContext = &WKWebBrowserContext;
, 2)]; , 2)];
} }
- (void)loadData { - (void)loadData {
NSURL* url=[NSURL URLWithString:[NSString stringWithFormat:@"%@web/index.html#/pages/prop/propMall?id=%@",H5ServerUrl,[QXGlobal shareGlobal].loginModel.token]]; NSURL* url=[NSURL URLWithString:[NSString stringWithFormat:@"%@web/index.html#/pages/prop/propMall?id=%@&is_show=%@",H5ServerUrl,[QXGlobal shareGlobal].loginModel.token,QXGlobal.shareGlobal.isAppStore?@"0":@"1"]];
NSURLRequest *request =[NSURLRequest requestWithURL:url]; NSURLRequest *request =[NSURLRequest requestWithURL:url];
[self.contentWebView loadRequest:request]; [self.contentWebView loadRequest:request];
} }
@@ -173,8 +173,6 @@ static void *WKWebBrowserContext = &WKWebBrowserContext;
configuration.processPool = [[WKProcessPool alloc] init]; configuration.processPool = [[WKProcessPool alloc] init];
//, jsoc(OCURL) //, jsoc(OCURL)
WKUserContentController * UserContentController = [[WKUserContentController alloc]init]; WKUserContentController * UserContentController = [[WKUserContentController alloc]init];
//
configuration.suppressesIncrementalRendering = NO;
// //
[UserContentController addScriptMessageHandler:self name:@"login"]; [UserContentController addScriptMessageHandler:self name:@"login"];
[UserContentController addScriptMessageHandler:self name:@"nativeHandler"]; [UserContentController addScriptMessageHandler:self name:@"nativeHandler"];

View File

@@ -63,7 +63,7 @@ static void *WKWebBrowserContext = &WKWebBrowserContext;
} }
- (void)loadData { - (void)loadData {
NSInteger safeTop = kSafeAreaTop; NSInteger safeTop = kSafeAreaTop;
NSURL* url=[NSURL URLWithString:[NSString stringWithFormat:@"%@web/index.html#/pages/other/income??id=%@&h=%ld",H5ServerUrl,[QXGlobal shareGlobal].loginModel.token,safeTop]]; NSURL* url=[NSURL URLWithString:[NSString stringWithFormat:@"%@web/index.html#/pages/other/income??id=%@&h=%ld&is_show=%@",H5ServerUrl,[QXGlobal shareGlobal].loginModel.token,safeTop,QXGlobal.shareGlobal.isAppStore?@"0":@"1"]];
NSURLRequest *request =[NSURLRequest requestWithURL:url]; NSURLRequest *request =[NSURLRequest requestWithURL:url];
[self.contentWebView loadRequest:request]; [self.contentWebView loadRequest:request];
} }

View File

@@ -105,6 +105,8 @@ NS_ASSUME_NONNULL_BEGIN
/// 是否使用靓号 0未使用 1 已使用 /// 是否使用靓号 0未使用 1 已使用
@property (nonatomic,strong)NSString *is_use_code; @property (nonatomic,strong)NSString *is_use_code;
-(instancetype)copyModel;
@end @end
@interface QXUserTag : NSObject @interface QXUserTag : NSObject

View File

@@ -18,6 +18,18 @@
+(NSDictionary<NSString *,id> *)modelContainerPropertyGenericClass{ +(NSDictionary<NSString *,id> *)modelContainerPropertyGenericClass{
return @{@"tag_list" : @"QXUserTag"}; return @{@"tag_list" : @"QXUserTag"};
} }
-(instancetype)copyModel{
QXUserHomeModel *copy = [[QXUserHomeModel alloc] init];
copy.user_id = self.user_id;
copy.user_code = self.user_code;
copy.avatar = self.avatar;
copy.sex = self.sex;
copy.dress = self.dress;
copy.nickname = self.nickname;
return copy;
}
@end @end

View File

@@ -19,6 +19,8 @@
[QXGlobal shareGlobal].loginModel.auth = userModel.auth.intValue; [QXGlobal shareGlobal].loginModel.auth = userModel.auth.intValue;
[QXGlobal shareGlobal].loginModel.chat_bubble = userModel.chat_bubble; [QXGlobal shareGlobal].loginModel.chat_bubble = userModel.chat_bubble;
[[QXGlobal shareGlobal] updateUserInfoWithMolde:[QXGlobal shareGlobal].loginModel]; [[QXGlobal shareGlobal] updateUserInfoWithMolde:[QXGlobal shareGlobal].loginModel];
BOOL api_version = [responseObject[@"api_version"] boolValue];
[QXGlobal shareGlobal].isAppStore = api_version;
[[NSUserDefaults standardUserDefaults] setInteger:userModel.is_can_chat forKey:kIsCanChat]; [[NSUserDefaults standardUserDefaults] setInteger:userModel.is_can_chat forKey:kIsCanChat];
[[NSUserDefaults standardUserDefaults] setObject:userModel.can_chat_money forKey:kIsCanChatMoney]; [[NSUserDefaults standardUserDefaults] setObject:userModel.can_chat_money forKey:kIsCanChatMoney];
[[NSUserDefaults standardUserDefaults] synchronize]; [[NSUserDefaults standardUserDefaults] synchronize];

View File

@@ -7,6 +7,8 @@
#import "QXRoomChatListView.h" #import "QXRoomChatListView.h"
#import "UIImage+WebP.h" #import "UIImage+WebP.h"
#import <AVFoundation/AVFoundation.h>
#define messageNoticeColor RGB16(0xCCA882) #define messageNoticeColor RGB16(0xCCA882)
#define messageNameColor RGB16(0x00C8FF) #define messageNameColor RGB16(0x00C8FF)
#define messageGiftColor RGB16(0xFFE309) #define messageGiftColor RGB16(0xFFE309)
@@ -51,6 +53,7 @@ NSInteger maxMessageCount = 20;
@property (nonatomic,assign)BOOL isDragging; @property (nonatomic,assign)BOOL isDragging;
@property (nonatomic,strong)UILabel *messageLabel; @property (nonatomic,strong)UILabel *messageLabel;
@property (nonatomic,strong)UIButton *messageCountBtn; @property (nonatomic,strong)UIButton *messageCountBtn;
@property (nonatomic,strong)AVSpeechSynthesizer *synthesizer;
@end @end
@implementation QXRoomChatListView @implementation QXRoomChatListView
@@ -64,6 +67,7 @@ NSInteger maxMessageCount = 20;
} }
-(void)initSubviews{ -(void)initSubviews{
self.synthesizer = [[AVSpeechSynthesizer alloc] init];
[self addSubview:self.tableView]; [self addSubview:self.tableView];
[self.tableView mas_makeConstraints:^(MASConstraintMaker *make) { [self.tableView mas_makeConstraints:^(MASConstraintMaker *make) {
make.left.right.equalTo(self); make.left.right.equalTo(self);
@@ -197,6 +201,16 @@ NSInteger maxMessageCount = 20;
// if (self.giftArray.count>maxMessageCount) { // if (self.giftArray.count>maxMessageCount) {
// [self.giftArray removeFirstObject]; // [self.giftArray removeFirstObject];
// } // }
#if DEBUG
if (model.messageType == QXRoomChatMessageTypeGift || model.messageType == QXRoomChatMessageTypeSystem) {
AVSpeechUtterance *utterance = [[AVSpeechUtterance alloc] initWithString:model.text];
utterance.voice = [AVSpeechSynthesisVoice voiceWithLanguage:@"zh-CN"];
utterance.rate = 0.5 ;
utterance.pitchMultiplier = 1.0 ;
utterance.volume = 1.0 ;
[self.synthesizer speakUtterance:utterance];
}
#endif
NSIndexPath *newIndexPath = [NSIndexPath indexPathForRow:self.dataArray.count - 1 inSection:0]; NSIndexPath *newIndexPath = [NSIndexPath indexPathForRow:self.dataArray.count - 1 inSection:0];
[self.tableView beginUpdates]; [self.tableView beginUpdates];
[self.tableView insertRowsAtIndexPaths:@[newIndexPath] withRowAnimation:UITableViewRowAnimationNone]; [self.tableView insertRowsAtIndexPaths:@[newIndexPath] withRowAnimation:UITableViewRowAnimationNone];