123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- //
- // KSDraftMergeViewController.m
- // KulexiuSchoolStudent
- //
- // Created by 王智 on 2023/11/1.
- //
- #import "KSDraftMergeViewController.h"
- #import "KSMediaMergeView.h"
- #import "AppDelegate+AppService.h"
- #import "UIDevice+TFDevice.h"
- @interface KSDraftMergeViewController ()
- @property (nonatomic, copy) DraftEditCallback callback;
- @property (nonatomic, assign) BOOL hasInitUI;
- @end
- @implementation KSDraftMergeViewController
- - (void)changeOrientation:(BOOL)isLandScape {
- if (isLandScape) {
- // 切换到横屏
- if (IS_IPAD) {
- self.zh_statusBarHidden = YES;
- }
- AppDelegate* delegate = [AppDelegate shareAppDelegate];
- delegate.allowAutoRotate = YES;
- [UIDevice switchNewOrientation:UIInterfaceOrientationLandscapeRight inController:self];
- }
- else {
- // 切换到横屏
- AppDelegate* delegate = (AppDelegate*)[UIApplication sharedApplication].delegate;
- delegate.allowAutoRotate = NO;
- dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
- if (IS_IPAD) {
- self.zh_statusBarHidden = NO;
- }
- [UIDevice switchNewOrientation:UIInterfaceOrientationPortrait inController:self];
- });
- }
- }
- - (void)editCallback:(DraftEditCallback)callback {
- if (callback) {
- self.callback = callback;
- }
- }
- - (void)viewDidLoad {
- [super viewDidLoad];
- // Do any additional setup after loading the view.
- self.ks_prefersNavigationBarHidden = YES;
- self.hasInitUI = NO;
- }
- - (void)configUI {
- self.hasInitUI = YES;
- [self.scrollView removeFromSuperview];
- KSMediaMergeView *mergeView = [[KSMediaMergeView alloc] init];
- mergeView.coverImage = self.sourceModel.img;
- mergeView.songName = self.sourceModel.musicSheetName;
- mergeView.recordId = self.sourceModel.musicPracticeRecordId;
- mergeView.desc = self.sourceModel.desc;
- [self.view addSubview:mergeView];
- [mergeView mas_makeConstraints:^(MASConstraintMaker *make) {
- make.left.right.top.bottom.mas_equalTo(self.view);
- }];
- NSString *videoUrl = @"";
- if ([self.sourceModel.videoUrl hasSuffix:@".mp4"]) {
- videoUrl = self.sourceModel.videoUrl;
- }
- NSString *recordUrl = self.sourceModel.recordFilePath;
- MJWeakSelf;
- [mergeView configRemoteVideoUrl:videoUrl bgAudioUrl:self.sourceModel.accompanyUrl recordUrl:recordUrl jsonConfig:self.sourceModel.jsonConfig callback:^{
- [weakSelf changePortraitAndBack];
- }];
- }
- - (void)changePortraitAndBack {
- // 切换到竖屏
- [self changeOrientation:NO];
- dispatch_delay_block(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC), ^{
- [self backRefreh];
- });
- }
- - (void)backRefreh {
- if (self.callback) {
- self.callback();
- }
- [self backAction];
- }
- - (void)viewDidAppear:(BOOL)animated {
- [super viewDidAppear:animated];
- [self changeOrientation:YES];
- if (self.hasInitUI == NO) {
- // 切换到横屏
- dispatch_delay_block(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC), ^{
- [self configUI];
- });
- }
- }
- /*
- #pragma mark - Navigation
- // In a storyboard-based application, you will often want to do a little preparation before navigation
- - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
- // Get the new view controller using [segue destinationViewController].
- // Pass the selected object to the new view controller.
- }
- */
- @end
|