Кто-нибудь знает, можно ли удалить тень, которая помещается в окно UIWebView?
Пример: http://uploadingit.com/files/1173105_olub5/shadow.png
Если возможно, как вы это делаете?
Спасибо
Кто-нибудь знает, можно ли удалить тень, которая помещается в окно UIWebView?
Пример: http://uploadingit.com/files/1173105_olub5/shadow.png
Если возможно, как вы это делаете?
Спасибо
Это более чистая альтернатива раствору «Николай Криль». Это скрывает только UIImageView в UIWebView, но не UIWebBrowserView.
for (UIView *view in [[[webView subviews] objectAtIndex:0] subviews]) {
if ([view isKindOfClass:[UIImageView class]]) view.hidden = YES;
}
Спасибо, Джеймс
маленький цикл for очень опасен, потому что он может дать сбой, если Apple изменит количество вложенных представлений.
таким образом он, по крайней мере, не дает сбой, когда что-то меняется:
if ([[webView subviews] count] > 0)
{
for (UIView* shadowView in [[[webView subviews] objectAtIndex:0] subviews])
{
[shadowView setHidden:YES];
}
// unhide the last view so it is visible again because it has the content
[[[[[webView subviews] objectAtIndex:0] subviews] lastObject] setHidden:NO];
}
Существует частный метод с селектором setAllowsRubberBanding: он принимает значение типа BOOL. Если передано NO, вы не сможете прокручивать веб-представление за верхнюю или нижнюю часть области содержимого, но все равно сможете прокручивать веб-представление в обычном режиме. К сожалению, этот метод является частным, и ваше приложение, скорее всего, не будет допущено в магазин, если вы его используете.
Однако вы можете попробовать извлечь реализацию метода и привязать ее к другому селектору, который вы создали, используя динамический характер среды выполнения Objective-C.
Тем не менее, этот метод является частным и может больше не существовать в будущих версиях ОС. Если вы все же хотите попробовать, вот пример кода, который извлечет реализацию метода setAllowsRubberBanding: и вызовет его за вас.
static inline void ShhhDoNotTellAppleAboutThis (UIWebView *webview)
{
const char *hax3d = "frgNyybjfEhooreOnaqvat";
char appleSelName[24];
for (int i = 0; i < 22; ++i)
{
char c = hax3d[i];
appleSelName[i] = (c >= 'a' && c <= 'z') ? ((c - 'a' + 13) % 26) + 'a' : ((c - 'A' + 13) % 26) + 'A';
}
appleSelName[22] = ':';
appleSelName[23] = 0;
SEL appleSEL = sel_getUid(appleSelName);
UIScrollView *scrollView = (UIScrollView *)[webview.subviews objectAtIndex:0];
Class cls = [scrollView class];
if (class_respondsToSelector(cls, appleSEL) == NO)
{
return;
}
IMP func = class_getMethodImplementation(cls, appleSEL);
func(scrollView, appleSEL, NO);
}
Обратите внимание, что это, вероятно, все равно будет обнаружено статическим анализатором Apple, если вы решите отправить приложение, используя этот код, в AppStore.
Вот функция Swift, которая избавляется от тени в UIWebView в iOS 9. Это безопаснее, чем любая альтернатива, которую я видел на SO, потому что все в ней есть в документации Apple, и она специально изменяет свойство тени (в отличие от скрытия весь вид или какое-либо другое свойство представления).
func removeShadow(webView: UIWebView) {
for subview:UIView in webView.scrollView.subviews {
subview.layer.shadowOpacity = 0
for subsubview in subview.subviews {
subsubview.layer.shadowOpacity = 0
}
}
}
Вы всегда можете получить доступ к свойству subviews объекта _2 _ (документация). Каждый UIView
имеет свойство layer
, которое является CALayer
(документация). У каждого CALayer
есть shadowOpacity
(документация).
Предостережения:
shadowOpacity
слоя этого представления на ноль.Это можно сделать без использования частных API. Все, что вам нужно сделать, это скрыть каждый UIImageView с тенью в нем. Вот код:
for (int x = 0; x < 10; ++x) {
[[[[[webView subviews] objectAtIndex:0] subviews] objectAtIndex:x] setHidden:YES];
}
Попробуй это
func webViewDidFinishLoad(_ webView: UIWebView) {
for shadowView in self.webView.scrollView.subviews {
if !shadowView.isKind(of: UIImageView.self) {
shadowView.subviews[0].layer.shadowColor = UIColor.clear.cgColor
} else {
shadowView.layer.shadowColor = UIColor.clear.cgColor
}
}
}
Просмотрите все подвиды, UIImageViews, изображение которых имеет ширину всего 1 пиксель, являются теневыми изображениями, вы можете скрыть их.
- (void)hideShadows {
[webview traverseViewsWithBlock:^(UIView *view) {
UIImageView *imgView = ([view isKindOfClass:[UIImageView class]] ? (UIImageView*)view : nil;
// image views whose image is 1px wide are shadow images, hide them
if (imgView && imgView.image.size.width == 1) {
imgView.hidden = YES;
}
}];
}
traverseViewsWithBlock делает то, как выглядит:
- (void)traverseViewsWithBlock:(void (^)(UIView* view))block
{
block(self);
for (id subview in self.subviews) {
[subview traverseViewsWithBlock:block];
}
}
Я просмотрел свойства класса и ничего там не нашел, но я могу придумать две стратегии «прикрытия»:
1. Вы можете использовать другое представление (родительский элемент для веб-представление), чтобы обрезать границы веб-просмотра.
2. Вы можете добавить другое представление поверх веб-представления, чтобы покрыть необходимую область цветом, соответствующим фону, вы можете использовать uiimage с прозрачной областью в центре.
Кстати, мне не нравится этот стандартный фон представлений таблиц: P, но его изменение может быть головной болью: P
Будьте осторожны, индикаторы прокрутки также относятся к UIImageViews. Я улучшу свой код, но вот базовое решение с подклассами:
http://forrst.com/posts/A_tiny_UIWebView_hack_remove_shadows_from_behi-gzH
Самый простой способ скрыть индикаторы прокрутки и сделать веб-просмотр прозрачным здесь в UIWebView
Убрать свитки.
for(UIView *view in webView.subviews){
if ([view isKindOfClass:[UIScrollView class]]) {
UIScrollView *sView = (UIScrollView *)view;
//to hide verticalScroller
sView.showsVerticalScrollIndicator = NO;
sView.showsVerticalScrollIndicator = NO;
}
}
А как насчет такой категории в UIWebView:
- (BOOL)showsScrollShadows
{
for(UIImageView *imageView in [self imageViewsWithShadows])
{
if(imageView.hidden)
{
return NO;
}
break;
}
return YES;
}
- (void)setShowsScrollShadows:(BOOL)showsScrollShadows
{
[[self imageViewsWithShadows] makeObjectsPerformSelector:@selector(setHidden:) withObject:@(!showsScrollShadows)];
}
- (NSArray *)imageViewsWithShadows
{
NSArray *potentialShadowImageViews = (self.subviews.count > 0) ? [self.subviews[0] subviews] : nil;
if(potentialShadowImageViews.count > 0)
{
NSPredicate *predicate = [NSPredicate predicateWithBlock:^BOOL(id evaluatedObject, NSDictionary *bindings)
{
return [evaluatedObject isKindOfClass:[UIImageView class]];
}];
return [potentialShadowImageViews filteredArrayUsingPredicate:predicate];
}
return nil;
}
Я осмотрелся и не вижу ничего, связанного с этим. Помимо маскировки его с помощью представления или его какого-либо обрезания, единственное, о чем я могу думать, - это пройти через все подпредставления UIWebView (и подподпредставления и т. Д.) И посмотреть, можете ли вы что-нибудь там увидеть!
Я могу ошибаться, но я думаю, что тень появляется только тогда, когда мы прокручиваем веб-просмотр, не так ли? В таком случае, вы хотите предотвратить прокрутку или действительно скрыть тень? Я не знаю никаких советов, которые скрывали бы тень. Чтобы отключить прокрутку, я бы установил для UserInteractionEnabled значение NO.
Я добавил рекурсивный метод в качестве категории к объекту UIView, чтобы он выполнял обход в глубину подпредставлений принимающего представления метода, скрывая все найденные подклассы UIImageView. Он не выйдет из строя, если нет подпредставлений. -Apply: метод взят из BlocksKit. Вы можете переписать эту функцию, чтобы не использовать ее, но блок применяется параллельно к каждому элементу принимающего массива, так что это довольно быстро.
@implementation UIView (RemoveShadow)
- (void)removeShadow {
if (self.subviews.count == 0 && [self isKindOfClass:[UIImageView class]]) {
self.hidden = YES;
} else if (self.subviews.count > 0) {
[self.subviews apply:^(id sender) {
[(UIView *)sender removeShadow];
}];
}
}
@end
if([wview isKindOfClass:[UIImageView class]] && wview.frame.size.width != 7) { wview.hidden = YES; }
вместо оператора if в этом ответе. 24.11.2012