Xamarin IOS скрывает значок панели поиска на основе свойства IsFocused в пользовательском рендерере - PullRequest
2 голосов
/ 16 октября 2019

Я хотел скрыть значок панели поиска в IOS, используя пользовательский SearchBarRenderer на основе свойства IsFocused. Как мне этого добиться?

protected override void OnElementPropertyChanged(object sender, System.ComponentModel.PropertyChangedEventArgs e)
        {
            base.OnElementPropertyChanged(sender, e);

            if (Element == null || Control == null)
                return;

            var element = Element as CustomSearchBar;

            if (element.IsFocused)
            {

            }
            else
            {

            }
        }

Ответы [ 2 ]

1 голос
/ 17 октября 2019

Если вы используете Пользовательский рендерер , чтобы реализовать его, введите следующий код.

[assembly: ExportRenderer(typeof(CustomSearchBar), typeof(CustomSearchBarRenderer))]
namespace App15.iOS
{
    public class CustomSearchBarRenderer : SearchBarRenderer
    {
        UIImage searchImg;
        protected override void OnElementChanged(ElementChangedEventArgs<SearchBar> e)
        {
            base.OnElementChanged(e);
            searchImg = Control.GetImageForSearchBarIcon(UISearchBarIcon.Search, UIControlState.Normal);
            if (e.OldElement != null)
            {
                Control.OnEditingStarted -= Control_OnEditingStarted;
                Control.OnEditingStopped -= Control_OnEditingStopped;
            }

            if (e.NewElement != null)
            {
                if (null != Control)
                {
                    Control.OnEditingStarted += Control_OnEditingStarted;
                    Control.OnEditingStopped += Control_OnEditingStopped;
                }
            }
        }

        private void Control_OnEditingStopped(object sender, EventArgs e)
        {
            var searchBar = sender as UISearchBar;
            searchBar.SetImageforSearchBarIcon(searchImg, UISearchBarIcon.Search, UIControlState.Normal);
        }

        private void Control_OnEditingStarted(object sender, EventArgs e)
        {
            var searchBar = sender as UISearchBar;
            searchBar.SetImageforSearchBarIcon(new UIImage(), UISearchBarIcon.Search, UIControlState.Normal);
        }
    }
}

Примечание: App15 - это пространство имен в моем локальном проекте.

Как документ Введение в эффекты с указанными эффектами, вы также можете обратиться к этому документу Создание эффекта , чтобы использовать Effect для его реализации, потому что нет необходимости использовать Custom Renderer

Пример эффекта:

Создание SearchBarEffects

public class SearchBarEffects : RoutingEffect
{
    public SearchBarEffects() : base($"MyCompany.{nameof(SearchBarEffects)}")
    {

    }
}

Использование в Xaml :

// here is custom renderer
<local:CustomSearchBar Placeholder="renderer input"/> 
// here is custom effect
<SearchBar Placeholder="effect input">
    <SearchBar.Effects>
        <local:SearchBarEffects />
    </SearchBar.Effects>
</SearchBar>

Создание SearchBarEffect в решении iOS:

[assembly: ResolutionGroupName("MyCompany")]
[assembly: ExportEffect(typeof(App15.iOS.SearchBarEffect), "SearchBarEffects")]
namespace App15.iOS
{
    public class SearchBarEffect : PlatformEffect
    {
        UIImage searchImg;
        protected override void OnAttached()
        {
            searchImg = ((UISearchBar)Control).GetImageForSearchBarIcon(UISearchBarIcon.Search, UIControlState.Normal);
            ((UISearchBar)Control).OnEditingStarted += SearchBar_OnEditingStarted;
            ((UISearchBar)Control).OnEditingStopped += SearchBar_OnEditingStopped;
        }

        private void SearchBar_OnEditingStopped(object sender, EventArgs e)
        {
            var searchBar = sender as UISearchBar;
            searchBar.SetImageforSearchBarIcon(searchImg, UISearchBarIcon.Search, UIControlState.Normal);
        }

        private void SearchBar_OnEditingStarted(object sender, EventArgs e)
        {
            var searchBar = sender as UISearchBar;
            searchBar.SetImageforSearchBarIcon(new UIImage(), UISearchBarIcon.Search, UIControlState.Normal);
        }

        protected override void OnDetached()
        {
            ((UISearchBar)Control).OnEditingStarted -= SearchBar_OnEditingStarted;
            ((UISearchBar)Control).OnEditingStopped -= SearchBar_OnEditingStopped;
        }
    }
}

Наконец, показ эффекта выполняется двумя способами. Up - эффект, down - рендер.

enter image description here

1 голос
/ 16 октября 2019

Личная заметка - для этого не нужно использовать Custom Renderer, эффекта более чем достаточно - я тестировал с Effect, а не с Custom Renderer. О том, как создавать эффекты, см. здесь

this.Control будет UISearchBar , если вы добавите этот эффект только к элементам <SearchBar>.

Таким образом, вы можете сделать это (на основе документации iOS и Xamarin.iOS ):

Реализация эффекта iOS:

public class NoSearchIconEffect : PlatformEffect
{
    UIImage defaultIcon = null;

    protected override void OnAttached()
    {
        var searchBar = this.Control as UISearchBar;
        defaultIcon = defaultIcon ?? searchBar.GetImageForSearchBarIcon(UISearchBarIcon.Search, UIControlState.Normal); //This will save the default icon

        searchBar.OnEditingStarted += delegate
        {
            searchBar.SetImageforSearchBarIcon(new UIImage(), UISearchBarIcon.Search, UIControlState.Normal);
        };

        searchBar.OnEditingStopped += delegate
        {
            searchBar.SetImageforSearchBarIcon(defaultIcon, UISearchBarIcon.Search, UIControlState.Normal);
        };
    }

    protected override void OnDetached()
    {

    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...