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


Java ScaleGestureDetector.getFocusX方法代碼示例

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


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

示例1: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
public boolean onScale(ScaleGestureDetector det) {
	if (bitmap != null) {
		float focusX = det.getFocusX();
		float focusY = det.getFocusY();
		float scaleFactor = det.getScaleFactor();
		float pageFocusX = (focusX + scrollX) / viewScale;
		float pageFocusY = (focusY + scrollY) / viewScale;
		viewScale *= scaleFactor;
		if (viewScale < minScale) viewScale = minScale;
		if (viewScale > maxScale) viewScale = maxScale;
		bitmapW = (int)(bitmap.getWidth() * viewScale);
		bitmapH = (int)(bitmap.getHeight() * viewScale);
		scrollX = (int)(pageFocusX * viewScale - focusX);
		scrollY = (int)(pageFocusY * viewScale - focusY);
		scroller.forceFinished(true);
		invalidate();
	}
	return true;
}
 
開發者ID:ArtifexSoftware,項目名稱:mupdf-android-viewer-mini,代碼行數:20,代碼來源:PageView.java

示例2: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScale(ScaleGestureDetector detector) {
    if (!mSupportsZoom) return true;
    //store old sclale factor

    float oldScaleFator = mScaleFactor;
    mScaleFactor *= (detector.getScaleFactor()*detector.getScaleFactor());

    // Don't let the object get too small or too large.
    mScaleFactor = Math.max(0.1f, Math.min(mScaleFactor, 10.0f));

    mFocusX = detector.getFocusX ();
    mFocusY = detector.getFocusY ();

    //distance between focus and old origin
    float dx = mFocusX-mPosX;
    float dy = mFocusY-mPosY;
    //distance between focus and new origin after rescale
    float dxSc = dx * mScaleFactor / oldScaleFator;
    float dySc = dy * mScaleFactor / oldScaleFator;

    // calcul of the new origin
    mPosX = mFocusX - dxSc;
    mPosY = mFocusY - dySc;

    invalidate();
    return true;
}
 
開發者ID:jkobject,項目名稱:PiPle,代碼行數:29,代碼來源:PanZoomView.java

示例3: onScaleBegin

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
/**
 * @brief Handles the onScaleBegin event
 * @param detector The class which stores all the event information
 * @return true
 * @details Handles the onScaleBegin event. Calls the canvas method startDrag and gets the x and y coordinates
 */
@Override
public boolean onScaleBegin(ScaleGestureDetector detector) {
	
	zoom = true;
	drag = true;
	canvas.startDrag();
	
	x= (int)(((detector.getFocusX() / scaleFactor) + realX) -detector.getFocusX() ) ;
	y= (int)(((detector.getFocusY() / scaleFactor) + realY) -detector.getFocusY() );

	if(x <0){
		x = 0;
	}
	if(realY < 0){
		y = 0;
	}		
	
	return true;
}
 
開發者ID:CodyyAndroid,項目名稱:LibVNCAndroid,代碼行數:26,代碼來源:CanvasActivity.java

示例4: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScale(ScaleGestureDetector detector) {
    if (mZoomEnabled) {
        mFromZoomRegion = false;
        mZoomFactor *= detector.getScaleFactor();
        mZoomFactor = Math.max(1f, Math.min(mZoomFactor, mMaxZoomFactor));
        mZoomFactor = mZoomFactor > mMaxZoomFactor ? mMaxZoomFactor : mZoomFactor < 1f ? 1f : mZoomFactor;
        mZoomCenterX = detector.getFocusX() / mZoomFactor + mCanvasClipBounds.left;
        mZoomCenterY = detector.getFocusY() / mZoomFactor + mCanvasClipBounds.top;

        if (mZoomFactor > 1f)
            showHideZoomRegionView(VISIBLE);
        else
            showHideZoomRegionView(INVISIBLE);

        invalidate();
    }

    return false;
}
 
開發者ID:rosenpin,項目名稱:QuickDrawEverywhere,代碼行數:21,代碼來源:DrawView.java

示例5: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
public boolean onScale(ScaleGestureDetector detector) {
    RectF rect = mCropWindowHandler.getRect();

    float x = detector.getFocusX();
    float y = detector.getFocusY();
    float dY = detector.getCurrentSpanY() / 2;
    float dX = detector.getCurrentSpanX() / 2;

    float newTop = y - dY;
    float newLeft = x - dX;
    float newRight = x + dX;
    float newBottom = y + dY;

    if (newLeft < newRight &&
            newTop <= newBottom &&
            newLeft >= 0 &&
            newRight <= mCropWindowHandler.getMaxCropWidth() &&
            newTop >= 0 &&
            newBottom <= mCropWindowHandler.getMaxCropHeight()) {

        rect.set(newLeft, newTop, newRight, newBottom);
        mCropWindowHandler.setRect(rect);
        invalidate();
    }

    return true;
}
 
開發者ID:garretyoder,項目名稱:Cluttr,代碼行數:30,代碼來源:CropOverlayView.java

示例6: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
public boolean onScale(ScaleGestureDetector detector)
{
	//  new scale factor
	float previousScale = mScale;
	mScale = Math.min(Math.max(mScale * detector.getScaleFactor(), MIN_SCALE), MAX_SCALE);

	//  did we really scale?
	if (mScale == previousScale)
		return true;

	//  scale children
	scaleChildren();

	//  maintain focus while scaling
	double scale = mScale / previousScale;
	double currentFocusX = detector.getFocusX();
	double currentFocusY = detector.getFocusY();
	double viewFocusX = (int) currentFocusX + getScrollX();
	double viewFocusY = (int) currentFocusY + getScrollY();
	int diffX = (int) (viewFocusX * (1 - scale));
	int diffY = (int) (viewFocusY * (1 - scale));
	mXScroll += diffX;
	mYScroll += diffY;

	requestLayout();

	return true;
}
 
開發者ID:ArtifexSoftware,項目名稱:mupdf-android-viewer-nui,代碼行數:29,代碼來源:DocViewBase.java

示例7: onScaleBegin

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScaleBegin(ScaleGestureDetector detector) {
    mStartFocusX = detector.getFocusX();
    mStartFocusY = detector.getFocusY();

    mStartScrollX = getScrollX();
    mStartScrollY = getScrollY();

    mStartScale = mViewScale;
    return true;
}
 
開發者ID:Axe-Ishmael,項目名稱:Blockly,代碼行數:12,代碼來源:VirtualWorkspaceView.java

示例8: onScaleBegin

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScaleBegin(ScaleGestureDetector scaleGestureDetector) {
    Log.i(TAG, "onScaleBegin");
    mPivotX = scaleGestureDetector.getFocusX();
    mPivotY = scaleGestureDetector.getFocusY();
    return true;
}
 
開發者ID:tringuyen1121,項目名稱:Khonsu,代碼行數:8,代碼來源:ZoomLayout.java

示例9: onScaleBegin

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScaleBegin(ScaleGestureDetector detector) {
    lastFocus.x = detector.getFocusX();
    lastFocus.y = detector.getFocusY();
    mCurrentScaleMax = mCurrentScale;
    mCurrentScaleMin = mCurrentScale;
    return true;
}
 
開發者ID:metagalactic,項目名稱:ScalableImageView,代碼行數:9,代碼來源:ScalableImageView.java

示例10: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
public boolean onScale(ScaleGestureDetector detector) {
  RectF rect = mCropWindowHandler.getRect();

  float x = detector.getFocusX();
  float y = detector.getFocusY();
  float dY = detector.getCurrentSpanY() / 2;
  float dX = detector.getCurrentSpanX() / 2;

  float newTop = y - dY;
  float newLeft = x - dX;
  float newRight = x + dX;
  float newBottom = y + dY;

  if (newLeft < newRight
      && newTop <= newBottom
      && newLeft >= 0
      && newRight <= mCropWindowHandler.getMaxCropWidth()
      && newTop >= 0
      && newBottom <= mCropWindowHandler.getMaxCropHeight()) {

    rect.set(newLeft, newTop, newRight, newBottom);
    mCropWindowHandler.setRect(rect);
    invalidate();
  }

  return true;
}
 
開發者ID:prashantsaini1,項目名稱:android-titanium-imagecropper,代碼行數:30,代碼來源:CropOverlayView.java

示例11: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScale(ScaleGestureDetector scaleGestureDetector) {

    if (!mScaleXEnable) return false;
    if (!mScaleGestureEnable) return super.onScale(scaleGestureDetector);

    float spanX = ScaleGestureDetectorCompat.getCurrentSpanX(scaleGestureDetector);

    float newWidth = lastSpanX / spanX * mCurrentViewport.width();

    if (newWidth < mCurrentViewport.width() && mCurrentViewport.width() < 0.1) {
        return true;
    }

    float focusX = scaleGestureDetector.getFocusX();
    float focusY = scaleGestureDetector.getFocusY();
    hitTest(focusX, focusY, viewportFocus);

    mCurrentViewport.left = viewportFocus.x
            - newWidth * (focusX - mContentRect.left)
            / mContentRect.width();

    mCurrentViewport.right = mCurrentViewport.left + newWidth;
    mCurrentViewport.constrainViewport();
    if (mScaleXEnable) triggerViewportChange();
    lastSpanX = spanX;

    return true;
}
 
開發者ID:donglua,項目名稱:JZAndroidChart,代碼行數:30,代碼來源:Chart.java

示例12: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScale(ScaleGestureDetector detector) {
    if (setState(PINCHING)) {
        float eps = 0.0001f;
        if (Math.abs(mAbsTargetX) < eps || Math.abs(mAbsTargetY) < eps) {
            // We want to interpret this as a scaled value, to work with the *actual* zoom.
            @ScaledPan float scaledFocusX = -detector.getFocusX();
            @ScaledPan float scaledFocusY = -detector.getFocusY();
            LOG.i("onScale:", "Setting focus.", "detectorFocusX:", scaledFocusX, "detectorFocusX:", scaledFocusY);

            // Account for current pan.
            scaledFocusX += getScaledPanX();
            scaledFocusY += getScaledPanY();

            // Transform to an absolute, scale-independent value.
            mAbsTargetX = unresolvePan(scaledFocusX);
            mAbsTargetY = unresolvePan(scaledFocusY);
            LOG.i("onScale:", "Setting focus.", "absTargetX:", mAbsTargetX, "absTargetY:", mAbsTargetY);
        }

        // Having both overPinch and overScroll is hard to manage, there are lots of bugs if we do.
        float factor = detector.getScaleFactor();
        float newZoom = mZoom * factor;
        applyPinch(newZoom, mAbsTargetX, mAbsTargetY, true);
        return true;
    }
    return false;
}
 
開發者ID:natario1,項目名稱:ZoomLayout,代碼行數:29,代碼來源:ZoomEngine.java

示例13: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScale(ScaleGestureDetector detector) {
	if(source != null) {
		// Zoom horizontal if focus in the main area or always if decoupled axis is deactivated:
		if(!decoupledAxis || detector.getFocusX() > getGridSize()*1.5) {
			float xScale = detector.getCurrentSpanX() / detector.getPreviousSpanX();
			long frequencyFocus = virtualFrequency + (int) ((detector.getFocusX() / width - 0.5) * virtualSampleRate);
			int maxSampleRate = demodulationEnabled ? (int) (source.getSampleRate() * 0.9) : source.getMaxSampleRate();
			if(recordingEnabled)
				maxSampleRate = source.getSampleRate();
			virtualSampleRate = (int) Math.min(Math.max(virtualSampleRate / xScale, MIN_VIRTUAL_SAMPLERATE), maxSampleRate);
			virtualFrequency = Math.min(Math.max(frequencyFocus + (long) ((virtualFrequency - frequencyFocus) / xScale),
					source.getMinFrequency() - source.getSampleRate() / 2), source.getMaxFrequency() + source.getSampleRate() / 2);

			// if we zoomed the channel selector out of the window, reset the channel selector:
			if (demodulationEnabled && channelFrequency < virtualFrequency - virtualSampleRate / 2) {
				channelFrequency = virtualFrequency - virtualSampleRate / 2;
				rfControlInterface.updateChannelFrequency(channelFrequency);
			}
			if (demodulationEnabled && channelFrequency > virtualFrequency + virtualSampleRate / 2) {
				channelFrequency = virtualFrequency + virtualSampleRate / 2;
				rfControlInterface.updateChannelFrequency(channelFrequency);
			}
		}

		// Zoom vertical if enabled and focus in the left grid area or if decoupled axis is deactivated:
		if (verticalZoomEnabled && (!decoupledAxis || detector.getFocusX() <= getGridSize() * 1.5)) {
			float yScale = detector.getCurrentSpanY() / detector.getPreviousSpanY();
			float dBFocus = maxDB - (maxDB - minDB) * (detector.getFocusY() / getFftHeight());
			float newMinDB = Math.min(Math.max(dBFocus - (dBFocus - minDB) / yScale, MIN_DB), MAX_DB - 10);
			float newMaxDB = Math.min(Math.max(dBFocus - (dBFocus - maxDB) / yScale, newMinDB + 10), MAX_DB);
			this.setDBScale(newMinDB, newMaxDB);

			// adjust the squelch if it is outside the visible viewport right now:
			if(squelch < minDB)
				squelch = minDB;
			if(squelch > maxDB)
				squelch = maxDB;
		}

		// Automatically re-adjust the sample rate of the source if we zoom too far out or in
		// (only if not recording or demodulating!)
		if(!recordingEnabled && !demodulationEnabled) {
			if (source.getSampleRate() < virtualSampleRate && virtualSampleRate < source.getMaxSampleRate())
				source.setSampleRate(source.getNextHigherOptimalSampleRate(virtualSampleRate));
			int nextLower = source.getNextLowerOptimalSampleRate(source.getSampleRate());
			if ((virtualSampleRate < nextLower) && (source.getSampleRate() > nextLower)) {
				source.setSampleRate(nextLower);
			}
		}
	}
	return true;
}
 
開發者ID:takyonxxx,項目名稱:AndroidSdrRtlTuner,代碼行數:54,代碼來源:AnalyzerSurface.java

示例14: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScale(ScaleGestureDetector detector) {
    final float oldViewScale = mViewScale;

    final float scaleFactor = detector.getScaleFactor();
    mViewScale *= scaleFactor;

    if (mViewScale < ZOOM_SCALES[0]) {
        mCurrentZoomScaleIndex = 0;
        mViewScale = ZOOM_SCALES[mCurrentZoomScaleIndex];
    } else if (mViewScale > ZOOM_SCALES[ZOOM_SCALES.length - 1]) {
        mCurrentZoomScaleIndex = ZOOM_SCALES.length - 1;
        mViewScale = ZOOM_SCALES[mCurrentZoomScaleIndex];
    } else {
        // find nearest zoom scale
        float minDist = Float.MAX_VALUE;
        // If we reach the end the last one was the closest
        int index = ZOOM_SCALES.length - 1;
        for (int i = 0; i < ZOOM_SCALES.length; i++) {
            float dist = Math.abs(mViewScale - ZOOM_SCALES[i]);
            if (dist < minDist) {
                minDist = dist;
            } else {
                // When it starts increasing again we've found the closest
                index = i - 1;
                break;
            }
        }
        mCurrentZoomScaleIndex = index;
    }

    if (shouldDrawGrid()) {
        mGridRenderer.updateGridBitmap(mViewScale);
    }

    mWorkspaceView.setScaleX(mViewScale);
    mWorkspaceView.setScaleY(mViewScale);

    // Compute scroll offsets based on difference between original and new scaling factor
    // and the focus point where the gesture started. This makes sure that the scroll offset
    // is adjusted to keep the focus point in place on the screen unless there is also a
    // focus point shift (see next scroll component below).
    final float scaleDifference = mViewScale - mStartScale;
    final int scrollScaleX = (int) (scaleDifference * mStartFocusX);
    final int scrollScaleY = (int) (scaleDifference * mStartFocusY);

    // Compute scroll offset based on shift of the focus point. This makes sure the view
    // pans along with the focus.
    final int scrollPanX = (int) (mStartFocusX - detector.getFocusX());
    final int scrollPanY = (int) (mStartFocusY - detector.getFocusY());

    // Apply the computed scroll components for scale and panning relative to the scroll
    // coordinates at the beginning of the gesture.
    scrollTo(mStartScrollX + scrollScaleX + scrollPanX,
            mStartScrollY + scrollScaleY + scrollPanY);

    return true;
}
 
開發者ID:Axe-Ishmael,項目名稱:Blockly,代碼行數:59,代碼來源:VirtualWorkspaceView.java

示例15: onScale

import android.view.ScaleGestureDetector; //導入方法依賴的package包/類
@Override
public boolean onScale(ScaleGestureDetector detector) {
    if (mIsAnimating) {
        return true;
    }

    focus.x = detector.getFocusX();
    focus.y = detector.getFocusY();

    float scale = detector.getScaleFactor();
    mAttemptedScaleMax = Math.max(scale, mAttemptedScaleMax);
    mAttemptedScaleMin = Math.min(scale, mAttemptedScaleMin);
    mCurrentScale = calculateNewScale(mCurrentScale, scale);
    mCurrentScaleMax = Math.max(mCurrentScale, mCurrentScaleMax);
    mCurrentScaleMin = Math.min(mCurrentScale, mCurrentScaleMin);

    if (Float.compare(mCurrentScale, NO_SCALE) > 0) {
        if (!ScaleType.MATRIX.equals(getScaleType())) {
            // Ensure we have the correct scale type
            setScaleType(ScaleType.MATRIX);
        }

        // For now we will always begin with a matrix that simulates a "fitCenter"
        // type of behavior; we can then apply cumulative transformations to this
        // matrix in order to have greater control over the current values of
        // scales, translations, etc.
        mMatrix.set(getFitCenterMatrix(ScalableImageView.this));

        // Scale the matrix to the current scale around the view center
        mMatrix.postScale(
                mCurrentScale,
                mCurrentScale,
                getX() + getWidth() * 0.5f,
                getY() + getHeight() * 0.5f);

        // Re-apply any translations from panning and also translate according to
        // to any lateral motion while scaling.
        mCurrentTranslation.x += focus.x - lastFocus.x;
        mCurrentTranslation.y += focus.y - lastFocus.y;
        mCurrentTranslation = getTranslationInBounds(mCurrentTranslation,
                ScalableImageView.this, mMatrix);
        mMatrix.postTranslate(mCurrentTranslation.x, mCurrentTranslation.y);

        lastFocus.x = focus.x;
        lastFocus.y = focus.y;
        setImageMatrix(mMatrix);
        return true;
    } else {
        resetScaling(hasScaled());
        return false;
    }
}
 
開發者ID:metagalactic,項目名稱:ScalableImageView,代碼行數:53,代碼來源:ScalableImageView.java


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