当前位置: 首页>>代码示例>>C#>>正文


C# WriteableBitmap.CopyPixels方法代码示例

本文整理汇总了C#中System.Windows.Media.Imaging.WriteableBitmap.CopyPixels方法的典型用法代码示例。如果您正苦于以下问题:C# WriteableBitmap.CopyPixels方法的具体用法?C# WriteableBitmap.CopyPixels怎么用?C# WriteableBitmap.CopyPixels使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.Windows.Media.Imaging.WriteableBitmap的用法示例。


在下文中一共展示了WriteableBitmap.CopyPixels方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: DrawRectangle

        /// <summary>
        /// Draws a red rectangle on the bitmap
        /// </summary>
        /// <param name="bitmap">The bitmap to draw on</param>
        /// <param name="rect">The position of the rectangle to draw</param>
        public static void DrawRectangle( WriteableBitmap bitmap, Rect rect )
        {
            int stride = ( bitmap.PixelWidth * bitmap.Format.BitsPerPixel + 7 ) / 8;

             byte[] pixelByteArray = new byte[bitmap.PixelHeight * stride];
             bitmap.CopyPixels( pixelByteArray, stride, 0 );

             for ( int column = 0; column < bitmap.PixelWidth; column++ )
             {
            for ( int row = 0; row < bitmap.PixelHeight; row++ )
            {
               if ( ( column == rect.X && row >= rect.Y && row <= rect.Y + rect.Height ) ||
                    ( row == rect.Y && column >= rect.X && column <= rect.X + rect.Width ) ||
                    ( column == rect.X + rect.Width && row >= rect.Y && row <= rect.Y + rect.Height ) ||
                    ( row == rect.Y + rect.Height && column >= rect.X && column <= rect.X + rect.Width ) )
               {
                  int index = row * stride + 4 * column;
                  pixelByteArray[index] = 0;
                  pixelByteArray[index + 1] = 0;
                  pixelByteArray[index + 2] = 255;
               }
            }
             }
             bitmap.WritePixels( new Int32Rect( 0, 0, bitmap.PixelWidth, bitmap.PixelHeight ), pixelByteArray, stride, 0 );
        }
开发者ID:dmarkachev,项目名称:CSE803Project,代码行数:30,代码来源:BitmapColorer.cs

示例2: WriteableBitmapWrapper

        public WriteableBitmapWrapper(WriteableBitmap source)
        {
            _inner = source;
            _width = source.PixelWidth;

            int width = _inner.PixelWidth;
            int height = _inner.PixelHeight;
            _pixels = new int[width * height];
            _inner.CopyPixels(_pixels, width * 4, 0);
        }
开发者ID:tgjones,项目名称:nexus,代码行数:10,代码来源:WriteableBitmapWrapper.cs

示例3: BitmapSourceToMat

        public static Mat<byte> BitmapSourceToMat(BitmapSource source)
        {
            WriteableBitmap writeableBmp = new WriteableBitmap(source);
            byte[] rawData = new byte[writeableBmp.PixelWidth * writeableBmp.PixelHeight];
            writeableBmp.CopyPixels(rawData, writeableBmp.PixelWidth, 0);

            Mat<byte> image = new Mat<byte>(writeableBmp.PixelHeight, writeableBmp.PixelWidth);
            for (int i = 0; i < writeableBmp.PixelHeight; i++)
                for (int j = 0; j < writeableBmp.PixelWidth; j++)
                    image[i, j] = rawData[i * writeableBmp.PixelWidth + j];

            return image;
        }
开发者ID:ArtanisCV,项目名称:TurboCV,代码行数:13,代码来源:Program.cs

示例4: Image_ImageOpened

    /// <summary>
    /// Obtains the image data once it is loaded
    /// </summary>
    protected void Image_ImageOpened(object sender, RoutedEventArgs e)
    {
      if (bitmap == null)
      {
        bitmap = new WriteableBitmap((BitmapImage)image.Source);
        image.Source = bitmap;
#if WPF
        int w = bitmap.PixelWidth;
        int h = bitmap.PixelHeight;
        pixelData = new int[w * h];
        int widthInBytes = 4 * w;
        bitmap.CopyPixels(pixelData, widthInBytes, 0);
#else
        pixelData = bitmap.Pixels;
#endif
      }
    }
开发者ID:benjaminrupp,项目名称:oxyplot,代码行数:20,代码来源:HistogramTestHarness.xaml.cs

示例5: TileSet

		public TileSet(System.Drawing.Bitmap source, int tileWidth, int tileHeight)
		{
			_source = new WriteableBitmap(Imaging.CreateBitmapSourceFromHBitmap(
				source.GetHbitmap(), IntPtr.Zero, Int32Rect.Empty,
				BitmapSizeOptions.FromWidthAndHeight(source.Width, source.Height)));

			TileWidth = tileWidth;
			TileHeight = tileHeight;
			_tilesPerRow = (int)_source.Width / TileWidth;

			_bytesPerPixel = _source.Format.BitsPerPixel / BITS_PER_BYTE;
			_stride = _source.PixelWidth * _bytesPerPixel;
			_originalPixels = new byte[_stride * _source.PixelHeight];
			_source.CopyPixels(_originalPixels, _stride, 0);

			_tiles = new List<CroppedBitmap>();
			GenerateTiles();
		}
开发者ID:treytomes,项目名称:wpf-console,代码行数:18,代码来源:TileSet.cs

示例6: execute

        public void execute()
        {
            if (Path != null)
                origin = LoadBitmap(Path);

            try
            {
                if (origin != null)
                {

                    origin = origin.Resize(68, 42, WriteableBitmapExtensions.Interpolation.NearestNeighbor);
                    origin.CopyPixels(new Int32Rect(0,0,origin.PixelWidth,origin.PixelHeight), monitor.BackBuffer,
                                    monitor.BackBufferStride * monitor.PixelHeight, monitor.BackBufferStride);
                }
            }
            catch (AccessViolationException e)
            {
                MessageBox.Show(e.Message);
            }
        }
开发者ID:BI-LedTable,项目名称:LedTable,代码行数:20,代码来源:ImagePixelate.cs

示例7: ColorBitmap

        /// <summary>
        /// Colors the connected objects in the bitmap. Note this function assumes the image is thresholded
        /// </summary>
        /// <param name="bitmap">The bitmap to color</param>
        /// <returns>A list of final colors in the image, one for each object</returns>
        public static List<Color> ColorBitmap( WriteableBitmap bitmap )
        {
            int stride = ( bitmap.PixelWidth * bitmap.Format.BitsPerPixel + 7 ) / 8;

             byte[] pixelArray = new byte[bitmap.PixelHeight * stride];
             bitmap.CopyPixels( pixelArray, stride, 0 );

             var colorMergeDictionary = new Dictionary<int, int>();
             var colors = new List<Color>();
             var random = new Random();
             for ( int i = 0; i < bitmap.PixelHeight; i++ )
             {
            for ( int j = 0; j < bitmap.PixelWidth; j++ )
            {
               int index = i * stride + 4 * j;

               // Check if it is a foreground object and has not been colored
               if ( GetPixelColor( pixelArray, index ) == Colors.Black )
               {
                  var color = GetPixelColoring( pixelArray, index, stride, colors, random, colorMergeDictionary );
                  pixelArray[index] = color.B;
                  pixelArray[index + 1] = color.G;
                  pixelArray[index + 2] = color.R;

                  // Keep track of all the colors in the image so
                  // we can merge them later
                  if ( !colors.Contains( color ) )
                  {
                     colors.Add( color );
                     colorMergeDictionary[colors.Count - 1] = colors.Count - 1;
                  }
               }
            }
             }

             var trueColors = MergeConnectedColors( pixelArray, colors, colorMergeDictionary );

             bitmap.WritePixels( new Int32Rect( 0, 0, bitmap.PixelWidth, bitmap.PixelHeight ), pixelArray, stride, 0 );

             return trueColors;
        }
开发者ID:dmarkachev,项目名称:CSE803Project,代码行数:46,代码来源:BitmapColorer.cs

示例8: Draw

        public unsafe override void Draw(WriteableBitmap desktop)
        {
            // Avoid exception if window is dragged bottom of screen
            if (rectangle.Top + rectangle.Height >= framebuffer.Height)
            {
                rectangle.Height = framebuffer.Height - rectangle.Top - 1;
            }

            if ((rectangle.Y * desktop.PixelWidth + rectangle.X) < (source.Y * desktop.PixelWidth + source.X))
            {
                Int32Rect srcRect = new Int32Rect(source.X, source.Y, rectangle.Width, rectangle.Height);
                desktop.WritePixels(srcRect, desktop.BackBuffer, desktop.BackBufferStride * desktop.PixelHeight, desktop.PixelWidth * 4, rectangle.X, rectangle.Y);
            }
            else
            {
                Int32[] pixelBuf = new Int32[rectangle.Width * rectangle.Height];

                desktop.CopyPixels(new Int32Rect(source.X, source.Y, rectangle.Width, rectangle.Height), pixelBuf, rectangle.Width * 4, 0);
                desktop.WritePixels(new Int32Rect(0, 0, rectangle.Width, rectangle.Height), pixelBuf, rectangle.Width * 4, rectangle.X, rectangle.Y);
            }
        }
开发者ID:nakano531,项目名称:VncSharpWpf,代码行数:21,代码来源:CopyRectRectangle.cs

示例9: ApplyBlobMaskToOtherBitmaps

        public static void ApplyBlobMaskToOtherBitmaps(WriteableBitmap bitmap, WriteableBitmap gradientBitmapRef, 
           WriteableBitmap realBitmapRef, System.Windows.Media.Color blobColor)
        {
            int stride = (bitmap.PixelWidth * bitmap.Format.BitsPerPixel + 7) / 8;

               byte[] pixelByteArray = new byte[bitmap.PixelHeight * stride];
               byte[] gradientByteArray = new byte[gradientBitmapRef.PixelHeight * stride];
               byte[] realByteArray = new byte[realBitmapRef.PixelHeight * stride];

               bitmap.CopyPixels(pixelByteArray, stride, 0);
               gradientBitmapRef.CopyPixels(gradientByteArray, stride, 0);
               realBitmapRef.CopyPixels(realByteArray, stride, 0);

               for (int column = 0; column < bitmap.PixelWidth; column++)
               {
               for (int row = 0; row < bitmap.PixelHeight; row++)
               {
                   int index = row * stride + 4 * column;

                   var pixelColor = new System.Windows.Media.Color();

                   pixelColor = System.Windows.Media.Color.FromRgb(pixelByteArray[index + 2],
                       pixelByteArray[index + 1], pixelByteArray[index]);

                   if (pixelColor != blobColor)
                   {
                       gradientByteArray[index] = 0;
                       gradientByteArray[index + 1] = 0;
                       gradientByteArray[index + 2] = 0;

                       realByteArray[index] = 0;
                       realByteArray[index + 1] = 0;
                       realByteArray[index + 2] = 0;
                   }
               }
               }

               gradientBitmapRef.WritePixels(new Int32Rect(0, 0, gradientBitmapRef.PixelWidth, gradientBitmapRef.PixelHeight), gradientByteArray, stride, 0);
               realBitmapRef.WritePixels(new Int32Rect(0, 0, realBitmapRef.PixelWidth, realBitmapRef.PixelHeight), realByteArray, stride, 0);
        }
开发者ID:dmarkachev,项目名称:CSE803Project,代码行数:40,代码来源:BitmapOperations.cs

示例10: Can_Create_Color_Image

        public void Can_Create_Color_Image()
        {
            var imageFactory = new RgbImageSourceFactory();

            var pointerFactory = new ArrayToPointerFactory();
            var data = new ushort[20 * 10 * 2];
            for (int index = data.Length / 2; index < data.Length; index++)
            {
                data[index] = ushort.MaxValue;
            }

            var bitmap = new WriteableBitmap(20, 10, 96, 96, PixelFormats.Bgr24, null);
            var pointer = pointerFactory.CreatePointer(data);
            try
            {
                 imageFactory.CreateImage(bitmap, pointer);
            }
            finally
            {
                pointerFactory.Destroy(pointer);
            }

            int height = bitmap.PixelHeight;
            int width = bitmap.PixelWidth;
            int stride = bitmap.PixelWidth * 3;
            byte[] pixelByteArray = new byte[bitmap.PixelHeight * stride];
            bitmap.CopyPixels(pixelByteArray, stride, 0);

            Assert.AreEqual(0, pixelByteArray[0]);
            Assert.AreEqual(0, pixelByteArray[1]);
            Assert.AreEqual(0, pixelByteArray[2]);

            Assert.AreEqual(255, pixelByteArray[10 * 3 + 9 * stride]);
            Assert.AreEqual(255, pixelByteArray[10 * 3 + 9 * stride + 1]);
            Assert.AreEqual(255, pixelByteArray[10 * 3 + 9 * stride + 2]);
        }
开发者ID:an83,项目名称:KinectTouch2,代码行数:36,代码来源:RGBImageSourceFactoryTests.cs

示例11: Create

        public Image Create(BitmapSource bitmapSource)
        {
            if (bitmapSource == null)
                return Image.Empty;
            try
            {
                var width = bitmapSource.PixelWidth;
                var height = bitmapSource.PixelHeight;
                var format = bitmapSource.Format;

                var bitmap = new WriteableBitmap(bitmapSource);
                var bytesPerPixel = (bitmap.Format.BitsPerPixel + 7)/8;
                var stride = 4*((bitmapSource.PixelWidth*bytesPerPixel + 3)/4);
                var length = stride*bitmapSource.PixelHeight;
                var pixels = new byte[length];
                bitmap.CopyPixels(pixels, stride, 0);

                return new Image(format.BitsPerPixel, width, height, pixels, format.ToString());
            }
            catch (Exception)
            {
                return Image.Empty;
            }
        }
开发者ID:rachwal,项目名称:RTM-Images,代码行数:24,代码来源:ImageFactory.cs

示例12: ColorizeBitmap

        public static BitmapSource ColorizeBitmap(BitmapSource bmp, Color tint)
        {
            var wbmp = new WriteableBitmap(bmp);
            var arr = new uint[wbmp.PixelWidth * wbmp.PixelHeight];

            wbmp.CopyPixels(arr, wbmp.PixelWidth * 4, 0);

            for (int i = 0; i < arr.Length; ++i)
            {
                byte a = (byte)((arr[i] >> 24) & 0xff);
                byte r = (byte)((arr[i] >> 16) & 0xff);
                byte g = (byte)((arr[i] >> 8) & 0xff);
                byte b = (byte)((arr[i] >> 0) & 0xff);

                var c = Color.FromArgb(a, r, g, b);
                c = TileSetHelpers.TintColor(c, tint);

                arr[i] = (uint)((c.A << 24) | (c.R << 16) | (c.G << 8) | (c.B << 0));
            }

            wbmp.WritePixels(new Int32Rect(0, 0, wbmp.PixelWidth, wbmp.PixelHeight), arr, wbmp.PixelWidth * 4, 0);

            return wbmp;
        }
开发者ID:Fulborg,项目名称:dwarrowdelf,代码行数:24,代码来源:TileSetHelpers.cs

示例13: ModifyImage

        // Sample --
        private void ModifyImage(string method)
        {
            WriteableBitmap modifiedImage;
            try
            {
                BitmapSource bitmapSource = new FormatConvertedBitmap(originalImage,
                    PixelFormats.Bgra32,
                    null, 0);
                modifiedImage = new WriteableBitmap(bitmapSource);
            }
            catch (ArgumentNullException)
            {
                return;
            }

            int height = modifiedImage.PixelHeight;
            int width = modifiedImage.PixelWidth;
            int[] pixelData = new int[width*height];
            int widthInByte = 4*width;

            modifiedImage.CopyPixels(pixelData, widthInByte, 0);

            // ----------- Extern call here --
            int[,] pixels;
            switch (method)
            {
                case "D":
                    double gmin = 0;
                    Double.TryParse(GMin.Text, out gmin);
                    double gmax = 255;
                    Double.TryParse(GMax.Text, out gmax);

                    imageProcessing.TresholdD(ref pixelData, (int)gmin, (int)gmax);
                    break;

                case "E":

                    double fmin = 0;
                    double fmax = 255;
                    Double.TryParse(FMin.Text, out fmin);
                    Double.TryParse(FMax.Text, out fmax);

                    imageProcessing.TresholdE(ref pixelData, (int)fmin, (int)fmax);
                    break;

                case "MIN":
                    pixels = ArrayConverter.To2D(pixelData, modifiedImage.PixelWidth, modifiedImage.PixelHeight);
                    pixels = imageProcessing.MinFilter(pixels);
                    pixelData = ArrayConverter.ToLinear(pixels);
                    break;

                case "MAX":
                    pixels = ArrayConverter.To2D(pixelData, modifiedImage.PixelWidth, modifiedImage.PixelHeight);
                    pixels = imageProcessing.MaxFilter(pixels);
                    pixelData = ArrayConverter.ToLinear(pixels);

                    break;

                case "MINMAX":
                    pixels = ArrayConverter.To2D(pixelData, modifiedImage.PixelWidth, modifiedImage.PixelHeight);
                    pixels = imageProcessing.MinMaxFilter(pixels);
                    pixelData = ArrayConverter.ToLinear(pixels);

                    break;

                case "BLUR":
                    pixels = ArrayConverter.To2D(pixelData, modifiedImage.PixelWidth, modifiedImage.PixelHeight);
                    pixels = imageProcessing.Blur(pixels);
                    pixelData = ArrayConverter.ToLinear(pixels);
                    break;

                default:
                    break;
            }
            // --------------------------------

            modifiedImage.WritePixels(new Int32Rect(0, 0, width, height), pixelData, widthInByte, 0);
            ModifiedImage.Source = modifiedImage;

            DrawHistogram(pixelData, "MODIFIED");
        }
开发者ID:romannort,项目名称:Dsp,代码行数:82,代码来源:MainWindow.xaml.cs

示例14: GenerateMask

        /// <summary>
        /// Méthode qui permet de générer la carte de chaleur ou de transparence de l'image
        /// </summary>
        /// <param name="mode">Mode sélectionné</param>
        /// <param name="img">Image sur laquelle on appose le masque</param>
        private void GenerateMask(string mode, ImageExp img)
        {
            ImageBmp = new WriteableBitmap(new BitmapImage(new Uri(img.Acces, UriKind.RelativeOrAbsolute)));
            imgBackground.Source = ImageBmp;

            // Taille de l'image d'origine
            //int width = imageBitmap.PixelWidth;
            //int height = imageBitmap.PixelHeight;
            int width = 1680;
            int height = 900;

            // Creation du masque a partir du bitmap d'origine
            WriteableBitmap bitmap = new WriteableBitmap(ImageBmp);

            // Pixels Destination (r,g,b,a)
            byte[, ,] pixels = new byte[height, width, 4];

            // Pixels Source
            int strideSource = ImageBmp.PixelWidth * 4;
            int sizeSource = ImageBmp.PixelHeight * strideSource;
            byte[] pixelSource = new byte[sizeSource];
            bitmap.CopyPixels(pixelSource, strideSource, 0);

            double max = Data[AppData.ImagesExp[img.Numero-1]].Cast<double>().Max();

            for (int row = 0; row < height; row++)
            {
                for (int col = 0; col < width; col++)
                {
                    // le numéro de l'image à indiquer est un en dessous
                    double tps = Data[AppData.ImagesExp[img.Numero-1]][row, col];

                        // Pixel d'origine
                        int indexSource = row * strideSource + 4 * col;

                        double coef = tps / max;

                        // 0 : bleu, 1 : vert, 2 : rouge
                        // Cas où on demande le gris
                        if (mode == "gris")
                        {
                            pixels[row, col, 0] = (byte)(pixelSource[indexSource] * coef);
                            pixels[row, col, 1] = (byte)(pixelSource[indexSource + 1] * coef);
                            pixels[row, col, 2] = (byte)((pixelSource[indexSource + 2]) * coef);
                        }
                            // Cas où l'utilisateur demande de la couleur
                        else
                        {
                            int x = (int)Math.Floor((1000 / max) * (max-tps));

                            if (x >= 0 && x < 255)
                            {
                                pixels[row, col, 2] = (byte)(pixelSource[indexSource+2]/2 + (255)/2);
                                pixels[row, col, 1] = (byte)(pixelSource[indexSource+1]/2 + (x)/2);
                                pixels[row, col, 0] = (byte)( pixelSource[indexSource]/2 + (0)/2);
                            }
                            if (x >= 255 && x < 510)
                            {
                                pixels[row, col, 2] = (byte)(pixelSource[indexSource + 2] / 2 + (510 - x) / 2);
                                pixels[row, col, 1] = (byte)(pixelSource[indexSource + 1] / 2 + (255) / 2);
                                pixels[row, col, 0] = (byte)(pixelSource[indexSource] / 2 + (0) / 2);

                            }
                            if (x >= 510 && x < 765)
                            {
                                pixels[row, col, 2] = (byte)(pixelSource[indexSource + 2] / 2 + (0) / 2);
                                pixels[row, col, 1] = (byte)(pixelSource[indexSource + 1] / 2 + (255) / 2);
                                pixels[row, col, 0] = (byte)(pixelSource[indexSource] / 2 + (x-510) / 2);
                            }
                            if (x >= 765 && x < 1020)
                            {
                                pixels[row, col, 2] = (byte)(pixelSource[indexSource + 2] / 2 + (0) / 2);
                                pixels[row, col, 1] = (byte)(pixelSource[indexSource + 1] / 2 + (1020-x) / 2);
                                pixels[row, col, 0] = (byte)(pixelSource[indexSource] / 2 + (255) / 2);
                            }
                            if (x >= 1020 && x < 1275)
                            {
                                pixels[row, col, 2] = (byte)(pixelSource[indexSource + 2] / 2 + (x-1020) / 2);
                                pixels[row, col, 1] = (byte)(pixelSource[indexSource + 1] / 2 + (0) / 2);
                                pixels[row, col, 0] = (byte)(pixelSource[indexSource] / 2 + (255) / 2);
                            }
                            if (x >= 1275 && x <= 1530)
                            {
                                pixels[row, col, 2] = (byte)(pixelSource[indexSource + 2] / 2 + (255) / 2);
                                pixels[row, col, 1] = (byte)(pixelSource[indexSource + 1] / 2 + (0) / 2);
                                pixels[row, col, 0] = (byte)(pixelSource[indexSource] / 2 + (1530-x) / 2);
                            }

                    }

                    // Alpha
                    pixels[row, col, 3] = 255;
                }
            }

//.........这里部分代码省略.........
开发者ID:Cara64,项目名称:pfeshabidi,代码行数:101,代码来源:CompDensiteRecouvrementUC.xaml.cs

示例15: PixelColorOfCentralBlob

        public static System.Windows.Media.Color PixelColorOfCentralBlob(WriteableBitmap bitmap)
        {
            int stride = (bitmap.PixelWidth * bitmap.Format.BitsPerPixel + 7) / 8;

              ConcurrentDictionary<System.Windows.Media.Color, int > colorDict =
              new ConcurrentDictionary<System.Windows.Media.Color, int>();

              byte[] pixelByteArray = new byte[bitmap.PixelHeight * stride];
              bitmap.CopyPixels(pixelByteArray, stride, 0);

              //Draw a Horizontal Line accross the middle
              for (int column = 0; column < bitmap.PixelWidth; column++)
              {
                  var color = new System.Windows.Media.Color();

                  int row = (int)(bitmap.PixelHeight/2.0);
                  int index = row * stride + 4 * column;

                  int R = Convert.ToInt32(pixelByteArray[index+2]);
                  int G = Convert.ToInt32(pixelByteArray[index+1]);
                  int B = Convert.ToInt32(pixelByteArray[index]);

                  color = System.Windows.Media.Color.FromRgb(pixelByteArray[index + 2],
                      pixelByteArray[index + 1], pixelByteArray[index]);

              if (!(R == 255 && B == 255 && G == 255) && !(R== 0 && B == 0 && G == 0))
              {
                  colorDict.AddOrUpdate(color, 1, (id, count) => count + 1);
              }
              }

              int maxValue = 0;
              var colorKey  = new System.Windows.Media.Color();
              foreach (var item in colorDict)
              {
              if (item.Value > maxValue)
              {
                  colorKey = item.Key;
                  maxValue = item.Value;
              }
              }
              return colorKey;
        }
开发者ID:dmarkachev,项目名称:CSE803Project,代码行数:43,代码来源:BitmapOperations.cs


注:本文中的System.Windows.Media.Imaging.WriteableBitmap.CopyPixels方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。