OSDN Git Service

softsubtitles:
[handbrake-jp/handbrake-jp-git.git] / macosx / PictureController.mm
index 132d3b1..1a5e0cb 100644 (file)
 /* $Id: PictureController.mm,v 1.11 2005/08/01 15:10:44 titer Exp $
 
    This file is part of the HandBrake source code.
-   Homepage: <http://handbrake.m0k.org/>.
+   Homepage: <http://handbrake.fr/>.
    It may be used under the terms of the GNU General Public License. */
 
-#include "PictureController.h"
+#import "PictureController.h"
+#import "Controller.h"
+#import "HBPreviewController.h"
 
-@interface PictureController (Private)
 
-- (NSSize)optimalViewSizeForImageSize: (NSSize)imageSize;
-- (void)resizeSheetForViewSize: (NSSize)viewSize;
-- (void)setViewSize: (NSSize)viewSize;
-- (BOOL)viewNeedsToResizeToSize: (NSSize)newSize;
 
-@end
+@implementation PictureController
+
+- (id)init
+{
+       if (self = [super initWithWindowNibName:@"PictureSettings"])
+       {
+        // NSWindowController likes to lazily load its window. However since
+        // this controller tries to set all sorts of outlets before the window
+        // is displayed, we need it to load immediately. The correct way to do
+        // this, according to the documentation, is simply to invoke the window
+        // getter once.
+        //
+        // If/when we switch a lot of this stuff to bindings, this can probably
+        // go away.
+        [self window];
+        
+       fPreviewController = [[PreviewController alloc] init];
+    }
+       return self;
+}
 
-static int GetAlignedSize( int size )
+//------------------------------------------------------------------------------------
+// Displays and brings the picture window to the front
+//------------------------------------------------------------------------------------
+- (IBAction) showPictureWindow: (id)sender
 {
-    int result = 1;
-    while( result < size )
+    if ([fPreviewController fullScreen] == YES)
     {
-        result *= 2;
+        [self showWindow:sender];
+        [[NSUserDefaults standardUserDefaults] setBool:YES forKey:@"PictureSizeWindowIsOpen"];
+        [self setToFullScreenMode];
     }
-    return result;
+    else
+    {
+        if ([[self window] isVisible])
+        {
+            [[self window] close];
+        }
+        else
+        {
+            [self showWindow:sender];
+            [[NSUserDefaults standardUserDefaults] setBool:YES forKey:@"PictureSizeWindowIsOpen"];
+            [self setToWindowedMode];
+        }
+    }
+    [self adjustFilterDisplay:nil];
+    [self adjustSizingDisplay:nil];
 }
 
-@implementation PictureController
+- (BOOL) previewFullScreenMode
+{
+    return [fPreviewController fullScreen];
+}
 
-- (id)initWithDelegate:(id)del
+/* this method is used to detect clicking on a tab in fSizeFilterView */
+- (void)tabView:(NSTabView *)tabView didSelectTabViewItem:(NSTabViewItem *)tabViewItem
 {
-       if (self = [super init])
-       {
-               delegate = del;
-        [self loadMyNibFile];
-       }
-       return self;
+
+[self resizeInspectorForTab:nil];
+
+}
+
+#pragma mark -
+
+/* resizeInspectorForTab is called at launch, and each time either the 
+ * Size or Filters tab is clicked. Size gives a horizontally oriented
+ * inspector and Filters is a vertically aligned inspector.
+ */
+- (IBAction) resizeInspectorForTab: (id)sender
+{
+    NSRect frame = [[self window] frame];
+    NSPoint windowOrigin = [[self window] frame].origin;
+    NSSize screenSize = [[[self window] screen] frame].size;
+    NSPoint screenOrigin = [[[self window] screen] frame].origin;
+    
+    /* We base our inspector size/layout on which tab is active for fSizeFilterView */
+    /* we are 1 which is Filters*/
+    if ([fSizeFilterView indexOfTabViewItem: [fSizeFilterView selectedTabViewItem]] == 1)
+    {
+        frame.size.width = 314;
+        /* we glean the height from the size of the boxes plus the extra window space
+         * needed for non boxed display
+         */
+        frame.size.height = 110.0 + [fDetelecineBox frame].size.height + [fDecombDeinterlaceBox frame].size.height + [fDenoiseBox frame].size.height + [fDeblockBox frame].size.height;
+        /* Hide the size readout at the bottom as the vertical inspector is not wide enough */
+        [fSizeInfoField setHidden:YES];
+    }
+    else // we are Tab index 0 which is size
+    {
+        frame.size.width = 50.0 + [fPictureSizeBox frame].size.width + [fPictureCropBox frame].size.width;
+        frame.size.height = [fPictureSizeBox frame].size.height + 85;
+        /* hide the size summary field at the bottom */
+        [fSizeInfoField setHidden:NO];      
+    }
+    /* get delta's for the change in window size */
+    CGFloat deltaX = frame.size.width - [[self window] frame].size.width;
+    CGFloat deltaY = frame.size.height - [[self window] frame].size.height;
+    
+    /* Check to see if we have changed the height from current */
+    //if (frame.size.height != [[self window] frame].size.height)
+    //{
+        /* change the inspector origin via the deltaY */
+        frame.origin.y -= deltaY;
+        /* keep the inspector centered so the tabs stay in place */
+        frame.origin.x -= deltaX / 2.0;
+    //}
+    
+     /* we make sure we are not horizontally off of our screen.
+     * this would be the case if we are on the vertical filter tab
+     * and we hit the size tab and the inspector grows horizontally
+     * off the screen to the right
+    */
+    if ((frame.origin.x + frame.size.width) > (screenOrigin.x + screenSize.width))
+    {
+        /* the right side of the preview is off the screen, so shift to the left */
+        frame.origin.x = (screenOrigin.x + screenSize.width) - frame.size.width;
+    }
+    
+    [[self window] setFrame:frame display:YES animate:YES];
+}
+
+- (IBAction) adjustSizingDisplay: (id) sender
+{
+    NSSize pictureSizingBoxSize = [fPictureSizeBox frame].size;
+    
+    NSPoint fPictureSizeBoxOrigin = [fPictureSizeBox frame].origin;
+    NSSize pictureCropBoxSize = [fPictureCropBox frame].size;
+    NSPoint fPictureCropBoxOrigin = [fPictureCropBox frame].origin;
+    
+    if ([fAnamorphicPopUp indexOfSelectedItem] == 3) // custom / power user jamboree
+    {
+        pictureSizingBoxSize.width = 530;
+        
+        /* Set visibility of capuj widgets */
+        [fParWidthField setHidden: NO];
+        [fParHeightField setHidden: NO];
+        [fParWidthLabel setHidden: NO];
+        [fParHeightLabel setHidden: NO];
+        [fDisplayWidthField setHidden: NO];
+        [fDisplayWidthLabel setHidden: NO];
+        [fModulusLabel setHidden: NO];
+        [fModulusPopUp setHidden: NO];
+        /* adjust/move keep ar checkbox */
+        [fRatioLabel setHidden: YES];
+        [fRatioLabel2 setHidden: NO];
+        
+        /* Optionally swith the Storage and Display width positions*/
+         /*
+         NSPoint fWidthLabelOrigin = [fWidthLabel frame].origin;
+         NSPoint fWidthFieldOrigin = [fWidthField frame].origin;
+         NSPoint fWidthStepperOrigin = [fWidthStepper frame].origin;
+         fWidthFieldOrigin.x = [fRatioLabel2 frame].origin.x + [fRatioLabel2 frame].size.width + 4;
+         [fWidthField setFrameOrigin:fWidthFieldOrigin];
+
+         fWidthStepperOrigin.x = [fWidthField frame].origin.x + [fWidthField frame].size.width + 4;
+         [fWidthStepper setFrameOrigin:fWidthStepperOrigin];
+         
+         fWidthLabelOrigin.x = [fWidthField frame].origin.x - [fWidthLabel frame].size.width - 4;
+         [fWidthLabel setFrameOrigin:fWidthLabelOrigin];
+         [fWidthLabel setStringValue:@"Storage Width:"];
+         */
+        
+        /* set the origin for fRatioCheck so origin.y == fRatioLabel2
+         * and origin.x == fDisplayWidthField
+         */
+         NSPoint fRatioCheckOrigin = [fRatioCheck frame].origin;
+         fRatioCheckOrigin.y = [fRatioLabel2 frame].origin.y - 2;
+         fRatioCheckOrigin.x = [fRatioLabel2 frame].origin.x + [fRatioLabel2 frame].size.width + 4;
+         [fRatioCheck setFrameOrigin:fRatioCheckOrigin];
+         
+    }
+    else
+    {
+        pictureSizingBoxSize.width = 200;
+        
+        /* Set visibility of capuj widgets */
+        [fParWidthField setHidden: YES];
+        [fParHeightField setHidden: YES];
+        [fParWidthLabel setHidden: YES];
+        [fParHeightLabel setHidden: YES];
+        [fDisplayWidthField setHidden: YES];
+        [fDisplayWidthLabel setHidden: YES];
+        [fModulusLabel setHidden: YES];
+        [fModulusPopUp setHidden: YES];
+        /* adjust/move keep ar checkbox */
+        [fRatioLabel setHidden: NO];
+        [fRatioLabel2 setHidden: YES];
+        
+         /* Optionally swith the Storage and Display width positions*/
+         
+         /*
+         NSPoint fWidthLabelOrigin = [fWidthLabel frame].origin;
+         NSPoint fWidthFieldOrigin = [fWidthField frame].origin;
+         NSPoint fWidthStepperOrigin = [fWidthStepper frame].origin;
+         
+         fWidthFieldOrigin.x = [fHeightField frame].origin.x;
+         [fWidthField setFrameOrigin:fWidthFieldOrigin];
+         
+         fWidthStepperOrigin.x = [fHeightStepper frame].origin.x;
+         [fWidthStepper setFrameOrigin:fWidthStepperOrigin];
+         
+         fWidthLabelOrigin.x = [fWidthField frame].origin.x - [fWidthLabel frame].size.width -4;
+         [fWidthLabel setFrameOrigin:fWidthLabelOrigin];
+         [fWidthLabel setStringValue:@"Width:"];
+         */
+        
+        
+        /* set the origin for fRatioCheck so origin.y == fRatioLabel
+         * and origin.x == fWidthStepper
+         */
+         NSPoint fRatioCheckOrigin = [fRatioCheck frame].origin;
+         fRatioCheckOrigin.y = [fRatioLabel frame].origin.y - 2;
+         fRatioCheckOrigin.x = [fWidthStepper frame].origin.x - 2;
+         [fRatioCheck setFrameOrigin:fRatioCheckOrigin];
+        
+    }
+    
+    /* Check to see if we have changed the size from current */
+    if (pictureSizingBoxSize.height != [fPictureSizeBox frame].size.height || pictureSizingBoxSize.width != [fPictureSizeBox frame].size.width)
+    {
+        /* Get our delta for the change in picture size box height */
+        CGFloat deltaYSizeBoxShift = pictureSizingBoxSize.height - [fPictureSizeBox frame].size.height;
+        fPictureSizeBoxOrigin.y -= deltaYSizeBoxShift;
+        /* Get our delta for the change in picture size box width */
+        CGFloat deltaXSizeBoxShift = pictureSizingBoxSize.width - [fPictureSizeBox frame].size.width;
+        //fPictureSizeBoxOrigin.x += deltaXSizeBoxShift;
+        /* set our new Picture size box size */
+        [fPictureSizeBox setFrameSize:pictureSizingBoxSize];
+        [fPictureSizeBox setFrameOrigin:fPictureSizeBoxOrigin];
+        
+        pictureCropBoxSize.height += deltaYSizeBoxShift;
+        fPictureCropBoxOrigin.y -= deltaYSizeBoxShift;
+        fPictureCropBoxOrigin.x += deltaXSizeBoxShift;
+        
+        [fPictureCropBox setFrameSize:pictureCropBoxSize];
+        [[fPictureCropBox animator] setFrameOrigin:fPictureCropBoxOrigin];
+    }
+
+    
+    /* now we call to resize the entire inspector window */
+   [self resizeInspectorForTab:nil];
+}
+
+- (IBAction) adjustFilterDisplay: (id) sender
+{
+    
+    NSBox * filterBox = nil;
+    NSTextField * filterField;
+    if (sender == fDetelecinePopUp)
+    {
+        filterBox = fDetelecineBox;
+        filterField = fDetelecineField;
+    }
+    
+    if (sender == fDecombDeinterlaceSlider)
+    {
+        if ([fDecombDeinterlaceSlider floatValue] == 0.0)
+        {
+            filterBox = fDecombBox;
+            filterField = fDecombField;
+        }
+        else
+        {
+            filterBox = fDeinterlaceBox;
+            filterField = fDeinterlaceField;
+        }
+    }
+    
+    if (sender == fDecombPopUp)
+    {
+        filterBox = fDecombBox;
+        filterField = fDecombField;
+    }
+    if (sender == fDeinterlacePopUp)
+    {
+        filterBox = fDeinterlaceBox;
+        filterField = fDeinterlaceField;
+    }
+    
+    if (sender == fDenoisePopUp)
+    {
+        filterBox = fDenoiseBox;
+        filterField = fDenoiseField;
+    }
+    
+    NSSize currentSize = [filterBox frame].size;
+    NSRect boxFrame = [filterBox frame];
+    
+    if ([sender titleOfSelectedItem] == @"Custom")
+    {
+        
+        currentSize.height = 60;
+        
+    }
+    else
+    {
+        currentSize.height = 30;
+        
+    }
+    /* Check to see if we have changed the size from current */
+    if (currentSize.height != [filterBox frame].size.height)
+    {
+        /* We are changing the size of the box, so recalc the origin */
+        NSPoint boxOrigin = [filterBox frame].origin;
+        /* We get the deltaY here for how much we are expanding/contracting the box vertically */
+        CGFloat deltaYBoxShift = currentSize.height - [filterBox frame].size.height;
+        boxOrigin.y -= deltaYBoxShift;
+        
+        boxFrame.size.height = currentSize.height;
+        boxFrame.origin.y = boxOrigin.y;
+        [filterBox setFrame:boxFrame];
+        
+        /* go ahead and resize the box */
+        //[[filterBox animator] setFrameSize:currentSize];
+        //[[filterBox animator] setFrameOrigin:origin];
+    
+        if (filterBox == fDecombBox || filterBox == fDeinterlaceBox)
+        {
+            /* fDecombDeinterlaceBox*/
+            NSSize decombDeinterlaceBoxSize = [fDecombDeinterlaceBox frame].size;
+            NSPoint decombDeinterlaceBoxOrigin = [fDecombDeinterlaceBox frame].origin;
+            
+            //decombDeinterlaceBoxSize.height = [filterBox frame].size.height + 50;
+            if (sender == fDecombDeinterlaceSlider)
+            {
+                [fHBController writeToActivityLog: "Sender is deinterlace decomb slider"];
+            }
+            
+            if ([fDeinterlaceBox isHidden] == YES)
+            {
+                decombDeinterlaceBoxSize.height = [fDecombBox frame].size.height + 50;
+                [fHBController writeToActivityLog: "Resize by Decomb box"];
+            }
+            else
+            {
+                decombDeinterlaceBoxSize.height = [fDeinterlaceBox frame].size.height + 50;
+                [fHBController writeToActivityLog: "Resize by Deinterlace box"];
+            }
+            /* get delta's for the change in window size */
+            
+            CGFloat deltaYdecombDeinterlace = decombDeinterlaceBoxSize.height - [fDecombDeinterlaceBox frame].size.height;
+            
+            deltaYBoxShift = deltaYdecombDeinterlace;
+            
+            decombDeinterlaceBoxOrigin.y -= deltaYdecombDeinterlace;
+            
+            [fDecombDeinterlaceBox setFrameSize:decombDeinterlaceBoxSize];
+            [fDecombDeinterlaceBox setFrameOrigin:decombDeinterlaceBoxOrigin];
+        }
+
+        /* now we must reset the origin of each box below the adjusted box*/
+        NSPoint decombDeintOrigin = [fDecombDeinterlaceBox frame].origin;
+        NSPoint denoiseOrigin = [fDenoiseBox frame].origin;
+        NSPoint deblockOrigin = [fDeblockBox frame].origin;
+        if (sender == fDetelecinePopUp)
+        {
+            decombDeintOrigin.y -= deltaYBoxShift;
+            [fDecombDeinterlaceBox setFrameOrigin:decombDeintOrigin];
+            
+            denoiseOrigin.y -= deltaYBoxShift;
+            [fDenoiseBox setFrameOrigin:denoiseOrigin];
+            
+            deblockOrigin.y -= deltaYBoxShift;
+            [fDeblockBox setFrameOrigin:deblockOrigin];
+        }
+        if (sender == fDecombPopUp || sender == fDeinterlacePopUp)
+        {
+            denoiseOrigin.y -= deltaYBoxShift;
+            [fDenoiseBox setFrameOrigin:denoiseOrigin];
+            
+            deblockOrigin.y -= deltaYBoxShift;
+            [fDeblockBox setFrameOrigin:deblockOrigin];
+        }
+        
+        if (sender == fDenoisePopUp)
+        {
+            deblockOrigin.y -= deltaYBoxShift;
+            [fDeblockBox setFrameOrigin:deblockOrigin];
+        }
+        
+        /* now we call to resize the entire inspector window */
+        [self resizeInspectorForTab:nil];
+    }
+    
+}
+
+
+#pragma mark -
+
+- (IBAction) previewGoWindowed: (id)sender
+{
+    [fPreviewController goWindowedScreen:self];
+}
+
+- (IBAction) showPreviewWindow: (id)sender
+{
+    [[NSUserDefaults standardUserDefaults] setBool:YES forKey:@"PreviewWindowIsOpen"];
+    [fPreviewController showWindow:sender];
+}
+
+
+
+
+- (void) setToFullScreenMode
+{
+    int32_t shieldLevel = CGShieldingWindowLevel(); 
+    
+    [fPictureWindow setLevel:shieldLevel + 1]; 
+    // Show the window. 
+    [fPictureWindow makeKeyAndOrderFront:self];
+}
+
+- (void) setToWindowedMode
+{
+    /* Set the window back to Floating Window mode 
+     * This will put the window always on top, but
+     * since we have Hide on Deactivate set in our
+     * xib, if other apps are put in focus we will
+     * hide properly to stay out of the way
+     */
+    [[self window] setLevel:NSFloatingWindowLevel];
+}
+
+- (void)setHBController: (HBController *)controller
+{
+    fHBController = controller;
+    [fPreviewController   setHBController: controller];
+    
+}
+
+- (void)awakeFromNib
+{
+    [fPictureWindow setDelegate:self];
+    if( ![[self window] setFrameUsingName:@"PictureSizing"] )
+        [[self window] center];
+    [self setWindowFrameAutosaveName:@"PictureSizing"];
+    [[self window] setExcludedFromWindowsMenu:YES];
+    
+    [self setInitialPictureFilters];
+    
+    /* Setup our layers for core animation */
+    [fSizeFilterView setWantsLayer:YES];
+    [fPictureSizeBox setWantsLayer:YES];
+    [fPictureCropBox setWantsLayer:YES];
+    
+}
+
+
+- (void)windowWillClose:(NSNotification *)aNotification
+{
+[[NSUserDefaults standardUserDefaults] setBool:NO forKey:@"PictureSizeWindowIsOpen"];
+}
+
+- (BOOL)windowShouldClose:(id)fPictureWindow
+{
+    return YES;
+}
+
+- (void) dealloc
+{
+    [fPreviewController release];
+    [super dealloc];
 }
 
 - (void) SetHandle: (hb_handle_t *) handle
 {
     fHandle = handle;
+    
+    [fPreviewController SetHandle: fHandle];
+}
 
-    fHasQE = CGDisplayUsesOpenGLAcceleration( kCGDirectMainDisplay );
+- (void) SetTitle: (hb_title_t *) title
+{
+    hb_job_t * job = title->job;
 
-    fBuffer     = NULL;
-    fBufferSize = 0;
-    fTexBuf[0]  = NULL;
-    fTexBuf[1]  = NULL;
-    fTexBufSize = 0;
+    fTitle = title;
 
     [fWidthStepper  setValueWraps: NO];
     [fWidthStepper  setIncrement: 16];
@@ -55,7 +494,7 @@ static int GetAlignedSize( int size )
     [fHeightStepper setValueWraps: NO];
     [fHeightStepper setIncrement: 16];
     [fHeightStepper setMinValue: 64];
-
+    
     [fCropTopStepper    setIncrement: 2];
     [fCropTopStepper    setMinValue:  0];
     [fCropBottomStepper setIncrement: 2];
@@ -64,35 +503,7 @@ static int GetAlignedSize( int size )
     [fCropLeftStepper   setMinValue:  0];
     [fCropRightStepper  setIncrement: 2];
     [fCropRightStepper  setMinValue:  0];
-}
-
-- (void) SetTitle: (hb_title_t *) title
-{
-    hb_job_t * job = title->job;
-
-    fTitle = title;
-
-    /* Make sure we have big enough buffers */
-    int newSize;
-    newSize = ( title->width + 2 ) * (title->height + 2 ) * 4;
-    if( fBufferSize < newSize )
-    {
-        fBufferSize = newSize;
-        fBuffer     = (uint8_t *) realloc( fBuffer, fBufferSize );
-    }
-    if( !fHasQE )
-    {
-        newSize = ( GetAlignedSize( title->width + 2 ) *
-            GetAlignedSize( title->height + 2 ) * 4 );
-    }
-    if( fTexBufSize < newSize )
-    {
-        fTexBufSize = newSize;
-        fTexBuf[0]  = (uint8_t *) realloc( fTexBuf[0], fTexBufSize );
-        fTexBuf[1]  = (uint8_t *) realloc( fTexBuf[1], fTexBufSize );
-    }
-
-
+    
     [fWidthStepper      setMaxValue: title->width];
     [fWidthStepper      setIntValue: job->width];
     [fWidthField        setIntValue: job->width];
@@ -113,7 +524,25 @@ static int GetAlignedSize( int size )
     {
     [fAnamorphicPopUp addItemWithTitle: @"Loose"];
     }
-    [fAnamorphicPopUp selectItemAtIndex: job->pixel_ratio];
+    [fAnamorphicPopUp addItemWithTitle: @"Custom"];
+    [fAnamorphicPopUp selectItemAtIndex: job->anamorphic.mode];
+    
+    //[self adjustSizingDisplay:nil];
+    
+    /* populate the modulus popup here */
+    [fModulusPopUp removeAllItems];
+    [fModulusPopUp addItemWithTitle: @"16"];
+    [fModulusPopUp addItemWithTitle: @"8"];
+    [fModulusPopUp addItemWithTitle: @"4"];
+    [fModulusPopUp addItemWithTitle: @"2"];
+    if (job->anamorphic.mode == 3)
+    {
+        [fModulusPopUp selectItemWithTitle: [NSString stringWithFormat:@"%d",job->anamorphic.modulus]];
+    }
+    else
+    {
+        [fModulusPopUp selectItemWithTitle: @"16"];
+    }
     
     /* We initially set the previous state of keep ar to on */
     keepAspectRatioPreviousState = 1;
@@ -135,156 +564,181 @@ static int GetAlignedSize( int size )
         [fCropMatrix  selectCellAtRow: 0 column:0];
        }
        
-       /* Set filters widgets according to the filters struct */
-       [fVFRCheck setState:fPictureFilterSettings.vfr];
-    [fDetelecineCheck setState:fPictureFilterSettings.detelecine];
+    /* Set filters widgets according to the filters struct */
+    [fDetelecinePopUp selectItemAtIndex:fPictureFilterSettings.detelecine];
+    [fDecombPopUp selectItemAtIndex:fPictureFilterSettings.decomb];
     [fDeinterlacePopUp selectItemAtIndex: fPictureFilterSettings.deinterlace];
     [fDenoisePopUp selectItemAtIndex: fPictureFilterSettings.denoise];
-    [fDeblockCheck setState: fPictureFilterSettings.deblock];
+    [fDeblockSlider setFloatValue:fPictureFilterSettings.deblock];
+    [fGrayscaleCheck setState:fPictureFilterSettings.grayscale];
+    
+    [self deblockSliderChanged: nil];
     
     fPicture = 0;
     MaxOutputWidth = title->width - job->crop[2] - job->crop[3];
     MaxOutputHeight = title->height - job->crop[0] - job->crop[1];
+    
+    titleDarWidth = job->anamorphic.dar_width;
+    titleDarHeight = job->anamorphic.dar_height;
+    
+    titleParWidth = job->anamorphic.par_width;
+    titleParHeight = job->anamorphic.par_height;
+    
     [self SettingsChanged: nil];
 }
 
-/* we use this to setup the initial picture filters upon first launch, after that their states
-are maintained across different sources */
-- (void) setInitialPictureFilters
+- (IBAction) storageLinkChanged: (id) sender
 {
-       /* we use a popup to show the deinterlace settings */
-       [fDeinterlacePopUp removeAllItems];
-    [fDeinterlacePopUp addItemWithTitle: @"None"];
-    [fDeinterlacePopUp addItemWithTitle: @"Fast"];
-    [fDeinterlacePopUp addItemWithTitle: @"Slow"];
-       [fDeinterlacePopUp addItemWithTitle: @"Slower"];
-       [fDeinterlacePopUp addItemWithTitle: @"Slowest"];
-    
-       /* Set deinterlaces level according to the integer in the main window */
-       [fDeinterlacePopUp selectItemAtIndex: fPictureFilterSettings.deinterlace];
-
-       /* we use a popup to show the denoise settings */
-       [fDenoisePopUp removeAllItems];
-    [fDenoisePopUp addItemWithTitle: @"None"];
-    [fDenoisePopUp addItemWithTitle: @"Weak"];
-       [fDenoisePopUp addItemWithTitle: @"Medium"];
-    [fDenoisePopUp addItemWithTitle: @"Strong"];
-       /* Set denoises level according to the integer in the main window */
-       [fDenoisePopUp selectItemAtIndex: fPictureFilterSettings.denoise];
+    /* since we have a tickless slider, make sure we are at 0.0 or 1.0 */
+    if ([fStorageLinkSlider floatValue] < 0.50)
+    {
+        [fStorageLinkSlider setFloatValue:0.0];
+        /* set slider labels to reflect choice */
+        [fStorageLinkParLabel setEnabled:YES];
+        [fStorageLinkDisplayLabel setEnabled:NO];
 
+    }
+    else
+    {
+        [fStorageLinkSlider setFloatValue:1.0];
+        /* set slider labels to reflect choice */
+        [fStorageLinkParLabel setEnabled:NO];
+        [fStorageLinkDisplayLabel setEnabled:YES];
+    }
+    
 }
-- (void) Display: (int) anim
+
+- (IBAction) parLinkChanged: (id) sender
 {
-    hb_get_preview( fHandle, fTitle, fPicture, fBuffer );
-    
-    /* Backup previous picture (for effects) */
-    memcpy( fTexBuf[1], fTexBuf[0], fTexBufSize );
-    
-    if( fHasQE )
+    /* since we have a tickless slider, make sure we are at 0.0 or 1.0 */
+    if ([fParLinkSlider floatValue] < 0.50)
     {
-        /* Simply copy */
-        memcpy( fTexBuf[0], fBuffer, fTexBufSize );
+        [fParLinkSlider setFloatValue:0.0];
+        /* set slider labels to reflect choice */
+        [fParLinkStorageLabel setEnabled:YES];
+        [fParLinkDisplayLabel setEnabled:NO];
     }
     else
     {
-        /* Copy line by line */
-        uint8_t * in  = fBuffer;
-        uint8_t * out = fTexBuf[0];
-               
-        for( int i = fTitle->height + 2; i--; )
-        {
-            memcpy( out, in, 4 * ( fTitle->width + 2 ) );
-            in  += 4 * ( fTitle->width + 2 );
-            out += 4 * GetAlignedSize( fTitle->width + 2 );
-        }
-        
+        [fParLinkSlider setFloatValue:1.0];
+        /* set slider labels to reflect choice */
+        [fParLinkStorageLabel setEnabled:NO];
+        [fParLinkDisplayLabel setEnabled:YES];
     }
     
-    if( [fEffectsCheck state] == NSOffState )
+}
+
+- (IBAction) displayLinkChanged: (id) sender
+{
+    /* since we have a tickless slider, make sure we are at 0.0 or 1.0 */
+    if ([fDisplayLinkSlider floatValue] < 0.50)
     {
-        anim = HB_ANIMATE_NONE;
+        [fDisplayLinkSlider setFloatValue:0.0];
+        /* set slider labels to reflect choice */
+        [fDisplayLinkStorageLabel setEnabled:YES];
+        [fDisplayLinkParLabel setEnabled:NO];
     }
-    else if( [[NSApp currentEvent] modifierFlags] & NSShiftKeyMask )
+    else
     {
-        anim |= HB_ANIMATE_SLOW;
+        [fDisplayLinkSlider setFloatValue:1.0];
+        /* set slider labels to reflect choice */
+        [fDisplayLinkStorageLabel setEnabled:NO];
+        [fDisplayLinkParLabel setEnabled:YES];
     }
     
-    [fPictureGLView Display: anim buffer1: fTexBuf[0]
-                    buffer2: fTexBuf[1] width: ( fTitle->width + 2 )
-                     height: ( fTitle->height + 2 )];
-       
-       NSSize displaySize = NSMakeSize( (float)fTitle->width, (float)fTitle->height );
-    /* Set the picture size display fields below the Preview Picture*/
-    if( fTitle->job->pixel_ratio == 1 ) // Original PAR Implementation
-    {
-        output_width = fTitle->width-fTitle->job->crop[2]-fTitle->job->crop[3];
-        output_height = fTitle->height-fTitle->job->crop[0]-fTitle->job->crop[1];
-        display_width = output_width * fTitle->job->pixel_aspect_width / fTitle->job->pixel_aspect_height;
-        [fInfoField setStringValue:[NSString stringWithFormat:
-                                    @"Source: %dx%d, Output: %dx%d, Anamorphic: %dx%d",
-                                    fTitle->width, fTitle->height, output_width, output_height, display_width, output_height]];
-        displaySize.width *= ((float)fTitle->job->pixel_aspect_width) / ((float)fTitle->job->pixel_aspect_height);   
-    }
-    else if (fTitle->job->pixel_ratio == 2) // Loose Anamorphic
-    {
-        display_width = output_width * output_par_width / output_par_height;
-        [fInfoField setStringValue:[NSString stringWithFormat:
-                                    @"Source: %dx%d, Output: %dx%d, Anamorphic: %dx%d",
-                                    fTitle->width, fTitle->height, output_width, output_height, display_width, output_height]];
-        
-        /* FIXME: needs to be fixed so that the picture window does not resize itself on the first
-         anamorphic width drop
-         */
-        if (fTitle->width - 8 < output_width)
-        {
-            displaySize.width *= ((float)output_par_width) / ((float)output_par_height);
-        }
+}    
+
+- (IBAction) SettingsChanged: (id) sender
+{
+    hb_job_t * job = fTitle->job;
+    [fModulusPopUp setEnabled:NO];
+    job->anamorphic.modulus = 16;
+
+    /* Since custom anamorphic allows for a height setting > fTitle->height
+     * check to make sure it is returned to fTitle->height for all other modes
+     */
+     [fHeightStepper setMaxValue: fTitle->height];
+    
+    autoCrop = ( [fCropMatrix selectedRow] == 0 );
+    [fCropTopStepper    setEnabled: !autoCrop];
+    [fCropBottomStepper setEnabled: !autoCrop];
+    [fCropLeftStepper   setEnabled: !autoCrop];
+    [fCropRightStepper  setEnabled: !autoCrop];
+    
+    if( autoCrop )
+    {
+        memcpy( job->crop, fTitle->crop, 4 * sizeof( int ) );
     }
-    else // No Anamorphic
+    else
     {
-        [fInfoField setStringValue: [NSString stringWithFormat:
-                                     @"Source: %dx%d, Output: %dx%d", fTitle->width, fTitle->height,
-                                     fTitle->job->width, fTitle->job->height]];
+        job->crop[0] = [fCropTopStepper    intValue];
+        job->crop[1] = [fCropBottomStepper intValue];
+        job->crop[2] = [fCropLeftStepper   intValue];
+        job->crop[3] = [fCropRightStepper  intValue];
     }
     
-    NSSize viewSize = [self optimalViewSizeForImageSize:displaySize];
-    if( [self viewNeedsToResizeToSize:viewSize] )
+    [fRatioCheck setEnabled: YES];
+
+    
+    [fParWidthField setEnabled: NO];
+    [fParHeightField setEnabled: NO];
+    [fDisplayWidthField setEnabled: NO];
+    
+    /* If we are not custom anamorphic, make sure we retain the orginal par */
+    if( [fAnamorphicPopUp indexOfSelectedItem] != 3 )
     {
-        [self resizeSheetForViewSize:viewSize];
-        [self setViewSize:viewSize];
+        job->anamorphic.par_width = titleParWidth;
+        job->anamorphic.par_height = titleParHeight;
+        [fRatioLabel setHidden: NO];
+        
+        [fWidthStepper  setIncrement: 16];
+        [fHeightStepper setIncrement: 16];
     }
-    
-    // Show the scaled text (use the height to check since the width can vary
-    // with anamorphic video).
-    if( ((int)viewSize.height) != fTitle->height )
+    else
     {
-        float scale = viewSize.width / ((float)fTitle->width);
-        NSString *scaleString = [NSString stringWithFormat:
-                                 NSLocalizedString( @" (Preview scaled to %.0f%% actual size)",
-                                                   @"String shown when a preview is scaled" ),
-                                 scale * 100.0];
-        [fInfoField setStringValue:
-         [[fInfoField stringValue] stringByAppendingString:scaleString]];
+        [fWidthStepper  setIncrement: [[fModulusPopUp titleOfSelectedItem] intValue]];
+        [fHeightStepper setIncrement: [[fModulusPopUp titleOfSelectedItem] intValue]];
     }
     
-    [fPrevButton setEnabled: ( fPicture > 0 )];
-    [fNextButton setEnabled: ( fPicture < 9 )];
-}
-
-- (IBAction) SettingsChanged: (id) sender
-{
-    hb_job_t * job = fTitle->job;
-    
        if( [fAnamorphicPopUp indexOfSelectedItem] > 0 )
        {
-        if ([fAnamorphicPopUp indexOfSelectedItem] == 2) // Loose anamorphic
+        if ([fAnamorphicPopUp indexOfSelectedItem] == 1) // strict
+        {
+            [fWidthStepper      setIntValue: fTitle->width-fTitle->job->crop[2]-fTitle->job->crop[3]];
+            [fWidthField        setIntValue: fTitle->width-fTitle->job->crop[2]-fTitle->job->crop[3]];
+            
+            /* This will show correct anamorphic height values, but
+             show distorted preview picture ratio */
+            [fHeightStepper      setIntValue: fTitle->height-fTitle->job->crop[0]-fTitle->job->crop[1]];
+            [fHeightField        setIntValue: fTitle->height-fTitle->job->crop[0]-fTitle->job->crop[1]];
+            job->width       = [fWidthStepper  intValue];
+            job->height      = [fHeightStepper intValue];
+            
+            job->anamorphic.mode = 1;
+            [fWidthStepper setEnabled: NO];
+            [fWidthField setEnabled: NO];
+            [fHeightStepper setEnabled: NO];
+            [fHeightField setEnabled: NO];
+        }
+        else if ([fAnamorphicPopUp indexOfSelectedItem] == 2) // Loose anamorphic
         {
-            job->pixel_ratio = 2;
+            job->anamorphic.mode = 2;
             [fWidthStepper setEnabled: YES];
             [fWidthField setEnabled: YES];
+            [fRatioCheck setEnabled: NO];
+            [fHeightStepper setEnabled: NO];
+            [fHeightField setEnabled: NO];
             /* We set job->width and call hb_set_anamorphic_size in libhb to do a "dry run" to get
              * the values to be used by libhb for loose anamorphic
              */
+            /* if the sender is the anamorphic popup, then we know that loose anamorphic has just
+             * been turned on, so snap the width to full width for the source.
+             */
+            if (sender == fAnamorphicPopUp)
+            {
+                [fWidthStepper      setIntValue: fTitle->width-fTitle->job->crop[2]-fTitle->job->crop[3]];
+                [fWidthField        setIntValue: fTitle->width-fTitle->job->crop[2]-fTitle->job->crop[3]];
+            }
             job->width       = [fWidthStepper  intValue];
             hb_set_anamorphic_size(job, &output_width, &output_height, &output_par_width, &output_par_height);
             [fHeightStepper      setIntValue: output_height];
@@ -292,21 +746,206 @@ are maintained across different sources */
             job->height      = [fHeightStepper intValue];
             
         }
-        else // must be "1" or strict anamorphic
+        else if ([fAnamorphicPopUp indexOfSelectedItem] == 3) // custom / power user jamboree
         {
-            [fWidthStepper      setIntValue: fTitle->width-fTitle->job->crop[2]-fTitle->job->crop[3]];
-            [fWidthField        setIntValue: fTitle->width-fTitle->job->crop[2]-fTitle->job->crop[3]];
+
+#pragma mark - STARTCapuj
+
+            job->anamorphic.mode = 3;
             
-            /* This will show correct anamorphic height values, but
-             show distorted preview picture ratio */
-            [fHeightStepper      setIntValue: fTitle->height-fTitle->job->crop[0]-fTitle->job->crop[1]];
-            [fHeightField        setIntValue: fTitle->height-fTitle->job->crop[0]-fTitle->job->crop[1]];
-            job->width       = [fWidthStepper  intValue];
-            job->height      = [fHeightStepper intValue];
+            /* Set the status of our custom ana only widgets accordingly */
+            /* for mod 3 we can use modulus other than 16 */
+            [fModulusPopUp setEnabled:YES];
+            job->anamorphic.modulus = [[fModulusPopUp titleOfSelectedItem] intValue];
             
-            job->pixel_ratio = 1;
-            [fWidthStepper setEnabled: NO];
-            [fWidthField setEnabled: NO];
+            [fWidthStepper setEnabled: YES];
+            [fWidthField setEnabled: YES];
+            
+            [fHeightStepper setEnabled: YES];
+            /* for capuj the storage field is immaterial */
+            [fHeightField setEnabled: YES];
+            
+            [fRatioCheck setEnabled: YES];
+            if (sender == fRatioCheck)
+            {
+                if ([fRatioCheck  state] == NSOnState)
+                {
+                    [fParWidthField setEnabled: NO];
+                    [fParHeightField setEnabled: NO];   
+                }
+                else
+                {
+                    [fParWidthField setEnabled: YES];
+                    [fParHeightField setEnabled: YES];
+                }
+            }
+            
+            [fParWidthField setEnabled: YES];
+            [fParHeightField setEnabled: YES];
+            
+            [fDisplayWidthField setEnabled: YES];
+            
+            
+            /* If we are coming into custom ana or if in custom ana and the 
+             * keep ar checkbox is checked, we reset the par to original
+             * which gives us a way back if things are hosed up
+             */
+             
+            if (sender == fAnamorphicPopUp || (sender == fRatioCheck && [fRatioCheck  state] == NSOnState))
+            {
+                if (sender == fAnamorphicPopUp)
+                {
+                    [fRatioCheck  setState: NSOnState];
+                }
+                
+                /*
+                 KEEPING ASPECT RATIO
+                 Disable editing: PIXEL WIDTH, PIXEL HEIGHT
+                 */
+                [fParWidthField setEnabled: NO];
+                [fParHeightField setEnabled: NO];
+                
+                job->width = [fWidthStepper intValue];
+                job->height = [fHeightStepper intValue];
+
+                /* make sure our par is set back to original */
+                job->anamorphic.par_width = titleParWidth;
+                job->anamorphic.par_height = titleParHeight;
+                
+                [fParWidthField   setIntValue: titleParWidth];
+                [fParHeightField   setIntValue: titleParHeight];
+                
+                /* modify our par dims from our storage dims */
+                hb_set_anamorphic_size(job, &output_width, &output_height, &output_par_width, &output_par_height);
+                float par_display_width = (float)output_width * (float)output_par_width / (float)output_par_height;
+                
+                /* go ahead and mod the display dims */
+                [fDisplayWidthField   setStringValue: [NSString stringWithFormat:@"%.2f", par_display_width]];
+                
+                job->anamorphic.dar_width = [fDisplayWidthField floatValue];
+                job->anamorphic.dar_height = (float)[fHeightStepper intValue];
+                
+                /* Set our dar here assuming we are just coming into capuj mode */
+                dar = [fDisplayWidthField floatValue] / (float)[fHeightField intValue];
+                
+            }
+
+            /* For capuj we disable these fields if we are keeping the dispay aspect */
+            if ([fRatioCheck  state] == NSOnState)
+            {
+                /*
+                 KEEPING ASPECT RATIO
+                 DAR = DISPLAY WIDTH / DISPLAY HEIGHT (cache after every modification) */
+                 /*Disable editing: PIXEL WIDTH, PIXEL HEIGHT */
+                
+                [fParWidthField setEnabled: NO];
+                [fParHeightField setEnabled: NO];
+                
+                /* Changing DISPLAY WIDTH: */
+                if (sender == fDisplayWidthField)
+                {
+                    job->anamorphic.dar_width = [fDisplayWidthField floatValue];
+                    /* Changes HEIGHT to keep DAR */
+                     /* calculate the height to retain the dar  */
+                    int raw_calulated_height = (int)((int)[fDisplayWidthField floatValue] / dar);
+                    /*  now use the modulus to go lower if there is a remainder  */
+                    /* Note to me, raw_calulated_height % [[fModulusPopUp titleOfSelectedItem] intValue]
+                     * gives me the remainder we are not mod (whatever our modulus is) subtract that from
+                     * the actual calculated value derived from the dar to round down to the nearest mod value.
+                     * This should be desireable over rounding up to the next mod value
+                     */
+                    int modulus_height = raw_calulated_height - (raw_calulated_height % [[fModulusPopUp titleOfSelectedItem] intValue]);
+                    if (modulus_height > fTitle->height)
+                    {
+                        [fHeightStepper setMaxValue: modulus_height];
+                    }
+                    [fHeightStepper setIntValue: modulus_height];
+                    job->anamorphic.dar_height = (float)[fHeightStepper intValue];
+                    job->height = [fHeightStepper intValue];
+                    
+                    /* Changes PIXEL WIDTH to new DISPLAY WIDTH */
+                    [fParWidthField setIntValue: [fDisplayWidthField intValue]];
+                    job->anamorphic.par_width = [fParWidthField intValue];
+                    /* Changes PIXEL HEIGHT to STORAGE WIDTH */
+                    [fParHeightField  setIntValue: [fWidthField intValue]];
+                    job->anamorphic.par_height = [fParHeightField intValue];
+                    
+                }
+                /* Changing HEIGHT: */
+                if (sender == fHeightStepper)
+                {
+                   job->anamorphic.dar_height = (float)[fHeightStepper intValue];
+                   job->height = [fHeightStepper intValue];
+                   
+                    /* Changes DISPLAY WIDTH to keep DAR*/
+                    [fDisplayWidthField setStringValue: [NSString stringWithFormat: @"%.2f",[fHeightStepper intValue] * dar]];
+                    job->anamorphic.dar_width = [fDisplayWidthField floatValue];
+                    /* Changes PIXEL WIDTH to new DISPLAY WIDTH */
+                    [fParWidthField setIntValue: [fDisplayWidthField intValue]];
+                    job->anamorphic.par_width = [fParWidthField intValue];
+                    /* Changes PIXEL HEIGHT to STORAGE WIDTH */
+                    [fParHeightField  setIntValue: [fWidthField intValue]];
+                    job->anamorphic.par_height = [fParHeightField intValue];
+                }
+                /* Changing STORAGE_WIDTH: */
+                if (sender == fWidthStepper)
+                {
+                    job->width = [fWidthStepper intValue];
+                    
+                    job->anamorphic.dar_width = [fDisplayWidthField floatValue];
+                    job->anamorphic.dar_height = [fHeightStepper floatValue];
+                     
+                    /* Changes PIXEL WIDTH to DISPLAY WIDTH */
+                    [fParWidthField setIntValue: [fDisplayWidthField intValue]];
+                    job->anamorphic.par_width = [fParWidthField intValue];
+                    /* Changes PIXEL HEIGHT to new STORAGE WIDTH */
+                    [fParHeightField  setIntValue: [fWidthStepper intValue]];
+                    job->anamorphic.par_height = [fParHeightField intValue];
+                }
+            }
+            else if ([fRatioCheck  state] == NSOffState)
+            {
+                /* Changing STORAGE_WIDTH: */
+                if (sender == fWidthStepper)
+                {
+                    job->width = [fWidthStepper intValue];
+                    /* changes DISPLAY WIDTH to STORAGE WIDTH * PIXEL WIDTH / PIXEL HEIGHT */
+                    [fDisplayWidthField setStringValue: [NSString stringWithFormat: @"%.2f",(float)[fWidthStepper intValue] * [fParWidthField intValue] / [fParHeightField intValue]]];
+                    job->anamorphic.dar_width = [fDisplayWidthField floatValue];
+                }
+                /* Changing PIXEL dimensions */
+                if (sender == fParWidthField || sender == fParHeightField)
+                {
+                    job->anamorphic.par_width = [fParWidthField intValue];
+                    job->anamorphic.par_height = [fParHeightField intValue];
+                    /* changes DISPLAY WIDTH to STORAGE WIDTH * PIXEL WIDTH / PIXEL HEIGHT */
+                    [fDisplayWidthField setStringValue: [NSString stringWithFormat: @"%.2f",(float)[fWidthStepper intValue] * [fParWidthField intValue] / [fParHeightField intValue]]];
+                    job->anamorphic.dar_width = [fDisplayWidthField floatValue];
+                }
+                /* Changing DISPLAY WIDTH: */
+                if (sender == fDisplayWidthField)
+                {
+                    job->anamorphic.dar_width = [fDisplayWidthField floatValue];
+                    job->anamorphic.dar_height = (float)[fHeightStepper intValue];
+                    /* changes PIXEL WIDTH to DISPLAY WIDTH and PIXEL HEIGHT to STORAGE WIDTH */
+                    [fParWidthField setIntValue: [fDisplayWidthField intValue]];
+                    job->anamorphic.par_width = [fParWidthField intValue];
+                    
+                    [fParHeightField  setIntValue: [fWidthField intValue]];
+                    job->anamorphic.par_height = [fParHeightField intValue];
+                    hb_set_anamorphic_size(job, &output_width, &output_height, &output_par_width, &output_par_height);
+                }
+                /* Changing HEIGHT: */
+                if (sender == fHeightStepper)
+                {
+                    /* just....changes the height.*/
+                    job->anamorphic.dar_height = [fHeightStepper intValue];
+                    job->height = [fHeightStepper intValue];
+                }
+                
+            }
+            
+#pragma mark - END Capuj                       
         }
         
         /* if the sender is the Anamorphic checkbox, record the state
@@ -315,19 +954,17 @@ are maintained across different sources */
         {
             keepAspectRatioPreviousState = [fRatioCheck state];
         }
-        [fRatioCheck setState:NSOffState];
-        [fRatioCheck setEnabled: NO];
-        
-        
-        [fHeightStepper setEnabled: NO];
-        [fHeightField setEnabled: NO];
+        if ([fAnamorphicPopUp indexOfSelectedItem] != 3)
+        {
+            [fRatioCheck setState:NSOffState];
+        }
         
     }
     else
        {
         job->width       = [fWidthStepper  intValue];
         job->height      = [fHeightStepper intValue];
-        job->pixel_ratio = 0;
+        job->anamorphic.mode = 0;
         [fWidthStepper setEnabled: YES];
         [fWidthField setEnabled: YES];
         [fHeightStepper setEnabled: YES];
@@ -342,84 +979,59 @@ are maintained across different sources */
         
        }
        
+    //job->keep_ratio  = ( [fRatioCheck state] == NSOnState );
     
-    job->keep_ratio  = ( [fRatioCheck state] == NSOnState );
-    
-       fPictureFilterSettings.deinterlace = [fDeinterlacePopUp indexOfSelectedItem];
-    /* if the gui deinterlace settings are fast through slowest, the job->deinterlace
-     value needs to be set to one, for the job as well as the previews showing deinterlacing
-     otherwise set job->deinterlace to 0 or "off" */
-    if (fPictureFilterSettings.deinterlace > 0)
-    {
-        job->deinterlace  = 1;
-    }
-    else
-    {
-        job->deinterlace  = 0;
-    }
-    fPictureFilterSettings.denoise     = [fDenoisePopUp indexOfSelectedItem];
-    fPictureFilterSettings.vfr  = [fVFRCheck state];
-    if (fPictureFilterSettings.vfr > 0)
-    {
-        [fDetelecineCheck setState:NSOnState];
-        [fDetelecineCheck setEnabled: NO];
-    }
-    else
-    {
-        [fDetelecineCheck setEnabled: YES];
-    }
-    fPictureFilterSettings.detelecine  = [fDetelecineCheck state];
-    fPictureFilterSettings.deblock  = [fDeblockCheck state];
-       //job->pixel_ratio = ( [fPARCheck state] == NSOnState );
-    
-    autoCrop = ( [fCropMatrix selectedRow] == 0 );
-    [fCropTopStepper    setEnabled: !autoCrop];
-    [fCropBottomStepper setEnabled: !autoCrop];
-    [fCropLeftStepper   setEnabled: !autoCrop];
-    [fCropRightStepper  setEnabled: !autoCrop];
-    
-    if( autoCrop )
-    {
-        memcpy( job->crop, fTitle->crop, 4 * sizeof( int ) );
-    }
-    else
-    {
-        job->crop[0] = [fCropTopStepper    intValue];
-        job->crop[1] = [fCropBottomStepper intValue];
-        job->crop[2] = [fCropLeftStepper   intValue];
-        job->crop[3] = [fCropRightStepper  intValue];
-    }
-    
-    if( job->keep_ratio )
+    if ([fAnamorphicPopUp indexOfSelectedItem] != 3)
     {
-        if( sender == fWidthStepper || sender == fRatioCheck ||
-           sender == fCropTopStepper || sender == fCropBottomStepper )
+    job->keep_ratio  = ( [fRatioCheck state] == NSOnState );
+            if( job->keep_ratio )
         {
-            hb_fix_aspect( job, HB_KEEP_WIDTH );
-            if( job->height > fTitle->height )
+            if( sender == fWidthStepper || sender == fRatioCheck ||
+               sender == fCropTopStepper || sender == fCropBottomStepper )
+            {
+                hb_fix_aspect( job, HB_KEEP_WIDTH );
+                if( job->height > fTitle->height )
+                {
+                    job->height = fTitle->height;
+                    hb_fix_aspect( job, HB_KEEP_HEIGHT );
+                }
+            }
+            else
             {
-                job->height = fTitle->height;
                 hb_fix_aspect( job, HB_KEEP_HEIGHT );
+                if( job->width > fTitle->width )
+                {
+                    job->width = fTitle->width;
+                    hb_fix_aspect( job, HB_KEEP_WIDTH );
+                }
             }
+            
         }
-        else
+    }
+    
+    // hb_get_preview can't handle sizes that are larger than the original title
+    if ([fAnamorphicPopUp indexOfSelectedItem] != 3)
+    {
+        // dimensions
+        if( job->width > fTitle->width )
         {
-            hb_fix_aspect( job, HB_KEEP_HEIGHT );
-            if( job->width > fTitle->width )
-            {
-                job->width = fTitle->width;
-                hb_fix_aspect( job, HB_KEEP_WIDTH );
-            }
+            job->width = fTitle->width;
+        }
+        
+        if( job->height > fTitle->height )
+        {
+            job->height = fTitle->height;
         }
     }
     
     [fWidthStepper      setIntValue: job->width];
     [fWidthField        setIntValue: job->width];
-    if( [fAnamorphicPopUp indexOfSelectedItem] < 2 )
-       {
+    if( [fAnamorphicPopUp indexOfSelectedItem] != 2) // if we are not loose or custom
+    {
         [fHeightStepper     setIntValue: job->height];
         [fHeightField       setIntValue: job->height];
     }
+    
     [fCropTopStepper    setIntValue: job->crop[0]];
     [fCropTopField      setIntValue: job->crop[0]];
     [fCropBottomStepper setIntValue: job->crop[1]];
@@ -428,44 +1040,64 @@ are maintained across different sources */
     [fCropLeftField     setIntValue: job->crop[2]];
     [fCropRightStepper  setIntValue: job->crop[3]];
     [fCropRightField    setIntValue: job->crop[3]];
+    
+    //[fPreviewController SetTitle:fTitle];
+    
     /* Sanity Check Here for < 16 px preview to avoid
      crashing hb_get_preview. In fact, just for kicks
      lets getting previews at a min limit of 32, since
      no human can see any meaningful detail below that */
     if (job->width >= 64 && job->height >= 64)
     {
-        [self Display: HB_ANIMATE_NONE];
+        [self reloadStillPreview];
     }
-}
-
-- (IBAction) PreviousPicture: (id) sender
-{   
-    if( fPicture <= 0 )
+    
+    /* we get the sizing info to display from fPreviewController */
+    [fSizeInfoField setStringValue: [fPreviewController pictureSizeInfoString]];
+    
+    if (sender != nil)
     {
-        return;
+        [fHBController pictureSettingsDidChange];
+    }   
+    
+    if ([[self window] isVisible])
+    { 
+        [self adjustSizingDisplay:nil];
     }
-    fPicture--;
-    [self Display: HB_ANIMATE_BACKWARD];
+    
 }
 
-- (IBAction) NextPicture: (id) sender
+- (NSString*) getPictureSizeInfoString
 {
-    if( fPicture >= 9 )
+    return [fSizeInfoField stringValue];
+}
+
+- (void)reloadStillPreview
+{ 
+   hb_job_t * job = fTitle->job; 
+   
+   [fPreviewController SetTitle:fTitle];
+    /* Sanity Check Here for < 16 px preview to avoid
+     crashing hb_get_preview. In fact, just for kicks
+     lets getting previews at a min limit of 32, since
+     no human can see any meaningful detail below that */
+    if (job->width >= 64 && job->height >= 64)
     {
-        return;
+       
+         // Purge the existing picture previews so they get recreated the next time
+        // they are needed.
+      //  [fPreviewController purgeImageCache];
+        /* We actually call displayPreview now from pictureSliderChanged which keeps
+         * our picture preview slider in sync with the previews being shown
+         */
+
+    //[fPreviewController pictureSliderChanged:nil];
     }
-    fPicture++;
-    [self Display: HB_ANIMATE_FORWARD];
+    
 }
 
-- (IBAction) ClosePanel: (id) sender
-{
-    if ([delegate respondsToSelector:@selector(pictureSettingsDidChange)])
-        [delegate pictureSettingsDidChange];
-        
-    [NSApp endSheet: fPicturePanel];
-    [fPicturePanel orderOut: self];
-}
+
+#pragma mark -
 
 - (BOOL) autoCrop
 {
@@ -486,192 +1118,269 @@ are maintained across different sources */
     allowLooseAnamorphic = setting;
 }
 
-- (int) detelecine
+- (IBAction)showPreviewPanel: (id)sender forTitle: (hb_title_t *)title
 {
-    return fPictureFilterSettings.detelecine;
+    //[self SetTitle:title];
+    [self showWindow:sender];
+    //[self adjustSizingDisplay:nil];
+    //[self adjustFilterDisplay:nil];
+
 }
 
-- (void) setDetelecine: (int) setting
+
+#pragma mark -
+/* we use this to setup the initial picture filters upon first launch, after that their states
+are maintained across different sources */
+- (void) setInitialPictureFilters
 {
-    fPictureFilterSettings.detelecine = setting;
+       /* we use a popup to show the detelecine settings */
+       [fDetelecinePopUp removeAllItems];
+    [fDetelecinePopUp addItemWithTitle: @"Off"];
+    [fDetelecinePopUp addItemWithTitle: @"Default"];
+    [fDetelecinePopUp addItemWithTitle: @"Custom"];
+    [fDetelecinePopUp selectItemAtIndex: fPictureFilterSettings.detelecine];
+    
+    [self modeDecombDeinterlaceSliderChanged:nil];
+    /* we use a popup to show the decomb settings */
+       [fDecombPopUp removeAllItems];
+    [fDecombPopUp addItemWithTitle: @"Off"];
+    [fDecombPopUp addItemWithTitle: @"Default"];
+    [fDecombPopUp addItemWithTitle: @"Custom"];
+    [fDecombPopUp selectItemAtIndex: fPictureFilterSettings.decomb];
+    
+    /* we use a popup to show the deinterlace settings */
+       [fDeinterlacePopUp removeAllItems];
+    [fDeinterlacePopUp addItemWithTitle: @"None"];
+    [fDeinterlacePopUp addItemWithTitle: @"Fast"];
+    [fDeinterlacePopUp addItemWithTitle: @"Slow"];
+       [fDeinterlacePopUp addItemWithTitle: @"Slower"];
+    [fDeinterlacePopUp addItemWithTitle: @"Custom"];
+    
+       /* Set deinterlaces level according to the integer in the main window */
+       [fDeinterlacePopUp selectItemAtIndex: fPictureFilterSettings.deinterlace];
+
+       /* we use a popup to show the denoise settings */
+       [fDenoisePopUp removeAllItems];
+    [fDenoisePopUp addItemWithTitle: @"None"];
+    [fDenoisePopUp addItemWithTitle: @"Weak"];
+       [fDenoisePopUp addItemWithTitle: @"Medium"];
+    [fDenoisePopUp addItemWithTitle: @"Strong"];
+    [fDenoisePopUp addItemWithTitle: @"Custom"];
+       /* Set denoises level according to the integer in the main window */
+       [fDenoisePopUp selectItemAtIndex: fPictureFilterSettings.denoise];
+    
+
 }
 
-- (int) vfr
+
+
+
+- (IBAction) modeDecombDeinterlaceSliderChanged: (id) sender
 {
-    return fPictureFilterSettings.vfr;
+    
+    /* since its a tickless slider, we have to  make sure we are on or off */
+    if ([fDecombDeinterlaceSlider floatValue] < 0.50)
+    {
+        [fDecombDeinterlaceSlider setFloatValue:0.0];
+    }
+    else
+    {
+        [fDecombDeinterlaceSlider setFloatValue:1.0];
+    }
+    
+    
+    /* Decomb selected*/
+    if ([fDecombDeinterlaceSlider floatValue] == 0.0)
+    {
+        [fDecombBox setHidden:NO];
+        [fDeinterlaceBox setHidden:YES];
+        fPictureFilterSettings.decomb = [fDecombPopUp indexOfSelectedItem];
+        fPictureFilterSettings.usedecomb = 1;
+        fPictureFilterSettings.deinterlace = 0;
+        [fDecombPopUp selectItemAtIndex:fPictureFilterSettings.decomb];
+        [self adjustFilterDisplay:fDecombPopUp];
+    }
+    else
+    {
+        [fDecombBox setHidden:YES];
+        [fDeinterlaceBox setHidden:NO];
+        fPictureFilterSettings.usedecomb = 0;
+        fPictureFilterSettings.decomb = 0;
+        [fDeinterlacePopUp selectItemAtIndex: fPictureFilterSettings.deinterlace];
+        [self adjustFilterDisplay:fDeinterlacePopUp];
+    }
+    [self FilterSettingsChanged: fDecombDeinterlaceSlider];
 }
 
-- (void) setVFR: (int) setting
+
+- (IBAction) FilterSettingsChanged: (id) sender
 {
-    fPictureFilterSettings.vfr = setting;
+    
+    fPictureFilterSettings.detelecine  = [fDetelecinePopUp indexOfSelectedItem];
+    [self adjustFilterDisplay:fDetelecinePopUp];
+    
+    fPictureFilterSettings.decomb = [fDecombPopUp indexOfSelectedItem];
+    [self adjustFilterDisplay:fDecombPopUp];
+    
+    fPictureFilterSettings.deinterlace = [fDeinterlacePopUp indexOfSelectedItem];
+    [self adjustFilterDisplay:fDeinterlacePopUp];
+    
+    fPictureFilterSettings.denoise = [fDenoisePopUp indexOfSelectedItem];
+    [self adjustFilterDisplay:fDenoisePopUp];
+    
+    if ([fDeblockField stringValue] == @"Off")
+    {
+        fPictureFilterSettings.deblock  = 0;
+    }
+    else
+    {
+        fPictureFilterSettings.deblock  = [fDeblockField intValue];
+    }
+    
+    fPictureFilterSettings.grayscale = [fGrayscaleCheck state];
+    
+    if (sender != nil)
+    {
+        [fHBController pictureSettingsDidChange];
+        
+    }   
+
 }
 
-- (int) deinterlace
+
+#pragma mark -
+
+- (IBAction) deblockSliderChanged: (id) sender
 {
-    return fPictureFilterSettings.deinterlace;
+    if ([fDeblockSlider floatValue] == 4.0)
+    {
+    [fDeblockField setStringValue: [NSString stringWithFormat: @"Off"]];
+    }
+    else
+    {
+    [fDeblockField setStringValue: [NSString stringWithFormat: @"%.0f", [fDeblockSlider floatValue]]];
+    }
+       [self FilterSettingsChanged: sender];
 }
 
-- (void) setDeinterlace: (int) setting {
-    fPictureFilterSettings.deinterlace = setting;
+
+- (int) detelecine
+{
+    return fPictureFilterSettings.detelecine;
 }
 
-- (int) denoise
+- (NSString*) detelecineCustomString
 {
-    return fPictureFilterSettings.denoise;
+    return [fDetelecineField stringValue];
 }
 
-- (void) setDenoise: (int) setting
+- (void) setDetelecine: (int) setting
 {
-    fPictureFilterSettings.denoise = setting;
+    fPictureFilterSettings.detelecine = setting;
 }
 
-- (int) deblock
+- (void) setDetelecineCustomString: (NSString*) string 
 {
-    return fPictureFilterSettings.deblock;
+    [fDetelecineField setStringValue:string];
 }
 
-- (void) setDeblock: (int) setting
+- (int) deinterlace
 {
-    fPictureFilterSettings.deblock = setting;
+    return fPictureFilterSettings.deinterlace;
+}
+- (NSString*) deinterlaceCustomString
+{
+    return [fDeinterlaceField stringValue];
 }
 
-- (void)showPanelInWindow: (NSWindow *)fWindow forTitle: (hb_title_t *)title
+- (void) setDeinterlaceCustomString: (NSString*) string 
 {
-    [self SetTitle:title];
-    
-    [NSApp beginSheet:fPicturePanel
-       modalForWindow:fWindow
-        modalDelegate:nil
-       didEndSelector:nil
-          contextInfo:NULL];
+    [fDeinterlaceField setStringValue:string];
 }
 
-- (BOOL) loadMyNibFile
+- (void) setDeinterlace: (int) setting 
 {
-    if(![NSBundle loadNibNamed:@"PictureSettings" owner:self])
-    {
-        NSLog(@"Warning! Could not load myNib file.\n");
-        return NO;
-    }
-    
-    return YES;
+    fPictureFilterSettings.deinterlace = setting;
+}
+- (int) decomb
+{
+    return fPictureFilterSettings.decomb;
 }
 
-@end
+- (NSString*) decombCustomString
+{
+    return [fDecombField stringValue];
+}
 
-@implementation PictureController (Private)
+- (int) useDecomb
+{
+    return fPictureFilterSettings.usedecomb;
+}
 
-//
-// -[PictureController(Private) optimalViewSizeForImageSize:]
-//
-// Given the size of the preview image to be shown, returns the best possible
-// size for the OpenGL view.
-//
-- (NSSize)optimalViewSizeForImageSize: (NSSize)imageSize
+- (void) setUseDecomb: (int) setting
 {
-    // The min size is 320x240
-    float minWidth = 320.0;
-    float minHeight = 240.0;
-    
-    // The max size of the view is when the sheet is taking up 85% of the screen.
-    NSSize screenSize = [[NSScreen mainScreen] frame].size;
-    NSSize sheetSize = [fPicturePanel frame].size;
-    NSSize viewAreaSize = [fPictureGLViewArea frame].size;
-    float paddingX = sheetSize.width - viewAreaSize.width;
-    float paddingY = sheetSize.height - viewAreaSize.height;
-    float maxWidth = (0.85 * screenSize.width) - paddingX;
-    float maxHeight = (0.85 * screenSize.height) - paddingY;
-    
-    NSSize resultSize = imageSize;
-    
-    // Its better to have a view that's too small than a view that's too big, so
-    // apply the maximum constraints last.
-    if( resultSize.width < minWidth )
+    fPictureFilterSettings.usedecomb = setting;
+    if (fPictureFilterSettings.usedecomb == 1)
     {
-        resultSize.height *= (minWidth / resultSize.width);
-        resultSize.width = minWidth;
+        [fDecombDeinterlaceSlider setFloatValue:0.0];
     }
-    if( resultSize.height < minHeight )
-    {
-        resultSize.width *= (minHeight / resultSize.height);
-        resultSize.height = minHeight;
-    }
-    if( resultSize.width > maxWidth )
-    {
-        resultSize.height *= (maxWidth / resultSize.width);
-        resultSize.width = maxWidth;
-    }
-    if( resultSize.height > maxHeight )
+    else
     {
-        resultSize.width *= (maxHeight / resultSize.height);
-        resultSize.height = maxHeight;
+        [fDecombDeinterlaceSlider setFloatValue:1.0];
     }
-    
-    return resultSize;
+    [self modeDecombDeinterlaceSliderChanged:nil];
+}
+
+- (void) setDecomb: (int) setting {
+    fPictureFilterSettings.decomb = setting;
 }
 
-//
-// -[PictureController(Private) resizePanelForViewSize:animate:]
-//
-// Resizes the entire sheet to accomodate an OpenGL view of a particular size.
-//
-- (void)resizeSheetForViewSize: (NSSize)viewSize
+- (void) setDecombCustomString: (NSString*) string 
 {
-    // Figure out the deltas for the new frame area
-    NSSize currentSize = [fPictureGLViewArea frame].size;
-    float deltaX = viewSize.width - currentSize.width;
-    float deltaY = viewSize.height - currentSize.height;
-    
-    // Now resize the whole panel by those same deltas, but don't exceed the min
-    NSRect frame = [fPicturePanel frame];
-    NSSize maxSize = [fPicturePanel maxSize];
-    NSSize minSize = [fPicturePanel minSize];
-    frame.size.width += deltaX;
-    frame.size.height += deltaY;
-    if( frame.size.width < minSize.width )
-    {
-        frame.size.width = minSize.width;
-    }
-    if( frame.size.height < minSize.height )
-    {
-        frame.size.height = minSize.height;
-    }
+    [fDecombField setStringValue:string];
+}
+
+- (int) denoise
+{
+    return fPictureFilterSettings.denoise;
+}
 
-    // But now the sheet is off-center, so also shift the origin to center it and
-    // keep the top aligned.
-    frame.origin.x -= (deltaX / 2.0);
-    frame.origin.y -= deltaY;
+- (NSString*) denoiseCustomString
+{
+    return [fDenoiseField stringValue];
+}
 
-    [fPicturePanel setFrame:frame display:YES animate:YES];
+- (void) setDenoiseCustomString: (NSString*) string 
+{
+    [fDenoiseField setStringValue:string];
 }
 
-//
-// -[PictureController(Private) setViewSize:]
-//
-// Changes the OpenGL view's size and centers it vertially inside of its area.
-// Assumes resizeSheetForViewSize: has already been called.
-//
-- (void)setViewSize: (NSSize)viewSize
+- (void) setDenoise: (int) setting
 {
-    [fPictureGLView setFrameSize:viewSize];
-    
-    // center it vertically
-    NSPoint origin = [fPictureGLViewArea frame].origin;
-    origin.y += ([fPictureGLViewArea frame].size.height -
-                 [fPictureGLView frame].size.height) / 2.0;
-    [fPictureGLView setFrameOrigin:origin];
+    fPictureFilterSettings.denoise = setting;
+}
+
+- (int) deblock
+{
+    return fPictureFilterSettings.deblock;
+}
+
+- (void) setDeblock: (int) setting
+{
+    fPictureFilterSettings.deblock = setting;
+}
+
+- (int) grayscale
+{
+    return fPictureFilterSettings.grayscale;
 }
 
-//
-// -[PictureController(Private) viewNeedsToResizeToSize:]
-//
-// Returns YES if the view will need to resize to match the given size.
-//
-- (BOOL)viewNeedsToResizeToSize: (NSSize)newSize
+- (void) setGrayscale: (int) setting
 {
-    NSSize viewSize = [fPictureGLView frame].size;
-    return (newSize.width != viewSize.width || newSize.height != viewSize.height);
+    fPictureFilterSettings.grayscale = setting;
 }
 
 
+
 @end
+