iOS--------長(zhǎng)按UIWebView上的圖片保存到相冊(cè)

長(zhǎng)按 UIWebView上的圖片保存到相冊(cè)

想法一:利用JS與原生交互,JS監(jiān)聽(tīng)圖片點(diǎn)擊事件踏拜,然后將圖片的url傳遞給原生的APP端态罪,原生APP將圖片保存到相冊(cè)

想法二:利用JS的api:Document.elementFromPoint()沟饥,實(shí)現(xiàn)這個(gè)功能完全可以只在APP原生端做一些代碼開(kāi)發(fā)棺亭。

想法二的具體操作:

1.給UIWebView添加長(zhǎng)按手勢(shì)

2.監(jiān)聽(tīng)手勢(shì)動(dòng)作,拿到坐標(biāo)點(diǎn)x,y

3.彈出對(duì)話框弟劲,是否保存到相冊(cè)

4.UIWebView注入JS:Document.elementFromPoint(x,y).src拿到img標(biāo)簽的src

5.拿到圖片的url祷安,生成uiimage

6.圖片保存到相冊(cè)

重點(diǎn):長(zhǎng)按手勢(shì)事件不能每次都響應(yīng),所以要想長(zhǎng)安手勢(shì)準(zhǔn)確率100%兔乞,要實(shí)現(xiàn)UIGestureRecognizerDelegate代理方法

實(shí)現(xiàn)代碼

#import "ImageSaveViewController.h"

@interface ImageSaveViewController ()

@property (strong, nonatomic) UIWebView* webview;

@end

@implementation ImageSaveViewController

- (void)viewDidLoad {

[super viewDidLoad];

self.webview = [[UIWebView alloc]init];

[self.view addSubview:self.webview];

self.webview.frame = CGRectMake(0, 64, [UIScreen mainScreen].bounds.size.width, [UIScreen mainScreen].bounds.size.height-64);

NSString* url = [NSString stringWithFormat:@"https://www.baidu.com"];

[self.webview loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:url]]];

//添加長(zhǎng)按手勢(shì)

UILongPressGestureRecognizer* longPressGestureRecognizer = [[UILongPressGestureRecognizer alloc]initWithTarget:self action:@selector(longPressed:)];

[self.webview addGestureRecognizer:longPressGestureRecognizer];

longPressGestureRecognizer.delegate = self;

}

#pragma mark--長(zhǎng)按代理

- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer{

return YES;

}

#pragma mark-- 長(zhǎng)按事件

- (void)longPressed:(UILongPressGestureRecognizer *)recognizer{

if (recognizer.state != UIGestureRecognizerStateBegan) {

return;

}

CGPoint touchPoint = [recognizer locationInView:self.webview];

NSString* imageURL = [NSString stringWithFormat:@"document.elementFromPoint(%f, %f).src", touchPoint.x, touchPoint.y];

NSLog(@"%@",imageURL);

NSString* toSaveStr = [self.webview stringByEvaluatingJavaScriptFromString:imageURL];

NSLog(@"%@",toSaveStr);

if (toSaveStr.length == 0) {

return;

}

UIAlertController *alertVC =? [UIAlertController alertControllerWithTitle:@"尊敬的客戶" message:@"您確定的要保存圖片到相冊(cè)嗎汇鞭?" preferredStyle:UIAlertControllerStyleAlert];

UIAlertAction *okAction = [UIAlertAction actionWithTitle:@"確定" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {

[self saveImageToAmblue:toSaveStr];

}];

UIAlertAction *cancelAction = [UIAlertAction actionWithTitle:@"不好意思,我點(diǎn)錯(cuò)了." style:UIAlertActionStyleDefault handler:nil];

[alertVC addAction:okAction];

[alertVC addAction:cancelAction];

[self presentViewController:alertVC animated:YES completion:nil];

}

#pragma mark---保存圖片

- (void)saveImageToAmblue:(NSString *)saveToURL{

NSURL* URL = [NSURL URLWithString:saveToURL];

NSURLSessionConfiguration* configuration = [NSURLSessionConfiguration defaultSessionConfiguration];

NSURLSession* session = [NSURLSession sessionWithConfiguration:configuration delegate:self delegateQueue:[NSOperationQueue new]];

NSURLRequest* request = [NSURLRequest requestWithURL:URL cachePolicy:NSURLRequestReturnCacheDataElseLoad timeoutInterval:30.0];

NSURLSessionDownloadTask* downloadTask = [session downloadTaskWithRequest:request completionHandler:^(NSURL * _Nullable location, NSURLResponse * _Nullable response, NSError * _Nullable error) {

if (error) {

return ;

}

NSData* data = [NSData dataWithContentsOfURL:location];

dispatch_async(dispatch_get_main_queue(), ^{

UIImage* iamge = [UIImage imageWithData:data];

UIImageWriteToSavedPhotosAlbum(iamge, session, @selector(imageSaveToAlbum: didFinishSavingWithError: contextInfo:), NULL);

});

}];

[downloadTask resume];

}

#pragma mark--圖片保存后回調(diào)

- (void)imageSaveToAlbum:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(id)contextInfo{

NSString* message;

if (!error) {

message = @"已經(jīng)成功保存到相冊(cè)";

}else{

message = [error description];

}

UIAlertController* alertController = [UIAlertController alertControllerWithTitle:@"提示" message:message preferredStyle:UIAlertControllerStyleAlert];

UIAlertAction* OKSection = [UIAlertAction actionWithTitle:@"確定" style:UIAlertActionStyleDestructive handler:nil];

[alertController addAction:OKSection];

[self presentViewController:alertController animated:YES completion:nil];

}

總結(jié):這兩種想法都有一定的局限性,想法一是太過(guò)麻煩报嵌,想法二是有的時(shí)候會(huì)獲取不到圖片的URL(若想準(zhǔn)確獲得URL需和前端做一些溝通)虱咧。鑒于此,具體使用哪種方法锚国,就看你的心情了腕巡。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市血筑,隨后出現(xiàn)的幾起案子绘沉,更是在濱河造成了極大的恐慌,老刑警劉巖豺总,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件车伞,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡喻喳,警方通過(guò)查閱死者的電腦和手機(jī)另玖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)表伦,“玉大人谦去,你說(shuō)我怎么就攤上這事”暮撸” “怎么了鳄哭?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)纲熏。 經(jīng)常有香客問(wèn)我妆丘,道長(zhǎng),這世上最難降的妖魔是什么局劲? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任勺拣,我火速辦了婚禮,結(jié)果婚禮上容握,老公的妹妹穿的比我還像新娘宣脉。我一直安慰自己,他們只是感情好剔氏,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布塑猖。 她就那樣靜靜地躺著,像睡著了一般谈跛。 火紅的嫁衣襯著肌膚如雪羊苟。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,071評(píng)論 1 285
  • 那天感憾,我揣著相機(jī)與錄音蜡励,去河邊找鬼。 笑死阻桅,一個(gè)胖子當(dāng)著我的面吹牛凉倚,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播嫂沉,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼稽寒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了趟章?” 一聲冷哼從身側(cè)響起杏糙,我...
    開(kāi)封第一講書(shū)人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蚓土,沒(méi)想到半個(gè)月后宏侍,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蜀漆,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年谅河,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片确丢。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡绷耍,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蠕嫁,到底是詐尸還是另有隱情锨天,我是刑警寧澤,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布剃毒,位于F島的核電站病袄,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏赘阀。R本人自食惡果不足惜益缠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望基公。 院中可真熱鬧幅慌,春花似錦、人聲如沸轰豆。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至骂租,卻和暖如春祷杈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背渗饮。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工但汞, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人互站。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓私蕾,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親胡桃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子踩叭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容