如何在xamarin中构建自定义视图

时间:2013-07-03 10:26:21

标签: android xamarin android-custom-view

是否有任何教程可以让我在xamarin中设计自定义视图?我想使用xamarin为我的Android应用程序构建缩放缩放功能。

我尝试过以下代码,但它无效,我总是收到android.view.InflateException: Binary XML file line #1: Error inflating class LA_Application.ZoomView错误

using System;    
using System.Collections.Generic;
using System.Linq;    
using System.Text;    
using Android.App;    
using Android.Content;    
using Android.OS;    
using Android.Runtime;    
using Android.Util;    
using Android.Views;    
using Android.Widget;    
using Android.Graphics;

namespace LA_Application    
{

    public class ZoomView : FrameLayout      
    {

        private ScaleGestureDetector mScaleDetector;    
        private static float mScaleFactor = 1.0f;   


        public ZoomView (Context context) : base (context)
        {
            Initialize ();    
        }

        public ZoomView (Context context, IAttributeSet attrs) : base (context,attrs)    
        {
            Initialize ();    
        }

        public ZoomView (Context context, IAttributeSet attrs, int defStyle) : base (context, attrs, defStyle)
        {
            Initialize ();
        }

        void Initialize ()
        {
            mScaleDetector = new ScaleGestureDetector(Context, new ScaleListener());
        }

        public override bool OnTouchEvent (MotionEvent e)
        {
            mScaleDetector.OnTouchEvent(e);

            return true;
        }

        protected override void OnDraw(Android.Graphics.Canvas canvas)
        {
            base.OnDraw(canvas);

            canvas.Save();    
            canvas.Scale(mScaleFactor, mScaleFactor);
            canvas.Restore();
        }
    }

    private class ScaleListener : ScaleGestureDetector.SimpleOnScaleGestureListener
    {
        public override bool OnScale(ScaleGestureDetector detector)
        {
            mScaleFactor *= detector.ScaleFactor;

            // Don't let the object get too small or too large.
            mScaleFactor = Math.Max(0.1f, Math.Min(mScaleFactor, 5.0f));

            return true;
        }  
    }
}

}

并在布局文件中

<?xml version="1.0" encoding="utf-8"?>
<LA_Application.ZoomView xmlns:android="http://schemas.android.com/apk/res/android"
                         android:layout_width="match_parent"
                         android:layout_height="match_parent"
                         android:id="@+id/my_view" />

活动代码

protected override void OnCreate (Bundle bundle)
{
    base.OnCreate (bundle);

    SetContentView(Resource.Layout.zoomview);

    /*some code*/
}

3 个答案:

答案 0 :(得分:7)

在布局文件中,您需要用小写字母写出类的路径。 对我来说Core.Droid.MyImageView必须写成core.droid.MyImageView

我不确定是否只有小写字母或所有字母,但您可以尝试lA_Application.ZoomViewla_application.ZoomView。其中一个很可能会工作:)

答案 1 :(得分:2)

以下是如何在xamarin.android

中创建自定义视图的框架

http://xandroid4net.blogspot.com/2014/09/custom-view.html

然后接受Emmanuel Touzery的回答并将其添加到骨架

android pinch zoom

答案 2 :(得分:1)

我建议查看这个Java Android教程,以了解您需要设置的内容:

http://developer.android.com/training/custom-views/index.html

您可能需要为自定义视图创建属性xml文件。

您可能需要考虑的另一种方法是使用片段而不是视图:

http://docs.xamarin.com/guides/android/platform_features/fragments/fragments_walkthrough