J'essaie d'utiliser la grille mais j'ai besoin de changer la direction d'insertion des enfants de ( gauche à droite ) à ( droite à gauche ). Y a-t-il un moyen de le faire, un exemple simple m'aiderait davantage.
Merci d'avance.
J'essaie d'utiliser la grille mais j'ai besoin de changer la direction d'insertion des enfants de ( gauche à droite ) à ( droite à gauche ). Y a-t-il un moyen de le faire, un exemple simple m'aiderait davantage.
Merci d'avance.
J'ai écrit ceci. Je pense avoir résolu votre problème
/** Returns inverted list by step that take. for example if our list is {1, 2, 3, 4, 5, 6,
* 7 ,8 ,9} and step is 3 inverted list is this: {3, 2, 1, 6, 5, 4, 9, 8, 7}
*/
public static <E> ArrayList<E> invert(List<E> source, int step){
List<E> inverted = new ArrayList<E>();
for(int i = 0; i < source.size(); i++){
if((i + 1) % step == 0){
for(int j = i, count = 0; count < step; j--, count++){
inverted.add(source.get(j));
}
}
}
//
// When (source.size() % step) is not 0 acts.this is for last of list. add last part
// of the source that wasn't add.
//
int remainder = source.size() % step;
if((remainder) != 0 ){
for (int j = source.size() - 1, count = 0; count < (remainder); j--, count++) {
inverted.add(source.get(j));
}
}
return (ArrayList<E>) inverted;
}
Je suppose que le seul moyen est de créer un gridview personnalisé, en surchargeant la méthode onLayout(). Jetez un coup d'œil aquí .
ou peut-être pouvez-vous inverser les éléments pour chaque ligne de l'adaptateur de liste ? comme pour une grille à 3 colonnes, au lieu de
[1 2 3][4 5 6][7 8] -->
[3 2 1][6 5 4][null 8 7].
(j'admets que je n'ai jamais utilisé gridview)
J'ai rencontré le même problème mais il a été résolu en utilisant la réinitialisation d'Array. Ici on ne change que u r column no = 3
ArrayList<String> tb_ith_sections_list = new ArrayList<String>;
tb_ith_sections_list = dbhelper.getArrayList();
int sectionCount = tb_ith_sections_list.size();
if(sectionCount > 0){
int rowCount =sectionCount/4;
int colCount ;
if(sectionCount > 4){
colCount=4;
}else{
colCount = sectionCount;
}
if(colCount>sectionCount){
colCount=sectionCount;
}
int k=colCount;
int m=0;
for(int j=0;j<rowCount;j++){
m=(j*colCount);
k=m+colCount;
if(k>sectionCount){
k=(sectionCount-(j*colCount));
}
for(int i=m;i<k;i++){
TB_IVN_SECTIONS tb_Temp=new TB_IVN_SECTIONS();
TB_IVN_SECTIONS tb_ithFirst=tb_ith_sections_list.get(i);
TB_IVN_SECTIONS tb_ithSecond= tb_ith_sections_list.get(k-1);
tb_Temp=tb_ithFirst;
tb_ith_sections_list.set(i, tb_ithSecond);
tb_ith_sections_list.set(k-1,tb_ithFirst);
k--;
}
}
Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.