165a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane/*
265a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * Copyright (C) 2014 The Android Open Source Project
365a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane *
465a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * Licensed under the Apache License, Version 2.0 (the "License");
565a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * you may not use this file except in compliance with the License.
665a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * You may obtain a copy of the License at
765a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane *
865a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane *      http://www.apache.org/licenses/LICENSE-2.0
965a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane *
1065a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * Unless required by applicable law or agreed to in writing, software
1165a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * distributed under the License is distributed on an "AS IS" BASIS,
1265a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1365a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * See the License for the specific language governing permissions and
1465a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * limitations under the License.
1565a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane */
1665a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane
1765a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lanepackage com.android.tv.settings.widget;
1865a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane
1965a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Laneimport android.view.View;
2065a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane
2165a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane/**
2265a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * The adapter can optionally implement ScrollAdapterCustomSize in addition to ScrollAdapter.
2365a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * This class is used as same purpose of attribute "selectedSize" of ScrollAdapterView but
2465a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane * can handle complicated size (e.g. the size of focused item is not same)
2565a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane */
2665a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lanepublic interface ScrollAdapterCustomSize extends ScrollAdapter {
2765a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane
2865a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane    /**
2965a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane     * return in pixels space when an item is in selected state.
3065a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane     * For example,  the app may set a focused item to take 120 pixels comparing to
3165a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane     * 100pixels of unfocused one.  ScrollAdapterView will assign more or less
3265a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane     * space to the focused item and animate the growing/shrinking.<p>
3365a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane     * NOTE: {@link ScrollAdapterView} does not actually scale the View or change
3465a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane     * it's width or height,  the view itself is responsible doing the scale in
3565a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane     * {@link ScrollAdapterTransform} or {@link ScrollAdapterView.OnScrollListener}
3665a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane     */
3765a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane    int getSelectItemSize(int adapterIndex, View view);
3865a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane
3965a5a7d84ad9b5324ae53eda526e39e513473af7Christopher Lane}
40