Glass की मदद से, अपने कार्ड के साथ स्क्रोल करने जैसे बेहतर इंटरैक्शन तैयार किए जा सकते हैं और ऐनिमेशन शामिल हैं.
गतिविधियों में कार्ड स्क्रोल करना
ग्लास डिसप्ले और टचपैड, स्वाइप किए जा सकने वाले कार्ड दिखाने के लिए बेहतरीन हैं,
जैसे कि ग्लास टाइमलाइन में देखा जा सकता है. अगर आपको कोई गतिविधि बनानी है, तो
उसी तरह के प्रभाव
CardScrollView
विजेट.
- लागू करने के लिए
CardScrollAdapter
करने के लिए कार्डCardScrollView
. स्टैंडर्ड व्यू हैरारकी (व्यू और व्यू ग्रुप के लेआउट का क्रम) खुद बनाई जा सकती है याCardBuilder
क्लास. - किसी प्रॉडक्ट की पिच के लिए
CardScrollView
जोCardScrollAdapter
कार्ड के सप्लायर के तौर पर. - अपनी गतिविधि के कॉन्टेंट व्यू को
CardScrollView
याCardScrollView
का इस्तेमाल कर सकते हैं.
यहां एक आसान तरीके से लागू करने का तरीका बताया गया है, जो तीन कार्ड तक स्क्रोल करता है:
public class CardScrollActivity extends Activity {
private List<CardBuilder> mCards;
private CardScrollView mCardScrollView;
private ExampleCardScrollAdapter mAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
createCards();
mCardScrollView = new CardScrollView(this);
mAdapter = new ExampleCardScrollAdapter();
mCardScrollView.setAdapter(mAdapter);
mCardScrollView.activate();
setContentView(mCardScrollView);
}
private void createCards() {
mCards = new ArrayList<CardBuilder>();
mCards.add(new CardBuilder(this, CardBuilder.Layout.TEXT)
.setText("This card has a footer.")
.setFootnote("I'm the footer!"));
mCards.add(new CardBuilder(this, CardBuilder.Layout.CAPTION)
.setText("This card has a puppy background image.")
.setFootnote("How can you resist?")
.addImage(R.drawable.puppy_bg));
mCards.add(new CardBuilder(this, CardBuilder.Layout.COLUMNS)
.setText("This card has a mosaic of puppies.")
.setFootnote("Aren't they precious?")
.addImage(R.drawable.puppy_small_1);
.addImage(R.drawable.puppy_small_2);
.addImage(R.drawable.puppy_small_3));
}
private class ExampleCardScrollAdapter extends CardScrollAdapter {
@Override
public int getPosition(Object item) {
return mCards.indexOf(item);
}
@Override
public int getCount() {
return mCards.size();
}
@Override
public Object getItem(int position) {
return mCards.get(position);
}
@Override
public int getViewTypeCount() {
return CardBuilder.getViewTypeCount();
}
@Override
public int getItemViewType(int position){
return mCards.get(position).getItemViewType();
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
return mCards.get(position).getView(convertView, parent);
}
}
}
स्क्रोल कार्ड का इस्तेमाल करके इंटरैक्ट करना
से
CardScrollView
AdapterView
तक बढ़ाएं
तो स्टैंडर्ड Android लिसनर का इस्तेमाल किया जा सकता है.
- इनहेरिट किए गए को कॉल करें
आपके
CardScrollView
परsetOnItemClickListener()
. - लागू करने के लिए
onItemClick()
टैप इवेंट के लिए हैंडलर.
यहां पिछले उदाहरण का एक्सटेंशन दिया गया है, जिसमें टैप करने पर आवाज़ आने लगती है कार्ड पर टैप करने के बाद:
@Override
protected void onCreate(Bundle savedInstanceState) {
...
setupClickListener();
setContentView(mCardScrollView);
}
private void setupClickListener() {
mCardScrollView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
AudioManager am = (AudioManager) getSystemService(Context.AUDIO_SERVICE);
am.playSoundEffect(Sounds.TAP);
}
});
}
स्क्रोलिंग कार्ड ऐनिमेट करना
स्क्रोलिंग कार्ड के लिए तीन ऐनिमेशन उपलब्ध हैं: नेविगेशन, इंसर्शन, और मिटाना.
- कार्ड सेट में एक तय जगह पर कार्ड में कोई इंसर्ट करें या मिटाएं.
- कॉल करें
animate()
औरCardScrollView.Animation
ईनम के मान का इस्तेमाल करें. बेहतर ऐनिमेशन दिखाने के लिए, इसके सभी रेफ़रंस हटाएं
notifyDataSetChanged()
.animate()
तरीका आपके डेटा सेट व्यू को अपडेट करने का काम करता है.private class ExampleCardScrollAdapter extends CardScrollAdapter { ... // Inserts a card into the adapter, without notifying. public void insertCardWithoutNotification(int position, CardBuilder card) { mCards.add(position, card); } } private void insertNewCard(int position, CardBuilder card) { // Insert new card in the adapter, but don't call // notifyDataSetChanged() yet. Instead, request proper animation // to inserted card from card scroller, which will notify the // adapter at the right time during the animation. mAdapter.insertCardWithoutNotification(position, card); mCardScrollView.animate(position, CardScrollView.Animation.INSERTION); }
स्क्रोल कार्ड की परफ़ॉर्मेंस और उन्हें लागू करने से जुड़ी सलाह
रिपोर्ट बनाते समय डिज़ाइन और परफ़ॉर्मेंस से जुड़ी इन चीज़ों का ध्यान रखें कार्ड स्क्रोलर.
कार्ड लाइफ़साइकल
परफ़ॉर्मेंस बेहतर बनाने के लिए, CardScrollView
कार्ड का सिर्फ़ एक सबसेट लोड करता है
CardScrollAdapter
ऐसी जानकारी जो लोगों को दिखती है. आम तौर पर, ऐसी कुछ और जानकारी होती है.
इस वजह से, कार्ड को इन चार सामान्य स्थितियों में से किसी में भी रखा जा सकता है:
- डिटैच किया गया - कार्ड के स्क्रोल व्यू में, मौजूदा समय में इस कार्ड की ज़रूरत नहीं है.
आपको कार्ड के
onDetachedToWindow()
से सूचना मिलती है विधि से अगर कोई कार्ड पहले अटैच किया गया था और फिर डिटैच किया गया था. - अटैच किया गया - कार्ड स्क्रोल व्यू, अडैप्टर से कार्ड का अनुरोध करता है
getView()
है, क्योंकि कार्ड "चालू" होने के करीब है. ऐसा होने पर, आपको कार्ड केonAttachedToWindow()
तरीके से सूचना दी जाती है. - चालू है - उपयोगकर्ता को कार्ड की जानकारी कुछ हद तक दिख रही है, लेकिन कार्ड स्क्रोल हो रहा है
दृश्य में "चुना गया" नहीं है उपयोगकर्ता को दिखाया जाने वाला कार्ड. कॉन्टेंट बनाने
'isActived()' तरीका
इस मामले में,
true
दिखाता है. - चुना गया - कार्ड उपयोगकर्ता का
पूरी स्क्रीन.
getSelectedView()
को कॉल करने पर, चुना गया कार्ड मौजूदा समय में दिखता है.isSelected()
तरीका इस्तेमाल करने पर, नतीजा मिलता है सही है.
अगर आप अपने कार्ड के व्यू को ऐनिमेट कर रहे हैं या दूसरे महंगे काम कर रहे हैं,
इसमें कार्रवाइयों को शुरू और बंद करता है
onAttachedToWindow()
और
onDetachedToWindow()
ताकि संसाधनों को सेव किया जा सके.
कार्ड को रीसाइकल करना
जब किसी कार्ड को अलग करने के बाद अटैच किया जाता है, तो उससे जुड़ा व्यू ऑब्जेक्ट कार्ड को रीसाइकल किया जा सकता है और अटैच किए जा रहे कार्ड में इस्तेमाल किया जा सकता है. अपडेट की गई जानकारी के साथ व्यू को रीसाइकल करना जिससे नए व्यू बन सकते हैं.
कार्ड को रीसाइकल करने के लिए,
getItemViewType()
getViewTypeCount()
,
और getView()
तरीके को अपनाना
CardScrollAdapter
क्लास. इसके बाद, आपने CardBuilder
में कुछ आसान तरीकों का इस्तेमाल किया है
आपके CardScrollAdapter
में रीसाइकलिंग लागू करने के लिए क्लास,
जैसा कि नीचे दिए गए उदाहरण में बताया गया है:
private List<CardBuilder> mCards;
...
/**
* Returns the number of view types for the CardBuilder class. The
* CardBuilder class has a convenience method that returns this value for
* you.
*/
@Override
public int getViewTypeCount() {
return CardBuilder.getViewTypeCount();
}
/**
* Returns the view type of this card, so the system can figure out
* if it can be recycled. The CardBuilder.getItemViewType() method
* returns it's own type.
*/
@Override
public int getItemViewType(int position){
return mCards.get(position).getItemViewType();
}
/**
* When requesting a card from the adapter, recycle the view if possible.
* The CardBuilder.getView() method automatically recycles the convertView
* it receives, if possible, or creates a new view if convertView is null or
* of the wrong type.
*/
@Override
public View getView(int position, View convertView, ViewGroup parent) {
return mCards.get(position).getView(convertView, parent);
}
स्थायी कार्ड आईडी लागू करना
जब कोई कार्ड चुना जाता है और लोगों को दिखाया जाता है, तब शायद आप ये काम न कर पाएं
आपको मिल रहे अडैप्टर में बदलाव करने की ज़रूरत है, ताकि लोगों को दिखने वाले कार्ड पर इसका असर पड़े
उसी समय. उदाहरण के लिए, अगर कोई उपयोगकर्ता, चुने गए किसी कार्ड और किसी कार्ड को देख रहा हो
उस कार्ड की बाईं ओर हटा दिया जाता है,
में बाईं ओर शिफ़्ट हो सकता है, क्योंकि
CardScrollAdapter
बदलाव होने पर, डिफ़ॉल्ट रूप से मौजूद डेटा सेट को फिर से आईडी असाइन करता है.
अगर आपको अपने कार्ड के लिए यूनीक आईडी असाइन करना सही लगता है, तो
ऊपर बताई गई समस्या को रोकने के लिए, डेटा सेट में एक जैसा आईडी होगा.
ऐसा करने के लिए, ओवरराइड करें
hasStableIds()
और true
वापस करें. इससे सिस्टम को यह पता चलता है कि
CardScrollAdapter
डेटा सेट में होने वाले सभी बदलावों के लिए स्थायी आईडी बनाए रखता है. इसके अलावा,
getItemId()
ताकि आपके अडैप्टर में मौजूद कार्ड का सही यूनीक आईडी दिखाया जा सके.
डिफ़ॉल्ट रूप से लागू होने पर, अडैप्टर में कार्ड की पोज़िशन इंडेक्स दिखती है.
जो स्वाभाविक रूप से अस्थिर है.
कार्डस्क्रोल अडैप्टर खाली है
जब आपके पास अडैप्टर के लिए कोई खाली डेटा सेट होता है, तो डिफ़ॉल्ट व्यू यह होता है
पर नज़र आ रही है. अगर आपको इन मामलों में अलग व्यू दिखाना है, तो
setEmptyView()
का इस्तेमाल न करें.
इसके बजाय, अपने CardScrollAdapter
में एक कार्ड बनाएं.
हॉरिज़ॉन्टल टगिंग फ़ीडबैक
Glass पर पहले से मौजूद कई चीज़ें "टगिंग" उपलब्ध कराती हैं पीछे की ओर स्वाइप करते समय और सुझाव, फ़ॉरवर्ड कोई कार्रवाई नहीं करते. उदाहरण के लिए, आपको यह सुझाव तब दिखेगा, जब स्वाइप करके फ़ोटो खींचें.
अगर आपका इमर्शन, परफ़ॉर्म करने के लिए हॉरिज़ॉन्टल स्वाइप वाले जेस्चर का इस्तेमाल नहीं करता
ऐप्लिकेशन-विशिष्ट फ़ंक्शन के साथ,
लेआउट,
CardScrollView
जिसमें एक कार्ड होता है.
अपने प्रोजेक्ट में नीचे दी गई हेल्पर क्लास कॉपी करें:
public class TuggableView extends CardScrollView { private final View mContentView; /** * Initializes a TuggableView that uses the specified layout * resource for its user interface. */ public TuggableView(Context context, int layoutResId) { this(context, LayoutInflater.from(context) .inflate(layoutResId, null)); } /** * Initializes a TuggableView that uses the specified view * for its user interface. */ public TuggableView(Context context, View view) { super(context); mContentView = view; setAdapter(new SingleCardAdapter()); activate(); } /** * Overridden to return false so that all motion events still * bubble up to the activity's onGenericMotionEvent() method after * they are handled by the card scroller. This allows the activity * to handle TAP gestures using a GestureDetector instead of the * card scroller's OnItemClickedListener. */ @Override protected boolean dispatchGenericFocusedEvent(MotionEvent event) { super.dispatchGenericFocusedEvent(event); return false; } /** Holds the single "card" inside the card scroll view. */ private class SingleCardAdapter extends CardScrollAdapter { @Override public int getPosition(Object item) { return 0; } @Override public int getCount() { return 1; } @Override public Object getItem(int position) { return mContentView; } @Override public View getView(int position, View recycleView, ViewGroup parent) { return mContentView; } } }
अपनी गतिविधि में मौजूद
onCreate
तरीके में बदलाव करें, ताकिCardScrollView
को दिखाया जा सके में आपका लेआउट होता है.@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // was: setContentView(R.layout.main_activity); setContentView(new TuggableView(this, R.layout.main_activity)); }