public void ThumbSelectionRemovesCorrectOnes2()
        {
            var thumbs   = FillWith(7);
            var filtered = ThumbUtil.CheckMaxThumbCount(thumbs, 4);

            Assert.AreSame(thumbs[0], filtered[0]);
            Assert.AreSame(thumbs[2], filtered[1]);
            Assert.AreSame(thumbs[4], filtered[2]);
            Assert.AreSame(thumbs[6], filtered[3]);
            Assert.AreEqual(4, filtered.Count);
        }
 public void ZeroThumbnailsIfZeroAvailable()
 {
     Assert.AreEqual(0, ThumbUtil.CheckMaxThumbCount(new List <IResultNode>(), 10).Count);
 }
 public void ZeroThumbnailsIfZeroWanted()
 {
     Assert.AreEqual(0, ThumbUtil.CheckMaxThumbCount(new List <IResultNode>(new [] { MockRepository.GenerateStub <IResultNode>() }), 0).Count);
 }
示例#4
0
        private void bwImport_DoWork(object sender, DoWorkEventArgs e)
        {
            bwImport.ReportProgress(0, "");
            while (true)
            {
                String fptry = null;
                lock (importFiles) {
                    if (importFiles.Count == 0)
                    {
                        break;
                    }
                    fptry = importFiles[0];
                    importFiles.RemoveAt(0);
                }

                String fpTIF = null;
                bool   isPDF = false;
                if (FIUt.IsPDF(fptry))
                {
                    fpTIF = tempFiles.NewFile(".tif");
                    bwImport.ReportProgress(0, "PDF 画像変換");
                    if (!PDFUt.PDF2TIF(fptry, fpTIF, null, sizeThumb.Width, null))
                    {
                        continue;
                    }
                    isPDF = true;
                }
                else
                {
                    fpTIF = fptry;
                }

                if (fpTIF != null)
                {
#if true
                    FIMULTIBITMAP      tif       = FreeImage.OpenMultiBitmapEx(fpTIF, true, false);
                    List <PicProvider> providers = new List <PicProvider>();
                    try {
                        int nPages = FreeImage.GetPageCount(tif);
                        for (int x = 0; x < nPages; x++)
                        {
                            FIBITMAP dib = FreeImage.LockPage(tif, x);
                            try {
                                FIBITMAP thumb = FreeImage.MakeThumbnail(dib, sizeThumb.Width, true);
                                try {
                                    bwImport.ReportProgress(0, String.Format("{0}/{1} from {2}", 1 + x, nPages, fptry));
                                    providers.Add(new PicProvider(FreeImage.GetBitmap(thumb), fpTIF, isPDF ? fptry : null, x, FreeImage.GetBPP(dib) == 1));
                                }
                                finally {
                                    FreeImage.UnloadEx(ref thumb);
                                }
                            }
                            finally {
                                FreeImage.UnlockPage(tif, dib, false);
                            }
                        }
                    }
                    finally {
                        FreeImage.CloseMultiBitmapEx(ref tif);
                    }

                    foreach (PicProvider pp in providers)
                    {
                        AddPage(pp);
                    }
#else
                    using (Bitmap pic = new Bitmap(fpTIF)) {
                        int nPages = pic.GetFrameCount(FrameDimension.Page);
                        for (int x = 0; x < nPages; x++)
                        {
                            pic.SelectActiveFrame(FrameDimension.Page, x);
                            AddPage(new PicProvider(ThumbUtil.Make(pic, sizeThumb), fpTIF, isPDF ? fptry : null, x, pic.PixelFormat == PixelFormat.Format1bppIndexed));
                        }
                    }
#endif
                }
            }
        }