java - イベント - ロック アイコン を ドラッグ と は



Android/Java-テキストビューをドラッグアンドドロップで追加GridViewチュートリアル/例 (1)

グリッド表示でドラッグドロップを実装する簡単な方法は、このリンクで見つけることができます。http://www.androidviews.net/2012/12/pageddragdropgrid/

このためのgitはhttps://github.com/mrKlar/PagedDragDropGridです

私は以下のチュートリアルからいくつかのクラスに基づいてプロジェクトを作成しました:

http://blahti.wordpress.com/2012/03/03/improved-drag-drop-for-gridview/

今私は、画像だけでなく、画像とtextViewを同時にドラッグ・アンド・ドロップできるようにサンプルを修正しようとしています。

これはどのように達成できますか?

私は既にtextViewをインスタンス化しています:

tx = (TextView) findViewById(R.id.textView1);   

今度は、チュートリアルのacceptDropメソッド(DropTargetクラス内)を変更する必要があると思いますが、その方法を100%確信しているわけではありません。

結論:

この簡単なドラッグ&ドロップのgridViewチュートリアルにtextViewを追加する方法を少し考えればいいだけです。

完全なソースはここで見られ、ダウンロードできます

https://docs.google.com/file/d/0B0wYSnCBkoR6MmdWbnktYUpTc2FFakdVU3NYeUxDZw/edit

PS

私はチュートリアルのコメントのセクションでこれを行うことに関するコメントを残し、著者は次のように述べました:

グリッドビューに表示される項目を定義するためのカスタムクラスを用意する必要があります。そのビューにはテキストと画像が表示されます新しいクラスにドラッグ&ドロップインターフェイスを実装させるacceptDropメソッドでは、と画像。

あなたが直面する問題の一部は、リストビューを持つカスタムリスト項目を持つことに似ています。 あなたがドラッグ・ドロップ部分を取る前にそれのいくつかの例を見つけることは良いかもしれません。

私はちょうどそうする助けを少し必要とする...

DropTarget.java:

/**
 * Interface defining an object that reacts to objects being dragged over and dropped onto it.
 *
 */
public interface DropTarget {

    /**
     * Handle an object being dropped on the DropTarget
     * 
     * @param source DragSource where the drag started
     * @param x X coordinate of the drop location
     * @param y Y coordinate of the drop location
     * @param xOffset Horizontal offset with the object being dragged where the original
     *          touch happened
     * @param yOffset Vertical offset with the object being dragged where the original
     *          touch happened
     * @param dragView The DragView that's being dragged around on screen.
     * @param dragInfo Data associated with the object being dragged
     * 
     */
    void onDrop(DragSource source, int x, int y, int xOffset, int yOffset,
            DragView dragView, Object dragInfo);

    /**
     * React to something started to be dragged.
     */    
    void onDragEnter(DragSource source, int x, int y, int xOffset, int yOffset,
            DragView dragView, Object dragInfo);

    /**
     * React to something being dragged over the drop target.
     */    
    void onDragOver(DragSource source, int x, int y, int xOffset, int yOffset,
            DragView dragView, Object dragInfo);

    /**
     * React to a drag 
     */    
    void onDragExit(DragSource source, int x, int y, int xOffset, int yOffset,
            DragView dragView, Object dragInfo);

    /**
     * Check if a drop action can occur at, or near, the requested location.
     * This may be called repeatedly during a drag, so any calls should return
     * quickly.
     * 
     * @param source DragSource where the drag started
     * @param x X coordinate of the drop location
     * @param y Y coordinate of the drop location
     * @param xOffset Horizontal offset with the object being dragged where the
     *            original touch happened
     * @param yOffset Vertical offset with the object being dragged where the
     *            original touch happened
     * @param dragView The DragView that's being dragged around on screen.
     * @param dragInfo Data associated with the object being dragged
     * @return True if the drop will be accepted, false otherwise.
     */
    boolean acceptDrop(DragSource source, int x, int y, int xOffset, int yOffset,
            DragView dragView, Object dragInfo);

    /**
     * Estimate the surface area where this object would land if dropped at the
     * given location.
     * 
     * @param source DragSource where the drag started
     * @param x X coordinate of the drop location
     * @param y Y coordinate of the drop location
     * @param xOffset Horizontal offset with the object being dragged where the
     *            original touch happened
     * @param yOffset Vertical offset with the object being dragged where the
     *            original touch happened
     * @param dragView The DragView that's being dragged around on screen.
     * @param dragInfo Data associated with the object being dragged
     * @param recycle {@link Rect} object to be possibly recycled.
     * @return Estimated area that would be occupied if object was dropped at
     *         the given location. Should return null if no estimate is found,
     *         or if this target doesn't provide estimations.
     */
    Rect estimateDropLocation(DragSource source, int x, int y, int xOffset, int yOffset,
            DragView dragView, Object dragInfo, Rect recycle);

    // These methods are implemented in Views
    void getHitRect(Rect outRect);
    void getLocationOnScreen(int[] loc);
    int getLeft();
    int getTop();
}




android-launcher