當前位置: 首頁>>代碼示例>>Java>>正文


Java Cursor.getPosition方法代碼示例

本文整理匯總了Java中android.database.Cursor.getPosition方法的典型用法代碼示例。如果您正苦於以下問題:Java Cursor.getPosition方法的具體用法?Java Cursor.getPosition怎麽用?Java Cursor.getPosition使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在android.database.Cursor的用法示例。


在下文中一共展示了Cursor.getPosition方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getExplainQueryPlan

import android.database.Cursor; //導入方法依賴的package包/類
private String[] getExplainQueryPlan() {
    Cursor cursor = db.rawQuery("EXPLAIN QUERY PLAN " + query, queryArgs);
    String[] plan = new String[cursor.getCount()];
    cursor.moveToFirst();
    while (!cursor.isAfterLast()) {
        // The docs at https://sqlite.org/eqp.html talk about how the output format of
        // EXPLAIN QUERY PLAN can change between SQLite versions. This has been observed
        // between the sqlite versions on Android 2.3.3 and Android 5.0. However, it seems
        // that the last column is always the one with the interesting details that we wish
        // to log. If this fails for some reason, then hey, it is only for debug builds, right?
        if (cursor.getColumnCount() > 0) {
            int index = cursor.getColumnCount() - 1;
            plan[cursor.getPosition()] = cursor.getString(index);
        }
        cursor.moveToNext();
    }
    cursor.close();
    return plan;
}
 
開發者ID:uhuru-mobile,項目名稱:mobile-store,代碼行數:20,代碼來源:LoggingQuery.java

示例2: FilteringCursorWrapper

import android.database.Cursor; //導入方法依賴的package包/類
public FilteringCursorWrapper(
        Cursor cursor, String[] acceptMimes, String[] rejectMimes, long rejectBefore) {
    mCursor = cursor;

    final int count = cursor.getCount();
    mPosition = new int[count];

    cursor.moveToPosition(-1);
    while (cursor.moveToNext() && mCount < count) {
        final String mimeType = getCursorString(cursor, Document.COLUMN_MIME_TYPE);
        final String name = getCursorString(cursor, Document.COLUMN_DISPLAY_NAME);
        final long lastModified = getCursorLong(cursor, Document.COLUMN_LAST_MODIFIED);
        if (rejectMimes != null && MimePredicate.mimeMatches(rejectMimes, mimeType)) {
            continue;
        }
        if (lastModified < rejectBefore) {
            continue;
        }

        if (MimePredicate.mimeMatches(acceptMimes, mimeType)) {
            mPosition[mCount++] = cursor.getPosition();
        }
    }

    Log.d(TAG, "Before filtering " + cursor.getCount() + ", after " + mCount);
}
 
開發者ID:medalionk,項目名稱:simple-share-android,代碼行數:27,代碼來源:FilteringCursorWrapper.java

示例3: exportTable

import android.database.Cursor; //導入方法依賴的package包/類
private JSONArray exportTable(String tableName) throws JSONException {

        // get everything from the table
        String sql = "select * from " + tableName;
        Cursor cur = mDatabase.rawQuery(sql, new String[0]);
        int numCols = cur.getColumnCount();
        JSONArray resultSet = new JSONArray();
        cur.moveToFirst();

        // move through the table, creating rows
        // and adding each column with name and value
        // to the row
        while (cur.getPosition() < cur.getCount()) {
            JSONObject rowObject = new JSONObject();
            for (int idx = 0; idx < numCols; idx++) {
                rowObject.put(cur.getColumnName(idx), cur.getString(idx));
            }

            resultSet.put(rowObject);
            cur.moveToNext();
        }

        cur.close();
        return resultSet;
    }
 
開發者ID:riteshakya037,項目名稱:Android-Scrapper,代碼行數:26,代碼來源:DatabaseDump.java

示例4: checkCursorPosition

import android.database.Cursor; //導入方法依賴的package包/類
void checkCursorPosition(Cursor cursor) throws IllegalArgumentException {
    if (cursor.getPosition() == -1) {
        throw new IllegalArgumentException(
            "Cursor position is -1. " +
            "Did you forget to moveToFirst() or move() before passing to the value object?");
    }
}
 
開發者ID:uhuru-mobile,項目名稱:mobile-store,代碼行數:8,代碼來源:ValueObject.java

示例5: migrateDatabase

import android.database.Cursor; //導入方法依賴的package包/類
public static void migrateDatabase(Context context,
                                     MasterSecret masterSecret,
                                     SmsMigrationProgressListener listener)
  {
//    if (context.getSharedPreferences("SecureSMS", Context.MODE_PRIVATE).getBoolean("migrated", false))
//      return;

    ThreadDatabase threadDatabase = DatabaseFactory.getThreadDatabase(context);
    Cursor cursor                 = null;

    try {
      Uri threadListUri = Uri.parse("content://mms-sms/conversations?simple=true");
      cursor            = context.getContentResolver().query(threadListUri, null, null, null, "date ASC");

      while (cursor != null && cursor.moveToNext()) {
        long   theirThreadId         = cursor.getLong(cursor.getColumnIndexOrThrow("_id"));
        String theirRecipients       = cursor.getString(cursor.getColumnIndexOrThrow("recipient_ids"));
        Recipients ourRecipients     = getOurRecipients(context, theirRecipients);
        ProgressDescription progress = new ProgressDescription(cursor.getCount(), cursor.getPosition(), 100, 0);

        if (ourRecipients != null) {
          long ourThreadId = threadDatabase.getThreadIdFor(ourRecipients);
          migrateConversation(context, masterSecret,
                              listener, progress,
                              theirThreadId, ourThreadId);
        }

        progress.incrementPrimaryComplete();
        listener.progressUpdate(progress);
      }
    } finally {
      if (cursor != null)
        cursor.close();
    }

    context.getSharedPreferences("SecureSMS", Context.MODE_PRIVATE).edit()
      .putBoolean("migrated", true).apply();
  }
 
開發者ID:XecureIT,項目名稱:PeSanKita-android,代碼行數:39,代碼來源:SmsMigrator.java

示例6: getType

import android.database.Cursor; //導入方法依賴的package包/類
private static int getType(Cursor cursor, int columnIndex) throws Exception
{

    if (Build.VERSION.SDK_INT >= 11)
    {
        return cursor.getType(columnIndex);
    }

    SQLiteCursor sqLiteCursor = (SQLiteCursor) cursor;
    CursorWindow cursorWindow = sqLiteCursor.getWindow();
    int pos = cursor.getPosition();
    int type = -1;
    if (cursorWindow.isNull(pos, columnIndex))
    {
        type = Cursor.FIELD_TYPE_NULL;
    } else if (cursorWindow.isLong(pos, columnIndex))
    {
        type = Cursor.FIELD_TYPE_INTEGER;
    } else if (cursorWindow.isFloat(pos, columnIndex))
    {
        type = Cursor.FIELD_TYPE_FLOAT;
    } else if (cursorWindow.isString(pos, columnIndex))
    {
        type = Cursor.FIELD_TYPE_STRING;
    } else if (cursorWindow.isBlob(pos, columnIndex))
    {
        type = Cursor.FIELD_TYPE_BLOB;
    }

    return type;
}
 
開發者ID:gzxishan,項目名稱:OftenPorter,代碼行數:32,代碼來源:TypeUtil.java

示例7: getCallTypes

import android.database.Cursor; //導入方法依賴的package包/類
/**
 * Returns the call types for the given number of items in the cursor.
 * <p>
 * It uses the next {@code count} rows in the cursor to extract the types.
 * <p>
 * It position in the cursor is unchanged by this function.
 */
private int[] getCallTypes(Cursor cursor, int count) {
    int position = cursor.getPosition();
    int[] callTypes = new int[count];
    for (int index = 0; index < count; ++index) {
        callTypes[index] = cursor.getInt(cursor.getColumnIndex(CallLog.Calls.TYPE));
        cursor.moveToNext();
    }
    cursor.moveToPosition(position);
    return callTypes;
}
 
開發者ID:treasure-lau,項目名稱:CSipSimple,代碼行數:18,代碼來源:CallLogAdapter.java

示例8: getCallIds

import android.database.Cursor; //導入方法依賴的package包/類
/**
 * Returns the call ids for the given number of items in the cursor.
 * <p>
 * It uses the next {@code count} rows in the cursor to extract the types.
 * <p>
 * It position in the cursor is unchanged by this function.
 */
private long[] getCallIds(Cursor cursor, int count) {
    int position = cursor.getPosition();
    long[] callIds = new long[count];
    for (int index = 0; index < count; ++index) {
        if(!cursor.isAfterLast()) {
            callIds[index] = cursor.getLong(cursor.getColumnIndex(CallLog.Calls._ID));
        }
        cursor.moveToNext();
    }
    cursor.moveToPosition(position);
    return callIds;
}
 
開發者ID:treasure-lau,項目名稱:CSipSimple,代碼行數:20,代碼來源:CallLogAdapter.java

示例9: createIntentFromSuggestion

import android.database.Cursor; //導入方法依賴的package包/類
/**
 * When a particular suggestion has been selected, perform the various lookups required
 * to use the suggestion.  This includes checking the cursor for suggestion-specific data,
 * and/or falling back to the XML for defaults;  It also creates REST style Uri data when
 * the suggestion includes a data id.
 *
 * @param c The suggestions cursor, moved to the row of the user's selection
 * @param actionKey The key code of the action key that was pressed,
 *        or {@link KeyEvent#KEYCODE_UNKNOWN} if none.
 * @param actionMsg The message for the action key that was pressed,
 *        or <code>null</code> if none.
 * @return An intent for the suggestion at the cursor's position.
 */
private Intent createIntentFromSuggestion(Cursor c, int actionKey, String actionMsg) {
    try {
        // use specific action if supplied, or default action if supplied, or fixed default
        String action = getColumnString(c, SearchManager.SUGGEST_COLUMN_INTENT_ACTION);

        if (action == null) {
            action = mSearchable.getSuggestIntentAction();
        }
        if (action == null) {
            action = Intent.ACTION_SEARCH;
        }

        // use specific data if supplied, or default data if supplied
        String data = getColumnString(c, SearchManager.SUGGEST_COLUMN_INTENT_DATA);
        if (data == null) {
            data = mSearchable.getSuggestIntentData();
        }
        // then, if an ID was provided, append it.
        if (data != null) {
            String id = getColumnString(c, SearchManager.SUGGEST_COLUMN_INTENT_DATA_ID);
            if (id != null) {
                data = data + "/" + Uri.encode(id);
            }
        }
        Uri dataUri = (data == null) ? null : Uri.parse(data);

        String query = getColumnString(c, SearchManager.SUGGEST_COLUMN_QUERY);
        String extraData = getColumnString(c, SearchManager.SUGGEST_COLUMN_INTENT_EXTRA_DATA);

        return createIntent(action, dataUri, extraData, query, actionKey, actionMsg);
    } catch (RuntimeException e ) {
        int rowNum;
        try {                       // be really paranoid now
            rowNum = c.getPosition();
        } catch (RuntimeException e2 ) {
            rowNum = -1;
        }
        Log.w(LOG_TAG, "Search suggestions cursor at row " + rowNum +
                        " returned exception.", e);
        return null;
    }
}
 
開發者ID:treasure-lau,項目名稱:CSipSimple,代碼行數:56,代碼來源:SearchView.java

示例10: makeSortedCursor

import android.database.Cursor; //導入方法依賴的package包/類
@Nullable
private static SortedLongCursor makeSortedCursor(@NonNull final Context context, @Nullable final Cursor cursor, final int idColumn) {
    if (cursor != null && cursor.moveToFirst()) {
        // create the list of ids to select against
        StringBuilder selection = new StringBuilder();
        selection.append(BaseColumns._ID);
        selection.append(" IN (");

        // this tracks the order of the ids
        long[] order = new long[cursor.getCount()];

        long id = cursor.getLong(idColumn);
        selection.append(id);
        order[cursor.getPosition()] = id;

        while (cursor.moveToNext()) {
            selection.append(",");

            id = cursor.getLong(idColumn);
            order[cursor.getPosition()] = id;
            selection.append(String.valueOf(id));
        }

        selection.append(")");

        // get a list of songs with the data given the selection statement
        Cursor songCursor = SongLoader.makeSongCursor(context, selection.toString(), null);
        if (songCursor != null) {
            // now return the wrapped TopTracksCursor to handle sorting given order
            return new SortedLongCursor(songCursor, order, BaseColumns._ID);
        }
    }

    return null;
}
 
開發者ID:aliumujib,項目名稱:Orin,代碼行數:36,代碼來源:TopAndRecentlyPlayedTracksLoader.java

示例11: moveCursor

import android.database.Cursor; //導入方法依賴的package包/類
public static int moveCursor(Cursor cursor, String idColumnName, long id) {
       int pos = cursor.getColumnIndexOrThrow(idColumnName);
       if (cursor.moveToFirst()) {
           do {
               if (cursor.getLong(pos) == id) {
                   return cursor.getPosition();
               }
           } while(cursor.moveToNext());
       }
	return -1;
}
 
開發者ID:tiberiusteng,項目名稱:financisto1-holo,代碼行數:12,代碼來源:Utils.java

示例12: makeSortedCursor

import android.database.Cursor; //導入方法依賴的package包/類
/**
 * 根據包含song id的cursor,獲取排序好的song cursor
 *
 * @param context
 * @param cursor
 * @param idColumn
 * @return
 */
public static SortedCursor makeSortedCursor(final Context context, final Cursor cursor,
                                            final int idColumn) {
    if (cursor != null && cursor.moveToFirst()) {

        StringBuilder selection = new StringBuilder();
        selection.append(BaseColumns._ID);
        selection.append(" IN (");

        long[] order = new long[cursor.getCount()];

        long id = cursor.getLong(idColumn);
        selection.append(id);
        order[cursor.getPosition()] = id;

        while (cursor.moveToNext()) {
            selection.append(",");

            id = cursor.getLong(idColumn);
            order[cursor.getPosition()] = id;
            selection.append(String.valueOf(id));
        }

        selection.append(")");

        Cursor songCursor = makeSongCursor(context, selection.toString(), null);
        if (songCursor != null) {
            return new SortedCursor(songCursor, order, BaseColumns._ID, null);
        }
    }

    if (cursor != null) {
        cursor.close();
    }

    return null;
}
 
開發者ID:komamj,項目名稱:KomaMusic,代碼行數:45,代碼來源:SongsPresenter.java

示例13: initConversationView

import android.database.Cursor; //導入方法依賴的package包/類
void initConversationView(final Context context, Cursor cursor, final InboxConversationView conversationView, Conversation conversation, boolean isExpanded) {
    conversationView.setAppId(conversation.getLastMessage().getAppId());
    conversationView.setAppSpecificSenderId(conversation.getSender().getAppSpecificUserId());
    conversationView.setFrom(conversation.getSender().getDisplayName());
    conversationView.setMessagePreview(conversation.getLastMessage().getBody());
    conversationView.setTimestamp(conversation.getLastMessage().getTimestamp());
    conversationView.setNumUnreadMessages(conversation.getNumUnreadMessages());
    App app = this.appManager.getAppById(conversation.getLastMessage().getAppId());
    Drawable icon = app.getAppIcon();
    ProfilePhoto profilePhoto = app.getProfilePhotoForMessage(conversation.getLastMessage());
    conversationView.setProfilePhoto(context, profilePhoto);
    if (profilePhoto == null) {
        ((ProfilePhotoManager) GuiceModule.get().getInstance(ProfilePhotoManager.class)).loadProfilePhoto(conversation.getSender().getAppId(), conversation.getSender().getAppSpecificUserId(), conversation.getSender().getDisplayName(), new ProfilePhotoManager.OnProfilePhotoLoadedListener() {
            public void onProfilePhotoLoaded(String appId, String senderId, String senderName, ProfilePhoto photo) {
                if (InboxCursorAdapter.this.areStringsEqual(appId, conversationView.getAppId()) && InboxCursorAdapter.this.areStringsEqual(senderId, conversationView.getAppSpecificSenderId()) && InboxCursorAdapter.this.areStringsEqual(senderName, conversationView.getFrom())) {
                    conversationView.setProfilePhoto(context, photo);
                }
            }
        });
    }
    conversationView.setIcon(icon);
    int index = cursor.getPosition();
    boolean showAllMessagesDivider = false;
    if (index == 0 && conversation.getNumUnreadMessages() <= 0) {
        this.firstReadConversation = conversation.getLastMessage().getTimestamp();
    } else if (index > 0 && conversation.getNumUnreadMessages() <= 0 && conversation.getLastMessage().getTimestamp() >= this.firstReadConversation) {
        this.firstReadConversation = conversation.getLastMessage().getTimestamp();
        showAllMessagesDivider = true;
    }
    conversationView.showAllMessagesDivider(showAllMessagesDivider);
}
 
開發者ID:bunnyblue,項目名稱:NoticeDog,代碼行數:32,代碼來源:InboxCursorAdapter.java

示例14: makeSortedCursor

import android.database.Cursor; //導入方法依賴的package包/類
@Nullable
private static SortedLongCursor makeSortedCursor(@NonNull final Context context, @Nullable final Cursor cursor, final int idColumn) {

    if (cursor != null && cursor.moveToFirst()) {
        // create the list of ids to select against
        StringBuilder selection = new StringBuilder();
        selection.append(BaseColumns._ID);
        selection.append(" IN (");

        // this tracks the order of the ids
        long[] order = new long[cursor.getCount()];

        long id = cursor.getLong(idColumn);
        selection.append(id);
        order[cursor.getPosition()] = id;

        while (cursor.moveToNext()) {
            selection.append(",");

            id = cursor.getLong(idColumn);
            order[cursor.getPosition()] = id;
            selection.append(String.valueOf(id));
        }

        selection.append(")");

        // get a list of songs with the data given the selection statement
        Cursor songCursor = SongLoader.makeSongCursor(context, selection.toString(), null);
        if (songCursor != null) {
            // now return the wrapped TopTracksCursor to handle sorting given order
            return new SortedLongCursor(songCursor, order, BaseColumns._ID);
        }
    }

    return null;
}
 
開發者ID:h4h13,項目名稱:RetroMusicPlayer,代碼行數:37,代碼來源:TopAndRecentlyPlayedTracksLoader.java

示例15: getItemPosition

import android.database.Cursor; //導入方法依賴的package包/類
public int getItemPosition(final long id) {
	final Cursor cursor = getCursor();
	if (cursor == null)
		return 1;

	if (cursor.moveToFirst())
		do {
			if (cursor.getLong(0 /* _ID */) == id)
				return cursor.getPosition() + 1;
		} while (cursor.moveToNext());
	return 1; // should never happen
}
 
開發者ID:runtimeco,項目名稱:Android-DFU-App,代碼行數:13,代碼來源:UARTConfigurationsAdapter.java


注:本文中的android.database.Cursor.getPosition方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。